diff --git a/.gitignore b/.gitignore index 47afe314a..77439d6cf 100644 --- a/.gitignore +++ b/.gitignore @@ -16,4 +16,7 @@ remix-compiler.config.js .yarnrc.yml logs/storage_layout_table.log cache_foundry -out \ No newline at end of file +out +.DS_Store + +dry-run/ \ No newline at end of file diff --git a/.gitmodules b/.gitmodules index 513e3636c..1beb46df6 100644 --- a/.gitmodules +++ b/.gitmodules @@ -9,3 +9,6 @@ path = lib/prb-math url = https://github.com/PaulRBerg/prb-math branch = release-v4 +[submodule "lib/solady"] + path = lib/solady + url = https://github.com/vectorized/solady diff --git a/README.md b/README.md index bb2a182f4..987a6808a 100644 --- a/README.md +++ b/README.md @@ -56,11 +56,11 @@ This repo contains source code of contracts that will be either deployed on the - On mainchains: - Governance contract: `MainchainGovernanceAdmin` - - Bridge contract: `MainchainGatewayV2` + - Bridge contract: `MainchainGatewayV3` - Trusted orgs contract: `RoninTrustedOrganization` - On Ronin chain: - Governance contract: `RoninGovernanceAdmin` - - Bridge operation: `RoninGatewayV2` + - Bridge operation: `RoninGatewayV3` - Trusted orgs contract: `RoninTrustedOrganization` - DPoS contracts diff --git a/contracts/extensions/GatewayV2.sol b/contracts/extensions/GatewayV3.sol similarity index 97% rename from contracts/extensions/GatewayV2.sol rename to contracts/extensions/GatewayV3.sol index 78ed6d152..6b10b19e2 100644 --- a/contracts/extensions/GatewayV2.sol +++ b/contracts/extensions/GatewayV3.sol @@ -5,7 +5,7 @@ import "@openzeppelin/contracts/security/Pausable.sol"; import "../interfaces/IQuorum.sol"; import "./collections/HasProxyAdmin.sol"; -abstract contract GatewayV2 is HasProxyAdmin, Pausable, IQuorum { +abstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum { uint256 internal _num; uint256 internal _denom; diff --git a/contracts/extensions/WithdrawalLimitation.sol b/contracts/extensions/WithdrawalLimitation.sol index c81213a3b..dc95c86f0 100644 --- a/contracts/extensions/WithdrawalLimitation.sol +++ b/contracts/extensions/WithdrawalLimitation.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: MIT pragma solidity ^0.8.0; -import "./GatewayV2.sol"; +import "./GatewayV3.sol"; -abstract contract WithdrawalLimitation is GatewayV2 { +abstract contract WithdrawalLimitation is GatewayV3 { /// @dev Error of invalid percentage. error ErrInvalidPercentage(); @@ -50,7 +50,7 @@ abstract contract WithdrawalLimitation is GatewayV2 { uint256[50] private ______gap; /** - * @dev Override `GatewayV2-setThreshold`. + * @dev Override `GatewayV3-setThreshold`. * * Requirements: * - The high-tier vote weight threshold must equal to or larger than the normal threshold. diff --git a/contracts/extensions/version-control/ConditionalImplementControl.sol b/contracts/extensions/version-control/ConditionalImplementControl.sol index edba5e04c..b88f4f7a5 100644 --- a/contracts/extensions/version-control/ConditionalImplementControl.sol +++ b/contracts/extensions/version-control/ConditionalImplementControl.sol @@ -1,6 +1,7 @@ /// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; +import { HasContracts } from "../collections/HasContracts.sol"; import { IConditionalImplementControl } from "../../interfaces/version-control/IConditionalImplementControl.sol"; import { ErrorHandler } from "../../libraries/ErrorHandler.sol"; import { AddressArrayUtils } from "../../libraries/AddressArrayUtils.sol"; @@ -10,7 +11,7 @@ import { ErrOnlySelfCall, IdentityGuard } from "../../utils/IdentityGuard.sol"; * @title ConditionalImplementControl * @dev A contract that allows conditional version control of contract implementations. */ -abstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard { +abstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts { using ErrorHandler for bool; using AddressArrayUtils for address[]; @@ -21,6 +22,9 @@ abstract contract ConditionalImplementControl is IConditionalImplementControl, I */ bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc; + /// @dev value is equal to keccak256("@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot") - 1 + bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633; + /** * @dev address of the proxy that delegates to this contract. * @notice immutable variables are directly stored in contract code. @@ -99,11 +103,49 @@ abstract contract ConditionalImplementControl is IConditionalImplementControl, I _upgradeTo(NEW_IMPL); } + /** + * @dev See {IConditionalImplementControl-setCallDatas}. + */ + function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage { + bytes[] storage callDatas = _callDatas(); + uint256 length = args.length; + for (uint256 i; i < length; ) { + callDatas.push(args[i]); + + unchecked { + ++i; + } + } + } + + /** + * @dev Internal function to access the array of calldatas. + * @return callDatas the storage array of calldatas. + */ + function _callDatas() internal pure returns (bytes[] storage callDatas) { + assembly ("memory-safe") { + callDatas.slot := CALLDATAS_SLOT + } + } + function _upgradeTo(address newImplementation) internal { assembly ("memory-safe") { sstore(_IMPLEMENTATION_SLOT, newImplementation) } emit Upgraded(newImplementation); + + bytes[] storage callDatas = _callDatas(); + uint256 length = callDatas.length; + bool success; + bytes memory returnOrRevertData; + for (uint256 i; i < length; ) { + (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]); + success.handleRevert(bytes4(callDatas[i]), returnOrRevertData); + + unchecked { + ++i; + } + } } /** diff --git a/contracts/interfaces/IMainchainGatewayV2.sol b/contracts/interfaces/IMainchainGatewayV3.sol similarity index 98% rename from contracts/interfaces/IMainchainGatewayV2.sol rename to contracts/interfaces/IMainchainGatewayV3.sol index 1139de854..5613d0969 100644 --- a/contracts/interfaces/IMainchainGatewayV2.sol +++ b/contracts/interfaces/IMainchainGatewayV3.sol @@ -6,7 +6,7 @@ import "./consumers/SignatureConsumer.sol"; import "./consumers/MappedTokenConsumer.sol"; import "../libraries/Transfer.sol"; -interface IMainchainGatewayV2 is SignatureConsumer, MappedTokenConsumer { +interface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer { /** * @dev Error indicating that a query was made for an approved withdrawal. */ diff --git a/contracts/interfaces/IRoninGatewayV2.sol b/contracts/interfaces/IRoninGatewayV3.sol similarity index 99% rename from contracts/interfaces/IRoninGatewayV2.sol rename to contracts/interfaces/IRoninGatewayV3.sol index 651067f00..7e72bcfac 100644 --- a/contracts/interfaces/IRoninGatewayV2.sol +++ b/contracts/interfaces/IRoninGatewayV3.sol @@ -4,7 +4,7 @@ pragma solidity ^0.8.0; import "../libraries/Transfer.sol"; import "./consumers/MappedTokenConsumer.sol"; -interface IRoninGatewayV2 is MappedTokenConsumer { +interface IRoninGatewayV3 is MappedTokenConsumer { /** * @dev Error thrown when attempting to withdraw funds that have already been migrated. */ diff --git a/contracts/interfaces/bridge/IBridgeSlash.sol b/contracts/interfaces/bridge/IBridgeSlash.sol index 3f73587fd..fd90f78a2 100644 --- a/contracts/interfaces/bridge/IBridgeSlash.sol +++ b/contracts/interfaces/bridge/IBridgeSlash.sol @@ -18,7 +18,7 @@ interface IBridgeSlash is IBridgeSlashEvents { uint256 totalBallot, uint256 totalVote, uint256 period - ) external returns (bool slashed); + ) external; /** * @dev Returns the penalize durations for the specified bridge operators. diff --git a/contracts/interfaces/version-control/IConditionalImplementControl.sol b/contracts/interfaces/version-control/IConditionalImplementControl.sol index e4933b9cc..442a8d108 100644 --- a/contracts/interfaces/version-control/IConditionalImplementControl.sol +++ b/contracts/interfaces/version-control/IConditionalImplementControl.sol @@ -14,4 +14,9 @@ interface IConditionalImplementControl { * @dev Executes the selfUpgrade function, upgrading to the new contract implementation. */ function selfUpgrade() external; + + /** + * @dev Set additional calldata to call when upgrading via `selfUpgrade`. + */ + function setCallDatas(bytes[] calldata args) external; } diff --git a/contracts/libraries/GlobalProposal.sol b/contracts/libraries/GlobalProposal.sol index 47b1450cc..5fd9dd3e4 100644 --- a/contracts/libraries/GlobalProposal.sol +++ b/contracts/libraries/GlobalProposal.sol @@ -13,7 +13,8 @@ library GlobalProposal { /* 0 */ BridgeManager, /* 1 */ GatewayContract, /* 2 */ BridgeReward, - /* 3 */ BridgeSlash + /* 3 */ BridgeSlash, + /* 4 */ BridgeTracking } struct GlobalProposalDetail { diff --git a/contracts/mainchain/MainchainGatewayV2.sol b/contracts/mainchain/MainchainGatewayV3.sol similarity index 97% rename from contracts/mainchain/MainchainGatewayV2.sol rename to contracts/mainchain/MainchainGatewayV3.sol index 03b691409..89a408a7b 100644 --- a/contracts/mainchain/MainchainGatewayV2.sol +++ b/contracts/mainchain/MainchainGatewayV3.sol @@ -8,13 +8,13 @@ import { IBridgeManagerCallback } from "../interfaces/bridge/IBridgeManagerCallb import { HasContracts, ContractType } from "../extensions/collections/HasContracts.sol"; import "../extensions/WithdrawalLimitation.sol"; import "../libraries/Transfer.sol"; -import "../interfaces/IMainchainGatewayV2.sol"; +import "../interfaces/IMainchainGatewayV3.sol"; -contract MainchainGatewayV2 is +contract MainchainGatewayV3 is WithdrawalLimitation, Initializable, AccessControlEnumerable, - IMainchainGatewayV2, + IMainchainGatewayV3, HasContracts { using Token for Token.Info; @@ -112,28 +112,28 @@ contract MainchainGatewayV2 is function receiveEther() external payable {} /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function DOMAIN_SEPARATOR() external view virtual returns (bytes32) { return _domainSeparator; } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin { _setWrappedNativeTokenContract(_wrappedToken); } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused { _requestDepositFor(_request, msg.sender); } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function submitWithdrawal( Transfer.Receipt calldata _receipt, @@ -143,7 +143,7 @@ contract MainchainGatewayV2 is } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) { bytes32 _receiptHash = _receipt.hash(); @@ -173,7 +173,7 @@ contract MainchainGatewayV2 is } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function mapTokens( address[] calldata _mainchainTokens, @@ -185,7 +185,7 @@ contract MainchainGatewayV2 is } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function mapTokensAndThresholds( address[] calldata _mainchainTokens, @@ -206,7 +206,7 @@ contract MainchainGatewayV2 is } /** - * @inheritdoc IMainchainGatewayV2 + * @inheritdoc IMainchainGatewayV3 */ function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) { _token = _roninToken[_mainchainToken]; @@ -444,7 +444,7 @@ contract MainchainGatewayV2 is } /** - * @inheritdoc GatewayV2 + * @inheritdoc GatewayV3 */ function _getTotalWeight() internal view override returns (uint256) { return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight(); diff --git a/contracts/mocks/ronin/MockRoninGatewayV2Extended.sol b/contracts/mocks/ronin/MockRoninGatewayV3Extended.sol similarity index 90% rename from contracts/mocks/ronin/MockRoninGatewayV2Extended.sol rename to contracts/mocks/ronin/MockRoninGatewayV3Extended.sol index 4ef1db097..de7c9c9b4 100644 --- a/contracts/mocks/ronin/MockRoninGatewayV2Extended.sol +++ b/contracts/mocks/ronin/MockRoninGatewayV3Extended.sol @@ -1,9 +1,9 @@ // SPDX-License-Identifier: MIT pragma solidity ^0.8.0; -import "../../ronin/gateway/RoninGatewayV2.sol"; +import "../../ronin/gateway/RoninGatewayV3.sol"; -contract MockRoninGatewayV2Extended is RoninGatewayV2 { +contract MockRoninGatewayV3Extended is RoninGatewayV3 { /* * @dev Returns the vote weight for a deposit based on its corressponding hash. */ diff --git a/contracts/ronin/gateway/BridgeReward.sol b/contracts/ronin/gateway/BridgeReward.sol index f6ece1c3e..edb10d0bc 100644 --- a/contracts/ronin/gateway/BridgeReward.sol +++ b/contracts/ronin/gateway/BridgeReward.sol @@ -43,17 +43,29 @@ contract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONT address bridgeTrackingContract, address bridgeSlashContract, address validatorSetContract, + address dposGA, uint256 rewardPerPeriod ) external payable initializer { _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract); _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract); _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract); _setContract(ContractType.VALIDATOR, validatorSetContract); + _setContract(ContractType.GOVERNANCE_ADMIN, dposGA); + LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max); _setRewardPerPeriod(rewardPerPeriod); - _syncLatestRewardedPeriod(); _receiveRON(); } + /** + * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. + * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()` + */ + function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) { + require(getLatestRewardedPeriod() == type(uint256).max, "already init rep 2"); + LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1); + _setContract(ContractType.GOVERNANCE_ADMIN, address(0)); + } + /** * @inheritdoc IBridgeReward */ @@ -95,6 +107,8 @@ contract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONT /** * @inheritdoc IBridgeReward + * + * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1. */ function execSyncReward( address[] calldata operators, @@ -106,7 +120,7 @@ contract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONT if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig); if (operators.length == 0) return; - // Only sync the period that is after the latest rewarded period. + // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`. unchecked { uint256 latestRewardedPeriod = getLatestRewardedPeriod(); if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig); @@ -195,16 +209,6 @@ contract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONT TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards); } - /** - * @dev Internal function to synchronize the latest rewarded period based on the current period of the validator set contract. - * @notice This function is used internally to synchronize the latest rewarded period with the current period of the validator set contract. - * @notice The `currentPeriod` of the validator set contract is retrieved and stored in the `LATEST_REWARDED_PERIOD_SLOT`. - * @notice This function ensures that the latest rewarded period is updated to reflect the current period in the validator set contract. - */ - function _syncLatestRewardedPeriod() internal { - LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod()); - } - /** * @dev Returns whether should share the reward equally, in case of bridge tracking returns * informed data or there is no ballot in a day. diff --git a/contracts/ronin/gateway/BridgeSlash.sol b/contracts/ronin/gateway/BridgeSlash.sol index c2f7fe6ce..3a39415bc 100644 --- a/contracts/ronin/gateway/BridgeSlash.sol +++ b/contracts/ronin/gateway/BridgeSlash.sol @@ -45,6 +45,9 @@ contract BridgeSlash is /// @dev value is equal to keccak256("@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot") - 1 bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe; + /// @dev The period that the contract allows slashing. + uint256 internal _startedAtPeriod; + /** * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period. * @param totalVote The total number of ballots for the period. @@ -54,6 +57,11 @@ contract BridgeSlash is _; } + modifier skipOnNotStarted(uint256 period) { + if (period < _startedAtPeriod) return; + _; + } + constructor() payable { _disableInitializers(); } @@ -61,11 +69,23 @@ contract BridgeSlash is function initialize( address validatorContract, address bridgeManagerContract, - address bridgeTrackingContract + address bridgeTrackingContract, + address dposGA ) external initializer { _setContract(ContractType.VALIDATOR, validatorContract); _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract); _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract); + _setContract(ContractType.GOVERNANCE_ADMIN, dposGA); + _startedAtPeriod = type(uint256).max; + } + + /** + * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. + */ + function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) { + require(_startedAtPeriod == type(uint256).max, "already init rep 2"); + _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1; + _setContract(ContractType.GOVERNANCE_ADMIN, address(0)); } /** @@ -116,18 +136,17 @@ contract BridgeSlash is * @inheritdoc IBridgeSlash */ function execSlashBridgeOperators( - address[] memory allBridgeOperators, + address[] memory operators, uint256[] memory ballots, uint256 totalBallot, uint256 totalVote, uint256 period - ) external onlyContract(ContractType.BRIDGE_TRACKING) onlyPeriodHasEnoughVotes(totalVote) returns (bool slashed) { - uint256 length = allBridgeOperators.length; - if (length != ballots.length) revert ErrLengthMismatch(msg.sig); - if (length == 0) return false; + ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) { + if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig); + if (operators.length == 0) return; if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) { emit BridgeTrackingIncorrectlyResponded(); - return false; + return; } // Get penalty durations for each slash tier. @@ -141,8 +160,8 @@ contract BridgeSlash is address bridgeOperator; Tier tier; - for (uint256 i; i < length; ) { - bridgeOperator = allBridgeOperators[i]; + for (uint256 i; i < operators.length; ) { + bridgeOperator = operators[i]; status = _bridgeSlashInfos[bridgeOperator]; // Check if the bridge operator was added before the current period. @@ -162,8 +181,6 @@ contract BridgeSlash is // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed. // Update the slash until period number for the bridge operator if the tier is not Tier 0. if (tier != Tier.Tier0) { - slashed = true; - if (slashUntilPeriod != SLASH_PERMANENT_DURATION) { emit Slashed(tier, bridgeOperator, period, slashUntilPeriod); } diff --git a/contracts/ronin/gateway/BridgeTracking.sol b/contracts/ronin/gateway/BridgeTracking.sol index 9b6aa5bfd..c55ffa1b7 100644 --- a/contracts/ronin/gateway/BridgeTracking.sol +++ b/contracts/ronin/gateway/BridgeTracking.sol @@ -49,15 +49,15 @@ contract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContr /// @dev The latest period that get synced with bridge's slashing and rewarding contract uint256 internal _lastSyncPeriod; - modifier skipOnUnstarted() { - _skipOnUnstarted(); + modifier skipOnNotStarted() { + _skipOnNotStarted(); _; } /** * @dev Returns the whole transaction in case the current block is less than start block. */ - function _skipOnUnstarted() private view { + function _skipOnNotStarted() private view { if (block.number < _startedAtBlock) { assembly { return(0, 0) @@ -86,11 +86,31 @@ contract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContr delete ______deprecatedValidator; } - function initializeV3(address bridgeManager, address bridgeSlash, address bridgeReward) external reinitializer(3) { + function initializeV3( + address bridgeManager, + address bridgeSlash, + address bridgeReward, + address dposGA + ) external reinitializer(3) { _setContract(ContractType.BRIDGE_MANAGER, bridgeManager); _setContract(ContractType.BRIDGE_SLASH, bridgeSlash); _setContract(ContractType.BRIDGE_REWARD, bridgeReward); - _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1; + _setContract(ContractType.GOVERNANCE_ADMIN, dposGA); + _lastSyncPeriod = type(uint256).max; + } + + /** + * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. + * The following must be assured after initializing REP2: + * `_lastSyncPeriod` + * == `{BridgeReward}.latestRewardedPeriod + 1` + * == `{BridgeSlash}._startedAtPeriod - 1` + * == `currentPeriod()` + */ + function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) { + require(_lastSyncPeriod == type(uint256).max, "already init rep 2"); + _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod(); + _setContract(ContractType.GOVERNANCE_ADMIN, address(0)); } /** @@ -159,7 +179,7 @@ contract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContr function handleVoteApproved( VoteKind kind, uint256 requestId - ) external override onlyContract(ContractType.BRIDGE) skipOnUnstarted { + ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted { ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId]; // Only records for the receipt which not approved @@ -192,7 +212,7 @@ contract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContr VoteKind kind, uint256 requestId, address operator - ) external override onlyContract(ContractType.BRIDGE) skipOnUnstarted { + ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted { uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod(); _trySyncBuffer(); ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId]; diff --git a/contracts/ronin/gateway/RoninGatewayV2.sol b/contracts/ronin/gateway/RoninGatewayV3.sol similarity index 78% rename from contracts/ronin/gateway/RoninGatewayV2.sol rename to contracts/ronin/gateway/RoninGatewayV3.sol index e89331aa6..aa6adcebc 100644 --- a/contracts/ronin/gateway/RoninGatewayV2.sol +++ b/contracts/ronin/gateway/RoninGatewayV3.sol @@ -3,26 +3,26 @@ pragma solidity ^0.8.0; import "@openzeppelin/contracts/access/AccessControlEnumerable.sol"; import "@openzeppelin/contracts/proxy/utils/Initializable.sol"; -import "../../extensions/GatewayV2.sol"; +import "../../extensions/GatewayV3.sol"; import "../../extensions/collections/HasContracts.sol"; import "../../extensions/MinimumWithdrawal.sol"; import "../../interfaces/IERC20Mintable.sol"; import "../../interfaces/IERC721Mintable.sol"; import "../../interfaces/bridge/IBridgeTracking.sol"; -import "../../interfaces/IRoninGatewayV2.sol"; +import "../../interfaces/IRoninGatewayV3.sol"; import "../../interfaces/IRoninTrustedOrganization.sol"; import "../../interfaces/consumers/VoteStatusConsumer.sol"; import "../../interfaces/validator/IRoninValidatorSet.sol"; import "../../libraries/IsolatedGovernance.sol"; import "../../interfaces/bridge/IBridgeManager.sol"; -contract RoninGatewayV2 is - GatewayV2, +contract RoninGatewayV3 is + GatewayV3, Initializable, MinimumWithdrawal, AccessControlEnumerable, VoteStatusConsumer, - IRoninGatewayV2, + IRoninGatewayV3, HasContracts { using Token for Token.Info; @@ -30,11 +30,8 @@ contract RoninGatewayV2 is using Transfer for Transfer.Receipt; using IsolatedGovernance for IsolatedGovernance.Vote; - /// @dev Withdrawal unlocker role hash - bytes32 public constant WITHDRAWAL_MIGRATOR = keccak256("WITHDRAWAL_MIGRATOR"); - - /// @dev Flag indicating whether the withdrawal migrate progress is done - bool public withdrawalMigrated; + /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value) + bool private ___deprecated4; /// @dev Total withdrawal uint256 public withdrawalCount; /// @dev Mapping from chain id => deposit id => deposit vote @@ -92,7 +89,7 @@ contract RoninGatewayV2 is uint256 _denominator, uint256 _trustedNumerator, uint256 _trustedDenominator, - address[] calldata _withdrawalMigrators, + address[] calldata /* _withdrawalMigrators */, // _packedAddresses[0]: roninTokens // _packedAddresses[1]: mainchainTokens address[][2] calldata _packedAddresses, @@ -108,14 +105,6 @@ contract RoninGatewayV2 is _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards); _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]); } - - for (uint256 _i; _i < _withdrawalMigrators.length; ) { - _grantRole(WITHDRAWAL_MIGRATOR, _withdrawalMigrators[_i]); - - unchecked { - ++_i; - } - } } function initializeV2() external reinitializer(2) { @@ -132,54 +121,15 @@ contract RoninGatewayV2 is } /** - * @dev Migrates withdrawals. - * - * Requirements: - * - The method caller is the migrator. - * - The arrays have the same length and its length larger than 0. - * - */ - function migrateWithdrawals( - Transfer.Request[] calldata _requests, - address[] calldata _requesters - ) external onlyRole(WITHDRAWAL_MIGRATOR) { - if (withdrawalMigrated) revert ErrWithdrawalsMigrated(); - if (!(_requesters.length == _requests.length && _requests.length > 0)) revert ErrLengthMismatch(msg.sig); - - for (uint256 _i; _i < _requests.length; ) { - MappedToken memory _token = getMainchainToken(_requests[_i].tokenAddr, 1); - if (_requests[_i].info.erc != _token.erc) revert ErrInvalidTokenStandard(); - - _storeAsReceipt(_requests[_i], 1, _requesters[_i], _token.tokenAddr); - - unchecked { - ++_i; - } - } - } - - /** - * @dev Mark the migration as done. - */ - function markWithdrawalMigrated() external { - if (!(hasRole(DEFAULT_ADMIN_ROLE, msg.sender) || hasRole(WITHDRAWAL_MIGRATOR, msg.sender))) { - revert ErrUnauthorized(msg.sig, RoleAccess.WITHDRAWAL_MIGRATOR); - } - if (withdrawalMigrated) revert ErrWithdrawalsMigrated(); - - withdrawalMigrated = true; - } - - /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function getWithdrawalSignatures( - uint256 _withdrawalId, - address[] calldata _validators + uint256 withdrawalId, + address[] calldata operators ) external view returns (bytes[] memory _signatures) { - _signatures = new bytes[](_validators.length); - for (uint256 _i = 0; _i < _validators.length; ) { - _signatures[_i] = _withdrawalSig[_withdrawalId][_validators[_i]]; + _signatures = new bytes[](operators.length); + for (uint256 _i = 0; _i < operators.length; ) { + _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]]; unchecked { ++_i; @@ -188,7 +138,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator { address _sender = msg.sender; @@ -201,7 +151,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function tryBulkAcknowledgeMainchainWithdrew( uint256[] calldata _withdrawalIds @@ -236,7 +186,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function tryBulkDepositFor( Transfer.Receipt[] calldata _receipts @@ -263,14 +213,14 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused { _requestWithdrawalFor(_request, msg.sender, _chainId); } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused { if (_requests.length == 0) revert ErrEmptyArray(); @@ -284,7 +234,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused { if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready(); @@ -298,32 +248,32 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function bulkSubmitWithdrawalSignatures( - uint256[] calldata _withdrawals, - bytes[] calldata _signatures + uint256[] calldata withdrawals, + bytes[] calldata signatures ) external whenNotPaused onlyBridgeOperator { - address _validator = msg.sender; + address operator = msg.sender; - if (!(_withdrawals.length > 0 && _withdrawals.length == _signatures.length)) { + if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) { revert ErrLengthMismatch(msg.sig); } uint256 _minVoteWeight = minimumVoteWeight(); - uint256 _id; + uint256 id; IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)); - for (uint256 _i; _i < _withdrawals.length; ) { - _id = _withdrawals[_i]; - _withdrawalSig[_id][_validator] = _signatures[_i]; - _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, _id, _validator); + for (uint256 _i; _i < withdrawals.length; ) { + id = withdrawals[_i]; + _withdrawalSig[id][operator] = signatures[_i]; + _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator); - IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[_id]; - VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, bytes32(_id)); + IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id]; + VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id)); if (_status == VoteStatus.Approved) { _proposal.status = VoteStatus.Executed; - _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, _id); + _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id); } unchecked { @@ -333,7 +283,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function mapTokens( address[] calldata _roninTokens, @@ -346,28 +296,28 @@ contract RoninGatewayV2 is } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) { return depositVote[_chainId][_depositId].voted(_voter); } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) { return mainchainWithdrewVote[_withdrawalId].voted(_voter); } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) { return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed; } /** - * @inheritdoc IRoninGatewayV2 + * @inheritdoc IRoninGatewayV3 */ function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) { _token = _mainchainToken[_roninToken][_chainId]; @@ -410,31 +360,30 @@ contract RoninGatewayV2 is * Emits the `Deposited` once the assets are released. * */ - function _depositFor(Transfer.Receipt memory _receipt, address _validator, uint256 _minVoteWeight) internal { - uint256 _id = _receipt.id; - _receipt.info.validate(); - if (_receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind(); + function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal { + uint256 id = receipt.id; + receipt.info.validate(); + if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind(); - if (_receipt.ronin.chainId != block.chainid) - revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid); + if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid); - MappedToken memory _token = getMainchainToken(_receipt.ronin.tokenAddr, _receipt.mainchain.chainId); + MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId); - if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.mainchain.tokenAddr)) + if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr)) revert ErrInvalidReceipt(); - IsolatedGovernance.Vote storage _proposal = depositVote[_receipt.mainchain.chainId][_id]; - bytes32 _receiptHash = _receipt.hash(); - VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, _receiptHash); - emit DepositVoted(_validator, _id, _receipt.mainchain.chainId, _receiptHash); + IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id]; + bytes32 _receiptHash = receipt.hash(); + VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash); + emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash); if (_status == VoteStatus.Approved) { _proposal.status = VoteStatus.Executed; - _receipt.info.handleAssetTransfer(payable(_receipt.ronin.addr), _receipt.ronin.tokenAddr, IWETH(address(0))); + receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0))); IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved( IBridgeTracking.VoteKind.Deposit, - _receipt.id + receipt.id ); - emit Deposited(_receiptHash, _receipt); + emit Deposited(_receiptHash, receipt); } } @@ -488,7 +437,7 @@ contract RoninGatewayV2 is } /** - * @inheritdoc GatewayV2 + * @inheritdoc GatewayV3 */ function _getTotalWeight() internal view virtual override returns (uint256) { return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight(); diff --git a/contracts/ronin/profile/Profile.sol b/contracts/ronin/profile/Profile.sol index 510acb84d..4d74bcd54 100644 --- a/contracts/ronin/profile/Profile.sol +++ b/contracts/ronin/profile/Profile.sol @@ -19,66 +19,47 @@ contract Profile is IProfile, ProfileHandler, Initializable { _setContract(ContractType.VALIDATOR, validatorContract); } - function migrateTestnet() external { - require(block.chainid == 2021, "mismatch chainID"); - require(msg.sender == 0x968D0Cd7343f711216817E617d3f92a23dC91c07, "not testnet admin"); - - CandidateProfile storage _profile; - - address[10] memory consensusList = [ - 0xCaba9D9424D6bAD99CE352A943F59279B533417a, - 0x9f1Abc67beA4db5560371fF3089F4Bfe934c36Bc, - 0xA85ddDdCeEaB43DccAa259dd4936aC104386F9aa, - 0xAcf8Bf98D1632e602d0B1761771049aF21dd6597, - 0xE9bf2A788C27dADc6B169d52408b710d267b9bff, - 0xD086D2e3Fac052A3f695a4e8905Ce1722531163C, - // 0x9687e8C41fa369aD08FD278a43114C4207856a61, // missing - 0xa325Fd3a2f4f5CafE2c151eE428b5CeDeD628193, - 0x9422d990AcDc3f2b3AA3B97303aD3060F09d7ffC, - 0xc3C97512421BF3e339E9fd412f18584e53138bFA, - 0x78fD38faa30ea66702cc39383D2E84f9a4A56fA6 + function migrateMainnetV2() external { + require(block.chainid == 2020, "mismatch chainID"); + require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, "not mainnet deployer"); + + address[29] memory consensusList = [ + 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, + 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, + 0xE07D7e56588a6FD860c5073c70a099658C060F3D, + 0x52349003240770727900b06a3B3a90f5c0219ADe, + 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, + 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, + 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, + 0xd11D9842baBd5209b9B1155e46f5878c989125b7, + 0x61089875fF9e506ae78C7FE9f7c388416520E386, + 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, + 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, + 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, + 0x9B959D27840a31988410Ee69991BCF0110D61F02, + 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, + 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, + 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, + 0x6E46924371d0e910769aaBE0d867590deAC20684, + 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, + 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, + 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, + 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, + 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, + 0xFc3e31519B551bd594235dd0eF014375a87C4e21, + 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, + 0x22C23429e46e7944D2918F2B368b799b11C417C1, + 0x03A7B98C226225e330d11D1B9177891391Fa4f80, + 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7, + 0x07d28F88D677C4056EA6722aa35d92903b2a63da, + 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD ]; + CandidateProfile storage _profile; for (uint i; i < consensusList.length; i++) { - _migrateTestnetHelper(consensusList[i]); - } - - { - _profile = _getId2ProfileHelper(0xCaba9D9424D6bAD99CE352A943F59279B533417a); - _setGovernor(_profile, 0xb033ba62EC622dC54D0ABFE0254e79692147CA26); - } - { - _profile = _getId2ProfileHelper(0x9f1Abc67beA4db5560371fF3089F4Bfe934c36Bc); - _setGovernor(_profile, 0x087D08e3ba42e64E3948962dd1371F906D1278b9); - } - { - _profile = _getId2ProfileHelper(0xA85ddDdCeEaB43DccAa259dd4936aC104386F9aa); - _setGovernor(_profile, 0x52ec2e6BBcE45AfFF8955Da6410bb13812F4289F); + _profile = _id2Profile[consensusList[i]]; + _profile.id = consensusList[i]; } - { - _profile = _getId2ProfileHelper(0xAcf8Bf98D1632e602d0B1761771049aF21dd6597); - _setGovernor(_profile, 0xd24D87DDc1917165435b306aAC68D99e0F49A3Fa); - } - } - - function migrateTestnetManual(address consensus, address governor) external { - require(block.chainid == 2021, "mismatch chainID"); - require(msg.sender == 0x968D0Cd7343f711216817E617d3f92a23dC91c07, "not testnet admin"); - - _migrateTestnetHelper(consensus); - if (governor != address(0)) { - CandidateProfile storage _profile = _getId2ProfileHelper(consensus); - _setGovernor(_profile, governor); - } - } - - function _migrateTestnetHelper(address consensus) internal { - CandidateProfile storage _profile = _getId2ProfileHelper(consensus); - ICandidateManager.ValidatorCandidate memory info = IRoninValidatorSet(getContract(ContractType.VALIDATOR)) - .getCandidateInfo(consensus); - _setConsensus(_profile, consensus); - _setAdmin(_profile, info.admin); - _setTreasury(_profile, payable(info.treasuryAddr)); } /** diff --git a/contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol b/contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol index ee7f0e460..c0bde3dec 100644 --- a/contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol +++ b/contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol @@ -4,7 +4,6 @@ pragma solidity ^0.8.0; import { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from "../../../extensions/version-control/ConditionalImplementControl.sol"; import { ITimingInfo } from "../../../interfaces/validator/info-fragments/ITimingInfo.sol"; import { ICoinbaseExecution } from "../../../interfaces/validator/ICoinbaseExecution.sol"; -import { HasProxyAdmin, HasContracts } from "../../../extensions/collections/HasContracts.sol"; import { TransparentUpgradeableProxyV2 } from "../../../extensions/TransparentUpgradeableProxyV2.sol"; import { ContractType } from "../../../utils/ContractType.sol"; @@ -12,7 +11,7 @@ import { ContractType } from "../../../utils/ContractType.sol"; * @title RoninValidatorSetTimedMigrator * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control. */ -contract RoninValidatorSetTimedMigrator is ConditionalImplementControl, HasContracts { +contract RoninValidatorSetTimedMigrator is ConditionalImplementControl { /** * @dev Modifier that executes the function when conditions are met. * If the function is {wrapUpEpoch} from {ICoinbaseExecution}, @@ -49,6 +48,7 @@ contract RoninValidatorSetTimedMigrator is ConditionalImplementControl, HasContr IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade(); IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade(); IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade(); + IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade(); } /** @@ -67,7 +67,7 @@ contract RoninValidatorSetTimedMigrator is ConditionalImplementControl, HasContr return ITimingInfo(address(this)).currentPeriod(); } - function _requireSelfCall() internal view override(ConditionalImplementControl, IdentityGuard) { + function _requireSelfCall() internal view override { ConditionalImplementControl._requireSelfCall(); } } diff --git a/deployments/ethereum/MainchainBridgeManager.json b/deployments/ethereum/MainchainBridgeManager.json new file mode 100644 index 000000000..8c682a30c --- /dev/null +++ b/deployments/ethereum/MainchainBridgeManager.json @@ -0,0 +1,2212 @@ +{ + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "abi": [ + { + "inputs": [ + { + "internalType": "uint256", + "name": "num", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "roninChainId", + "type": "uint256" + }, + { + "internalType": "address", + "name": "bridgeContract", + "type": "address" + }, + { + "internalType": "address[]", + "name": "callbackRegisters", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "ErrBridgeOperatorAlreadyExisted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "ErrBridgeOperatorUpdateFailed", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrCurrentProposalIsNotCompleted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrDuplicated", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ErrInsufficientGas", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidArguments", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "actual", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expected", + "type": "uint256" + } + ], + "name": "ErrInvalidChainId", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidExpiryTimestamp", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidOrder", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidProposalNonce", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidVoteWeight", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrOnlySelfCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrRelayFailed", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "interfaceId", + "type": "bytes4" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrUnsupportedInterface", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrUnsupportedVoteType", + "type": "error" + }, + { + "inputs": [], + "name": "ErrVoteIsFinalized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrZeroAddress", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "governor", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "fromBridgeOperator", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "toBridgeOperator", + "type": "address" + } + ], + "name": "BridgeOperatorUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "BridgeOperatorsAdded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "BridgeOperatorsRemoved", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "round", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "bytes32", + "name": "globalProposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct GlobalProposal.GlobalProposalDetail", + "name": "globalProposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "address", + "name": "creator", + "type": "address" + } + ], + "name": "GlobalProposalCreated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes", + "name": "callData", + "type": "bytes" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "registers", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "bytes[]", + "name": "returnDatas", + "type": "bytes[]" + } + ], + "name": "Notified", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalApproved", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "round", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "address", + "name": "creator", + "type": "address" + } + ], + "name": "ProposalCreated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "indexed": false, + "internalType": "bool[]", + "name": "successCalls", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "bytes[]", + "name": "returnDatas", + "type": "bytes[]" + } + ], + "name": "ProposalExecuted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalExpired", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "duration", + "type": "uint256" + } + ], + "name": "ProposalExpiryDurationChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalRejected", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "voter", + "type": "address" + }, + { + "indexed": false, + "internalType": "enum Ballot.VoteType", + "name": "support", + "type": "uint8" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "weight", + "type": "uint256" + } + ], + "name": "ProposalVoted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum GlobalProposal.TargetOption", + "name": "targetOption", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "TargetOptionUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "ThresholdUpdated", + "type": "event" + }, + { + "inputs": [], + "name": "DOMAIN_SEPARATOR", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "addBridgeOperators", + "outputs": [ + { + "internalType": "bool[]", + "name": "addeds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_voteWeight", + "type": "uint256" + } + ], + "name": "checkThreshold", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "getBridgeOperatorOf", + "outputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "getBridgeOperatorWeight", + "outputs": [ + { + "internalType": "uint96", + "name": "weight", + "type": "uint96" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getBridgeOperators", + "outputs": [ + { + "internalType": "address[]", + "name": "", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getCallbackRegisters", + "outputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getFullBridgeOperatorInfos", + "outputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + }, + { + "internalType": "uint96[]", + "name": "weights", + "type": "uint96[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "governor", + "type": "address" + } + ], + "name": "getGovernorWeight", + "outputs": [ + { + "internalType": "uint96", + "name": "weight", + "type": "uint96" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "getGovernorWeights", + "outputs": [ + { + "internalType": "uint96[]", + "name": "weights", + "type": "uint96[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getGovernors", + "outputs": [ + { + "internalType": "address[]", + "name": "", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "getGovernorsOf", + "outputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getProposalExpiryDuration", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "num_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getTotalWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_round", + "type": "uint256" + } + ], + "name": "globalProposalRelayed", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "isBridgeOperator", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "minimumVoteWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "name": "registerCallbacks", + "outputs": [ + { + "internalType": "bool[]", + "name": "registereds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct GlobalProposal.GlobalProposalDetail", + "name": "globalProposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "name": "relayGlobalProposal", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "name": "relayProposal", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "removeBridgeOperators", + "outputs": [ + { + "internalType": "bool[]", + "name": "removeds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + } + ], + "name": "resolveTargets", + "outputs": [ + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "round", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + } + ], + "name": "setThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "sumGovernorsWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "sum", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "totalBridgeOperator", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "name": "unregisterCallbacks", + "outputs": [ + { + "internalType": "bool[]", + "name": "unregistereds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newBridgeOperator", + "type": "address" + } + ], + "name": "updateBridgeOperator", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "name": "updateManyTargetOption", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "vote", + "outputs": [ + { + "internalType": "enum VoteStatusConsumer.VoteStatus", + "name": "status", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "hash", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "againstVoteWeight", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "forVoteWeight", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + } + ], + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "receipt": { + "to": null, + "from": "0xba0000a467FA5d2BCbB78209728dbD2753b41f25", + "contractAddress": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "transactionIndex": 89, + "gasUsed": "4722481", + "logsBloom": "0x042200000000000000000000000000000000800000002400001000000000000000004000000000100000000000000000000100000000000102000000000c0004000000000000800000000000000000000000000000040005000400000000000000000000020000000000000000000800000000000000000000000000000000000000000000000000000000000000000000000000080000000000004400000000000000000000001000010100000000400000000000002000000000000000000040000000000000000000000000000000000000800000001000000000000460000000020000000000000800000000000000000000008000008200000000001000", + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e", + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "logs": [ + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0x976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8", + "0x0000000000000000000000000000000000000000000000000000000000000001", + "0x0000000000000000000000000000000000000000000000000000000000000046", + "0x0000000000000000000000000000000000000000000000000000000000000064" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 279, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + }, + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000002", + "0x00000000000000000000000064192819ac13ef72bf6b5ae239ac672b43a9af08" + ], + "data": "0x", + "logIndex": 280, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + }, + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0x897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b78" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000010000000000000000000000003200a8eb56767c3760e108aa27c65bfff036d8e6000000000000000000000000000000000000000000000000000000000000000100000000000000000000000032015e8b982c61bc8a593816fdbf03a603eec823", + "logIndex": 281, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + }, + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0xe5cd1c123a8cf63fa1b7229678db61fe8ae99dbbd27889370b6667c8cae97da1", + "0x8000000000000000000000000000000000000000000000000000000000000000" + ], + "data": "0x", + "logIndex": 282, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + }, + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x000000000000000000000000a71456fa88a5f6a4696d0446e690db4a5913fab0" + ], + "data": "0x", + "logIndex": 283, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + }, + { + "transactionIndex": 89, + "blockNumber": 18325619, + "transactionHash": "0x32eecd93f9c09035bc4a6f9ed5e78da877b9918d50137b13820668e48f059485", + "address": "0xa71456fA88a5f6a4696D0446E690Db4a5913fab0", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000001", + "0x00000000000000000000000064192819ac13ef72bf6b5ae239ac672b43a9af08" + ], + "data": "0x", + "logIndex": 284, + "blockHash": "0x30be9623b906151095a8c5166a99d05d37ea50438ac2f2c747fd40684f154c1e" + } + ], + "blockNumber": 18325619, + "cumulativeGasUsed": "17942081", + "status": 1, + "byzantium": true + }, + "args": [ + 70, + 100, + 2020, + "0x64192819ac13ef72bf6b5ae239ac672b43a9af08", + [], + [ + "0x32015E8B982c61bc8a593816FdBf03A603EEC823" + ], + [ + "0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6" + ], + [ + 100 + ], + [ + 1 + ], + [ + "0x64192819ac13ef72bf6b5ae239ac672b43a9af08" + ] + ], + "numDeployments": 1, + "solcInputHash": "d5751a51f1eb067d18a7dec1633f85eb", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"num\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"roninChainId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"bridgeContract\",\"type\":\"address\"},{\"internalType\":\"address[]\",\"name\":\"callbackRegisters\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"ErrBridgeOperatorAlreadyExisted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"ErrBridgeOperatorUpdateFailed\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCurrentProposalIsNotCompleted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrDuplicated\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ErrInsufficientGas\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidArguments\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"actual\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expected\",\"type\":\"uint256\"}],\"name\":\"ErrInvalidChainId\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidExpiryTimestamp\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidOrder\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidProposalNonce\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidVoteWeight\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrOnlySelfCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrRelayFailed\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrUnsupportedInterface\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrUnsupportedVoteType\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrVoteIsFinalized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrZeroAddress\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"fromBridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"toBridgeOperator\",\"type\":\"address\"}],\"name\":\"BridgeOperatorUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorsAdded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorsRemoved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"round\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"globalProposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct GlobalProposal.GlobalProposalDetail\",\"name\":\"globalProposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"creator\",\"type\":\"address\"}],\"name\":\"GlobalProposalCreated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes\",\"name\":\"callData\",\"type\":\"bytes\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"bytes[]\",\"name\":\"returnDatas\",\"type\":\"bytes[]\"}],\"name\":\"Notified\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalApproved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"round\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"creator\",\"type\":\"address\"}],\"name\":\"ProposalCreated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"successCalls\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"bytes[]\",\"name\":\"returnDatas\",\"type\":\"bytes[]\"}],\"name\":\"ProposalExecuted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalExpired\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"duration\",\"type\":\"uint256\"}],\"name\":\"ProposalExpiryDurationChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalRejected\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"enum Ballot.VoteType\",\"name\":\"support\",\"type\":\"uint8\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"}],\"name\":\"ProposalVoted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum GlobalProposal.TargetOption\",\"name\":\"targetOption\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"TargetOptionUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"DOMAIN_SEPARATOR\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"addBridgeOperators\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"addeds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"getBridgeOperatorOf\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"getBridgeOperatorWeight\",\"outputs\":[{\"internalType\":\"uint96\",\"name\":\"weight\",\"type\":\"uint96\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeOperators\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCallbackRegisters\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getFullBridgeOperatorInfos\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"uint96[]\",\"name\":\"weights\",\"type\":\"uint96[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"}],\"name\":\"getGovernorWeight\",\"outputs\":[{\"internalType\":\"uint96\",\"name\":\"weight\",\"type\":\"uint96\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"getGovernorWeights\",\"outputs\":[{\"internalType\":\"uint96[]\",\"name\":\"weights\",\"type\":\"uint96[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getGovernors\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"getGovernorsOf\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getProposalExpiryDuration\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getTotalWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_round\",\"type\":\"uint256\"}],\"name\":\"globalProposalRelayed\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"isBridgeOperator\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"name\":\"registerCallbacks\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"registereds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct GlobalProposal.GlobalProposalDetail\",\"name\":\"globalProposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"name\":\"relayGlobalProposal\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"name\":\"relayProposal\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"removeBridgeOperators\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"removeds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"}],\"name\":\"resolveTargets\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"round\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"sumGovernorsWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"sum\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalBridgeOperator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"name\":\"unregisterCallbacks\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"unregistereds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newBridgeOperator\",\"type\":\"address\"}],\"name\":\"updateBridgeOperator\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"name\":\"updateManyTargetOption\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"vote\",\"outputs\":[{\"internalType\":\"enum VoteStatusConsumer.VoteStatus\",\"name\":\"status\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"hash\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"againstVoteWeight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"forVoteWeight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrBridgeOperatorAlreadyExisted(address)\":[{\"details\":\"Error thrown when attempting to add a bridge operator that already exists in the contract. This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\"}],\"ErrBridgeOperatorUpdateFailed(address)\":[{\"details\":\"Error raised when a bridge operator update operation fails.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator that failed to update.\"}}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrCurrentProposalIsNotCompleted()\":[{\"details\":\"Error thrown when the current proposal is not completed.\"}],\"ErrDuplicated(bytes4)\":[{\"details\":\"Error thrown when a duplicated element is detected in an array.\",\"params\":{\"msgSig\":\"The function signature that invoke the error.\"}}],\"ErrInsufficientGas(bytes32)\":[{\"details\":\"Error thrown when there is insufficient gas to execute a function.\"}],\"ErrInvalidArguments(bytes4)\":[{\"details\":\"Error indicating that arguments are invalid.\"}],\"ErrInvalidChainId(bytes4,uint256,uint256)\":[{\"details\":\"Error indicating that the chain ID is invalid.\",\"params\":{\"actual\":\"Current chain ID that executing function.\",\"expected\":\"Expected chain ID required for the tx to success.\",\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid chain ID.\"}}],\"ErrInvalidExpiryTimestamp()\":[{\"details\":\"Error thrown when an invalid expiry timestamp is provided.\"}],\"ErrInvalidOrder(bytes4)\":[{\"details\":\"Error indicating that an order is invalid.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid order.\"}}],\"ErrInvalidProposalNonce(bytes4)\":[{\"details\":\"Error indicating that the proposal nonce is invalid.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\"}}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrInvalidVoteWeight(bytes4)\":[{\"details\":\"Error indicating that a vote weight is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that encountered an invalid vote weight.\"}}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrOnlySelfCall(bytes4)\":[{\"details\":\"Error indicating that a function can only be called by the contract itself.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that can only be called by the contract itself.\"}}],\"ErrRelayFailed(bytes4)\":[{\"details\":\"Error indicating that a relay call has failed.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the relay call that failed.\"}}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnsupportedInterface(bytes4,address)\":[{\"details\":\"The error indicating an unsupported interface.\",\"params\":{\"addr\":\"The address where the unsupported interface was encountered.\",\"interfaceId\":\"The bytes4 interface identifier that is not supported.\"}}],\"ErrUnsupportedVoteType(bytes4)\":[{\"details\":\"Error indicating that a vote type is not supported.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an unsupported vote type.\"}}],\"ErrVoteIsFinalized()\":[{\"details\":\"Error thrown when attempting to interact with a finalized vote.\"}],\"ErrZeroAddress(bytes4)\":[{\"details\":\"Error indicating that given address is null when it should not.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"addBridgeOperators(uint96[],address[],address[])\":{\"details\":\"Adds multiple bridge operators.\",\"params\":{\"bridgeOperators\":\"An array of addresses representing the bridge operators to add.\",\"governors\":\"An array of addresses of hot/cold wallets for bridge operator to update their node address.\"},\"returns\":{\"addeds\":\"An array of booleans indicating whether each bridge operator was added successfully. Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators( voteWeights, governors, bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]); const filteredWeights = weights.filter((_, index) => addeds[index]); const filteredGovernors = governors.filter((_, index) => addeds[index]); // ... (Process or use the information as required) ... ```\"}},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"getBridgeOperatorOf(address[])\":{\"details\":\"Returns an array of bridge operators correspoding to governor addresses.\",\"returns\":{\"bridgeOperators\":\"An array containing the addresses of all bridge operators.\"}},\"getBridgeOperatorWeight(address)\":{\"details\":\"External function to retrieve the vote weight of a specific bridge operator.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator to get the vote weight for.\"},\"returns\":{\"weight\":\"The vote weight of the specified bridge operator.\"}},\"getBridgeOperators()\":{\"details\":\"Returns an array of all bridge operators.\",\"returns\":{\"_0\":\"An array containing the addresses of all bridge operators.\"}},\"getCallbackRegisters()\":{\"details\":\"Retrieves the addresses of registered callbacks.\",\"returns\":{\"registers\":\"An array containing the addresses of registered callbacks.\"}},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getFullBridgeOperatorInfos()\":{\"details\":\"Retrieves the full information of all registered bridge operators. This external function allows external callers to obtain the full information of all the registered bridge operators. The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\",\"returns\":{\"bridgeOperators\":\"An array of addresses representing the registered bridge operators.\",\"governors\":\"An array of addresses representing the governors of each bridge operator.\",\"weights\":\"An array of uint256 values representing the vote weights of each bridge operator. Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator. Example Usage: ``` (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos(); for (uint256 i = 0; i < bridgeOperators.length; i++) { // Access individual information for each bridge operator. address governor = governors[i]; address bridgeOperator = bridgeOperators[i]; uint256 weight = weights[i]; // ... (Process or use the information as required) ... } ```\"}},\"getGovernorWeight(address)\":{\"details\":\"External function to retrieve the vote weight of a specific governor.\",\"params\":{\"governor\":\"The address of the governor to get the vote weight for.\"},\"returns\":{\"weight\":\"voteWeight The vote weight of the specified governor.\"}},\"getGovernorWeights(address[])\":{\"details\":\"Returns the weights of a list of governor addresses.\"},\"getGovernors()\":{\"details\":\"Returns an array of all governors.\",\"returns\":{\"_0\":\"An array containing the addresses of all governors.\"}},\"getGovernorsOf(address[])\":{\"details\":\"Retrieves the governors corresponding to a given array of bridge operators. This external function allows external callers to obtain the governors associated with a given array of bridge operators. The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\",\"params\":{\"bridgeOperators\":\"An array of bridge operator addresses for which governors are to be retrieved.\"},\"returns\":{\"governors\":\"An array of addresses representing the governors corresponding to the provided bridge operators.\"}},\"getProposalExpiryDuration()\":{\"details\":\"Returns the expiry duration for a new proposal.\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"getTotalWeight()\":{\"details\":\"Returns total weights.\"},\"globalProposalRelayed(uint256)\":{\"details\":\"Returns whether the voter `_voter` casted vote for the proposal.\"},\"isBridgeOperator(address)\":{\"details\":\"Checks if the given address is a bridge operator.\",\"params\":{\"addr\":\"The address to check.\"},\"returns\":{\"_0\":\"A boolean indicating whether the address is a bridge operator.\"}},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"registerCallbacks(address[])\":{\"details\":\"Registers multiple callbacks with the bridge.\",\"params\":{\"registers\":\"The array of callback addresses to register.\"},\"returns\":{\"registereds\":\"An array indicating the success status of each registration.\"}},\"relayGlobalProposal((uint256,uint256,uint8[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceRelay-_relayGlobalProposal`. Requirements: - The method caller is governor.\"},\"relayProposal((uint256,uint256,uint256,address[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceRelay-_relayProposal`. Requirements: - The method caller is governor.\"},\"removeBridgeOperators(address[])\":{\"details\":\"Removes multiple bridge operators.\",\"params\":{\"bridgeOperators\":\"An array of addresses representing the bridge operators to remove.\"},\"returns\":{\"removeds\":\"An array of booleans indicating whether each bridge operator was removed successfully. * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators( bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]); // ... (Process or use the information as required) ... ```\"}},\"resolveTargets(uint8[])\":{\"details\":\"Returns corresponding address of target options. Return address(0) on non-existent target.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setThreshold(uint256,uint256)\":{\"details\":\"Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event.\"},\"sumGovernorsWeight(address[])\":{\"details\":\"Returns total weights of the governor list.\"},\"totalBridgeOperator()\":{\"details\":\"Returns the total number of bridge operators.\",\"returns\":{\"_0\":\"The total number of bridge operators.\"}},\"unregisterCallbacks(address[])\":{\"details\":\"Unregisters multiple callbacks from the bridge.\",\"params\":{\"registers\":\"The array of callback addresses to unregister.\"},\"returns\":{\"unregistereds\":\"An array indicating the success status of each unregistration.\"}},\"updateBridgeOperator(address)\":{\"details\":\"Governor updates their corresponding governor and/or operator address. Requirements: - The caller must the governor of the operator that is requested changes.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator to update.\"}},\"updateManyTargetOption(uint8[],address[])\":{\"details\":\"Updates list of `targetOptions` to `targets`. Requirement: - Only allow self-call through proposal. \"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"round(uint256)\":{\"notice\":\"chain id = 0 for global proposal\"},\"updateBridgeOperator(address)\":{\"notice\":\"This method checks authorization by querying the corresponding operator of the msg.sender and then attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave their operator address blank null `address(0)`, consider add authorization check.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/mainchain/MainchainBridgeManager.sol\":\"MainchainBridgeManager\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for managing\\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\\n * types.\\n *\\n * Sets have the following properties:\\n *\\n * - Elements are added, removed, and checked for existence in constant time\\n * (O(1)).\\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\\n *\\n * ```\\n * contract Example {\\n * // Add the library methods\\n * using EnumerableSet for EnumerableSet.AddressSet;\\n *\\n * // Declare a set state variable\\n * EnumerableSet.AddressSet private mySet;\\n * }\\n * ```\\n *\\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\\n * and `uint256` (`UintSet`) are supported.\\n *\\n * [WARNING]\\n * ====\\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\\n *\\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\\n * ====\\n */\\nlibrary EnumerableSet {\\n // To implement this library for multiple types with as little code\\n // repetition as possible, we write it in terms of a generic Set type with\\n // bytes32 values.\\n // The Set implementation uses private functions, and user-facing\\n // implementations (such as AddressSet) are just wrappers around the\\n // underlying Set.\\n // This means that we can only create new EnumerableSets for types that fit\\n // in bytes32.\\n\\n struct Set {\\n // Storage of set values\\n bytes32[] _values;\\n // Position of the value in the `values` array, plus 1 because index 0\\n // means a value is not in the set.\\n mapping(bytes32 => uint256) _indexes;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function _add(Set storage set, bytes32 value) private returns (bool) {\\n if (!_contains(set, value)) {\\n set._values.push(value);\\n // The value is stored at length-1, but we add 1 to all indexes\\n // and use 0 as a sentinel value\\n set._indexes[value] = set._values.length;\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function _remove(Set storage set, bytes32 value) private returns (bool) {\\n // We read and store the value's index to prevent multiple reads from the same storage slot\\n uint256 valueIndex = set._indexes[value];\\n\\n if (valueIndex != 0) {\\n // Equivalent to contains(set, value)\\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\\n // the array, and then remove the last element (sometimes called as 'swap and pop').\\n // This modifies the order of the array, as noted in {at}.\\n\\n uint256 toDeleteIndex = valueIndex - 1;\\n uint256 lastIndex = set._values.length - 1;\\n\\n if (lastIndex != toDeleteIndex) {\\n bytes32 lastValue = set._values[lastIndex];\\n\\n // Move the last value to the index where the value to delete is\\n set._values[toDeleteIndex] = lastValue;\\n // Update the index for the moved value\\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\\n }\\n\\n // Delete the slot where the moved value was stored\\n set._values.pop();\\n\\n // Delete the index for the deleted slot\\n delete set._indexes[value];\\n\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\\n return set._indexes[value] != 0;\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function _length(Set storage set) private view returns (uint256) {\\n return set._values.length;\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\\n return set._values[index];\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function _values(Set storage set) private view returns (bytes32[] memory) {\\n return set._values;\\n }\\n\\n // Bytes32Set\\n\\n struct Bytes32Set {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _add(set._inner, value);\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _remove(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\\n return _contains(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(Bytes32Set storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\\n return _at(set._inner, index);\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\\n return _values(set._inner);\\n }\\n\\n // AddressSet\\n\\n struct AddressSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(AddressSet storage set, address value) internal returns (bool) {\\n return _add(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(AddressSet storage set, address value) internal returns (bool) {\\n return _remove(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(AddressSet storage set, address value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(AddressSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\\n return address(uint160(uint256(_at(set._inner, index))));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(AddressSet storage set) internal view returns (address[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n address[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n\\n // UintSet\\n\\n struct UintSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(UintSet storage set, uint256 value) internal returns (bool) {\\n return _add(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\\n return _remove(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function length(UintSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\\n return uint256(_at(set._inner, index));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(UintSet storage set) internal view returns (uint256[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n uint256[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n}\\n\",\"keccak256\":\"0x5050943b32b6a8f282573d166b2e9d87ab7eb4dbba4ab6acf36ecb54fe6995e4\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \\\"./BridgeManagerCallbackRegister.sol\\\";\\nimport { IHasContracts, HasContracts } from \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { IQuorum } from \\\"../../interfaces/IQuorum.sol\\\";\\nimport { IBridgeManager } from \\\"../../interfaces/bridge/IBridgeManager.sol\\\";\\nimport { AddressArrayUtils } from \\\"../../libraries/AddressArrayUtils.sol\\\";\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\nimport { RoleAccess } from \\\"../../utils/RoleAccess.sol\\\";\\nimport { TUint256Slot } from \\\"../../types/Types.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\\n using AddressArrayUtils for address[];\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\\\") - 1\\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\\\") - 1\\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\\\") - 1\\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\\\") - 1\\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\\n\\n /**\\n * @dev The numerator value used for calculations in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\\\") - 1\\n */\\n TUint256Slot internal constant NUMERATOR_SLOT =\\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\\n\\n /**\\n * @dev The denominator value used for calculations in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\\\") - 1\\n */\\n TUint256Slot internal constant DENOMINATOR_SLOT =\\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\\n\\n /**\\n * @dev The nonce value used for tracking nonces in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\\\") - 1\\n */\\n TUint256Slot internal constant NONCE_SLOT =\\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\\n\\n /**\\n * @dev The total weight value used for storing the cumulative weight in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\\\") - 1\\n */\\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n bytes32 public immutable DOMAIN_SEPARATOR;\\n\\n modifier onlyGovernor() virtual {\\n _requireGovernor(msg.sender);\\n _;\\n }\\n\\n constructor(\\n uint256 num,\\n uint256 denom,\\n uint256 roninChainId,\\n address bridgeContract,\\n address[] memory callbackRegisters,\\n address[] memory bridgeOperators,\\n address[] memory governors,\\n uint96[] memory voteWeights\\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\\n NONCE_SLOT.store(1);\\n\\n _setThreshold(num, denom);\\n _setContract(ContractType.BRIDGE, bridgeContract);\\n\\n DOMAIN_SEPARATOR = keccak256(\\n abi.encode(\\n keccak256(\\\"EIP712Domain(string name,string version,bytes32 salt)\\\"),\\n keccak256(\\\"BridgeAdmin\\\"), // name hash\\n keccak256(\\\"2\\\"), // version hash\\n keccak256(abi.encode(\\\"BRIDGE_ADMIN\\\", roninChainId)) // salt\\n )\\n );\\n\\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external onlySelfCall returns (bool[] memory addeds) {\\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function removeBridgeOperators(\\n address[] calldata bridgeOperators\\n ) external onlySelfCall returns (bool[] memory removeds) {\\n removeds = _removeBridgeOperators(bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\\n * their operator address blank null `address(0)`, consider add authorization check.\\n */\\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\\n _requireNonZeroAddress(newBridgeOperator);\\n\\n // Queries the previous bridge operator\\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\\n if (currentBridgeOperator == newBridgeOperator) {\\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\\n }\\n\\n // Tries replace the bridge operator\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\\n\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n delete _governorOf[currentBridgeOperator];\\n _governorOf[newBridgeOperator] = msg.sender;\\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\\n\\n _notifyRegisters(\\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\\n abi.encode(currentBridgeOperator, newBridgeOperator)\\n );\\n\\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(\\n uint256 numerator,\\n uint256 denominator\\n ) external override onlySelfCall returns (uint256, uint256) {\\n return _setThreshold(numerator, denominator);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getTotalWeight() public view returns (uint256) {\\n return TOTAL_WEIGHTS_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\\n weights = _getGovernorWeights(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\\n weight = _getGovernorWeight(governor);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function sumGovernorsWeight(\\n address[] calldata governors\\n ) external view nonDuplicate(governors) returns (uint256 sum) {\\n sum = _sumGovernorsWeight(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function totalBridgeOperator() external view returns (uint256) {\\n return _getBridgeOperatorSet().length();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function isBridgeOperator(address addr) external view returns (bool) {\\n return _getBridgeOperatorSet().contains(addr);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperators() external view returns (address[] memory) {\\n return _getBridgeOperators();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernors() external view returns (address[] memory) {\\n return _getGovernors();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\\n uint256 length = governors.length;\\n bridgeOperators = new address[](length);\\n\\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\\n for (uint256 i; i < length; ) {\\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\\n uint256 length = bridgeOperators.length;\\n governors = new address[](length);\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n\\n for (uint256 i; i < length; ) {\\n governors[i] = _governorOf[bridgeOperators[i]];\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\\n {\\n governors = _getGovernors();\\n bridgeOperators = getBridgeOperatorOf(governors);\\n weights = _getGovernorWeights(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() public view virtual returns (uint256) {\\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\\n }\\n\\n /**\\n * @dev Internal function to add bridge operators.\\n *\\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\\n *\\n * Requirements:\\n * - The caller must have the necessary permission to add bridge operators.\\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\\n *\\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\\n * @param governors An array of addresses representing the governors for each bridge operator.\\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\\n */\\n function _addBridgeOperators(\\n uint96[] memory voteWeights,\\n address[] memory governors,\\n address[] memory bridgeOperators\\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\\n uint256 length = bridgeOperators.length;\\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\\n addeds = new bool[](length);\\n // simply skip add operations if inputs are empty.\\n if (length == 0) return addeds;\\n\\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n address governor;\\n address bridgeOperator;\\n uint256 accumulatedWeight;\\n BridgeOperatorInfo memory bridgeOperatorInfo;\\n\\n for (uint256 i; i < length; ) {\\n governor = governors[i];\\n bridgeOperator = bridgeOperators[i];\\n\\n _requireNonZeroAddress(governor);\\n _requireNonZeroAddress(bridgeOperator);\\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\\n\\n addeds[i] = !(_governorSet.contains(governor) ||\\n _governorSet.contains(bridgeOperator) ||\\n _bridgeOperatorSet.contains(governor) ||\\n _bridgeOperatorSet.contains(bridgeOperator));\\n\\n if (addeds[i]) {\\n _governorSet.add(governor);\\n _bridgeOperatorSet.add(bridgeOperator);\\n _governorOf[bridgeOperator] = governor;\\n bridgeOperatorInfo.addr = bridgeOperator;\\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\\n\\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\\n\\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @dev Internal function to remove bridge operators.\\n *\\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\\n *\\n * Requirements:\\n * - The caller must have the necessary permission to remove bridge operators.\\n *\\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\\n */\\n function _removeBridgeOperators(\\n address[] memory bridgeOperators\\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\\n uint256 length = bridgeOperators.length;\\n removeds = new bool[](length);\\n // simply skip remove operations if inputs are empty.\\n if (length == 0) return removeds;\\n\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n address governor;\\n address bridgeOperator;\\n uint256 accumulatedWeight;\\n BridgeOperatorInfo memory bridgeOperatorInfo;\\n\\n for (uint256 i; i < length; ) {\\n bridgeOperator = bridgeOperators[i];\\n governor = _governorOf[bridgeOperator];\\n\\n _requireNonZeroAddress(governor);\\n _requireNonZeroAddress(bridgeOperator);\\n\\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\\n\\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\\n if (removeds[i]) {\\n _governorSet.remove(governor);\\n _bridgeOperatorSet.remove(bridgeOperator);\\n\\n delete _governorOf[bridgeOperator];\\n delete _governorToBridgeOperatorInfo[governor];\\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\\n\\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\\n\\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(\\n uint256 numerator,\\n uint256 denominator\\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\\n\\n previousNum = NUMERATOR_SLOT.load();\\n previousDenom = DENOMINATOR_SLOT.load();\\n NUMERATOR_SLOT.store(numerator);\\n DENOMINATOR_SLOT.store(denominator);\\n\\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\\n }\\n\\n /**\\n * @dev Internal function to get all bridge operators.\\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\\n */\\n function _getBridgeOperators() internal view returns (address[] memory) {\\n return _getBridgeOperatorSet().values();\\n }\\n\\n /**\\n * @dev Internal function to get all governors.\\n * @return governors An array containing all the registered governor addresses.\\n */\\n function _getGovernors() internal view returns (address[] memory) {\\n return _getGovernorsSet().values();\\n }\\n\\n /**\\n * @dev Internal function to get the vote weights of a given array of governors.\\n * @param governors An array containing the addresses of governors.\\n * @return weights An array containing the vote weights of the corresponding governors.\\n */\\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\\n uint256 length = governors.length;\\n weights = new uint96[](length);\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n for (uint256 i; i < length; ) {\\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\\n * @return sum The total sum of vote weights for the provided governors.\\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\\n */\\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n for (uint256 i; i < governors.length; ) {\\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to require that the caller has governor role access.\\n * @param addr The address to check for governor role access.\\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\\n */\\n function _requireGovernor(address addr) internal view {\\n if (_getGovernorWeight(addr) == 0) {\\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\\n }\\n }\\n\\n /**\\n * @dev Internal function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function _getGovernorWeight(address governor) internal view returns (uint96) {\\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\\n }\\n\\n /**\\n * @dev Internal function to access the address set of bridge operators.\\n * @return bridgeOperators the storage address set.\\n */\\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\\n assembly (\\\"memory-safe\\\") {\\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the address set of bridge operators.\\n * @return governors the storage address set.\\n */\\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\\n assembly (\\\"memory-safe\\\") {\\n governors.slot := GOVERNOR_SET_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\\n */\\n function _getGovernorToBridgeOperatorInfo()\\n internal\\n pure\\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\\n {\\n assembly (\\\"memory-safe\\\") {\\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from bridge operator => governor.\\n * @return governorOf the mapping from bridge operator => governor.\\n */\\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\\n assembly (\\\"memory-safe\\\") {\\n governorOf.slot := GOVENOR_OF_SLOT\\n }\\n }\\n}\\n\",\"keccak256\":\"0xed4094d87c13f38dc4b76b52b8b238447d99cdc2ad452f322ddc891b1217d572\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { EnumerableSet } from \\\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\\\";\\nimport { IBridgeManagerCallbackRegister } from \\\"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\\\";\\nimport { IBridgeManagerCallback } from \\\"../../interfaces/bridge/IBridgeManagerCallback.sol\\\";\\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\n\\n/**\\n * @title BridgeManagerCallbackRegister\\n * @dev A contract that manages callback registrations and execution for a bridge.\\n */\\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n /**\\n * @dev Storage slot for the address set of callback registers.\\n * @dev Value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\\\") - 1.\\n */\\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\\n\\n constructor(address[] memory callbackRegisters) payable {\\n _registerCallbacks(callbackRegisters);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\\n registereds = _registerCallbacks(registers);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function unregisterCallbacks(\\n address[] calldata registers\\n ) external onlySelfCall returns (bool[] memory unregistereds) {\\n unregistereds = _unregisterCallbacks(registers);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function getCallbackRegisters() external view returns (address[] memory registers) {\\n registers = _getCallbackRegisters().values();\\n }\\n\\n /**\\n * @dev Internal function to register multiple callbacks with the bridge.\\n * @param registers The array of callback addresses to register.\\n * @return registereds An array indicating the success status of each registration.\\n */\\n function _registerCallbacks(\\n address[] memory registers\\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\\n uint256 length = registers.length;\\n registereds = new bool[](length);\\n if (length == 0) return registereds;\\n\\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\\n address register;\\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\\n\\n for (uint256 i; i < length; ) {\\n register = registers[i];\\n\\n _requireHasCode(register);\\n _requireSupportsInterface(register, callbackInterface);\\n\\n registereds[i] = _callbackRegisters.add(register);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to unregister multiple callbacks from the bridge.\\n * @param registers The array of callback addresses to unregister.\\n * @return unregistereds An array indicating the success status of each unregistration.\\n */\\n function _unregisterCallbacks(\\n address[] memory registers\\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\\n uint256 length = registers.length;\\n unregistereds = new bool[](length);\\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\\n\\n for (uint256 i; i < length; ) {\\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\\n * @param callbackFnSig The function signature of the callback method.\\n * @param inputs The data to pass to the callback method.\\n */\\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\\n address[] memory registers = _getCallbackRegisters().values();\\n uint256 length = registers.length;\\n if (length == 0) return;\\n\\n bool[] memory successes = new bool[](length);\\n bytes[] memory returnDatas = new bytes[](length);\\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\\n\\n for (uint256 i; i < length; ) {\\n (successes[i], returnDatas[i]) = registers[i].call(callData);\\n if (!successes[i]) {\\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n emit Notified(callData, registers, successes, returnDatas);\\n }\\n\\n /**\\n * @dev Internal function to retrieve the address set of callback registers.\\n * @return callbackRegisters The storage reference to the callback registers.\\n */\\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\\n assembly (\\\"memory-safe\\\") {\\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\\n }\\n }\\n}\\n\",\"keccak256\":\"0x0fd58e2e9955d95cfde1ccd8b120fbb3d5bbf7b41143c09217833bd1d01590ce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/CoreGovernance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Proposal.sol\\\";\\nimport \\\"../../libraries/GlobalProposal.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\nimport \\\"../../libraries/Ballot.sol\\\";\\nimport \\\"../../interfaces/consumers/ChainTypeConsumer.sol\\\";\\nimport \\\"../../interfaces/consumers/SignatureConsumer.sol\\\";\\nimport \\\"../../interfaces/consumers/VoteStatusConsumer.sol\\\";\\n\\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\\n using Proposal for Proposal.ProposalDetail;\\n\\n /**\\n * @dev Error thrown when attempting to interact with a finalized vote.\\n */\\n error ErrVoteIsFinalized();\\n\\n /**\\n * @dev Error thrown when the current proposal is not completed.\\n */\\n error ErrCurrentProposalIsNotCompleted();\\n\\n struct ProposalVote {\\n VoteStatus status;\\n bytes32 hash;\\n uint256 againstVoteWeight; // Total weight of against votes\\n uint256 forVoteWeight; // Total weight of for votes\\n address[] forVoteds; // Array of addresses voting for\\n address[] againstVoteds; // Array of addresses voting against\\n uint256 expiryTimestamp;\\n mapping(address => Signature) sig;\\n mapping(address => bool) voted;\\n }\\n\\n /// @dev Emitted when a proposal is created\\n event ProposalCreated(\\n uint256 indexed chainId,\\n uint256 indexed round,\\n bytes32 indexed proposalHash,\\n Proposal.ProposalDetail proposal,\\n address creator\\n );\\n /// @dev Emitted when the proposal is voted\\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\\n /// @dev Emitted when the proposal is approved\\n event ProposalApproved(bytes32 indexed proposalHash);\\n /// @dev Emitted when the vote is reject\\n event ProposalRejected(bytes32 indexed proposalHash);\\n /// @dev Emitted when the vote is expired\\n event ProposalExpired(bytes32 indexed proposalHash);\\n /// @dev Emitted when the proposal is executed\\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\\n /// @dev Emitted when the proposal expiry duration is changed.\\n event ProposalExpiryDurationChanged(uint256 indexed duration);\\n\\n /// @dev Mapping from chain id => vote round\\n /// @notice chain id = 0 for global proposal\\n mapping(uint256 => uint256) public round;\\n /// @dev Mapping from chain id => vote round => proposal vote\\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\\n\\n uint256 internal _proposalExpiryDuration;\\n\\n constructor(uint256 _expiryDuration) {\\n _setProposalExpiryDuration(_expiryDuration);\\n }\\n\\n /**\\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\\n * if it is expired and not increase the `_round`.\\n */\\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\\n _round = round[_chainId];\\n // Skip checking for the first ever round\\n if (_round == 0) {\\n _round = round[_chainId] = 1;\\n } else {\\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\\n if (!_isExpired) {\\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\\n unchecked {\\n _round = ++round[_chainId];\\n }\\n }\\n }\\n }\\n\\n /**\\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\\n */\\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\\n _vote.hash = _proposalHash;\\n _vote.expiryTimestamp = _expiryTimestamp;\\n }\\n\\n /**\\n * @dev Proposes for a new proposal.\\n *\\n * Requirements:\\n * - The chain id is not equal to 0.\\n *\\n * Emits the `ProposalCreated` event.\\n *\\n */\\n function _proposeProposal(\\n uint256 chainId,\\n uint256 expiryTimestamp,\\n address[] memory targets,\\n uint256[] memory values,\\n bytes[] memory calldatas,\\n uint256[] memory gasAmounts,\\n address creator\\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\\n uint256 round_ = _createVotingRound(chainId);\\n\\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\\n }\\n\\n /**\\n * @dev Proposes proposal struct.\\n *\\n * Requirements:\\n * - The chain id is not equal to 0.\\n * - The proposal nonce is equal to the new round.\\n *\\n * Emits the `ProposalCreated` event.\\n *\\n */\\n function _proposeProposalStruct(\\n Proposal.ProposalDetail memory proposal,\\n address creator\\n ) internal virtual returns (uint256 round_) {\\n uint256 chainId = proposal.chainId;\\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n round_ = _createVotingRound(chainId);\\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\\n }\\n\\n /**\\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\\n *\\n * Requirements:\\n * - The proposal nonce is equal to the round.\\n * - The vote is not finalized.\\n * - The voter has not voted for the round.\\n *\\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\\n * proposal is approved, executed or rejected.\\n *\\n */\\n function _castVote(\\n Proposal.ProposalDetail memory proposal,\\n Ballot.VoteType support,\\n uint256 minimumForVoteWeight,\\n uint256 minimumAgainstVoteWeight,\\n address voter,\\n Signature memory signature,\\n uint256 voterWeight\\n ) internal virtual returns (bool done) {\\n uint256 chainId = proposal.chainId;\\n uint256 round_ = proposal.nonce;\\n ProposalVote storage _vote = vote[chainId][round_];\\n\\n if (_tryDeleteExpiredVotingRound(_vote)) {\\n return true;\\n }\\n\\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\\n\\n _vote.voted[voter] = true;\\n // Stores the signature if it is not empty\\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\\n _vote.sig[voter] = signature;\\n }\\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\\n\\n uint256 _forVoteWeight;\\n uint256 _againstVoteWeight;\\n if (support == Ballot.VoteType.For) {\\n _vote.forVoteds.push(voter);\\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\\n } else if (support == Ballot.VoteType.Against) {\\n _vote.againstVoteds.push(voter);\\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\\n } else revert ErrUnsupportedVoteType(msg.sig);\\n\\n if (_forVoteWeight >= minimumForVoteWeight) {\\n done = true;\\n _vote.status = VoteStatus.Approved;\\n emit ProposalApproved(_vote.hash);\\n _tryExecute(_vote, proposal);\\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\\n done = true;\\n _vote.status = VoteStatus.Rejected;\\n emit ProposalRejected(_vote.hash);\\n }\\n }\\n\\n /**\\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\\n *\\n * Emits the event `ProposalExpired` if the vote is expired.\\n *\\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\\n * before or it will emit an unexpected event of `ProposalExpired`.\\n */\\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\\n isExpired =\\n _getChainType() == ChainType.RoninChain &&\\n proposalVote.status == VoteStatus.Pending &&\\n proposalVote.expiryTimestamp <= block.timestamp;\\n\\n if (isExpired) {\\n emit ProposalExpired(proposalVote.hash);\\n\\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n delete proposalVote.status;\\n delete proposalVote.hash;\\n delete proposalVote.againstVoteWeight;\\n delete proposalVote.forVoteWeight;\\n delete proposalVote.forVoteds;\\n delete proposalVote.againstVoteds;\\n delete proposalVote.expiryTimestamp;\\n }\\n }\\n\\n /**\\n * @dev Executes the proposal and update the vote status once the proposal is executable.\\n */\\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\\n if (proposal.executable()) {\\n vote_.status = VoteStatus.Executed;\\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\\n }\\n }\\n\\n /**\\n * @dev Sets the expiry duration for a new proposal.\\n */\\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\\n _proposalExpiryDuration = expiryDuration;\\n emit ProposalExpiryDurationChanged(expiryDuration);\\n }\\n\\n /**\\n * @dev Returns the expiry duration for a new proposal.\\n */\\n function _getProposalExpiryDuration() internal view returns (uint256) {\\n return _proposalExpiryDuration;\\n }\\n\\n /**\\n * @dev Returns whether the voter casted for the proposal.\\n */\\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\\n return vote_.voted[voter];\\n }\\n\\n /**\\n * @dev Returns total weight from validators.\\n */\\n function _getTotalWeight() internal view virtual returns (uint256);\\n\\n /**\\n * @dev Returns minimum vote to pass a proposal.\\n */\\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\\n\\n /**\\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\\n */\\n function _getChainType() internal view virtual returns (ChainType);\\n}\\n\",\"keccak256\":\"0xc6056209e8f6a0d9edced67388a4037c6fafffb68a3c7b2fe5759c487bb1d81c\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/GlobalCoreGovernance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Proposal.sol\\\";\\nimport \\\"../../libraries/GlobalProposal.sol\\\";\\nimport \\\"./CoreGovernance.sol\\\";\\n\\nabstract contract GlobalCoreGovernance is CoreGovernance {\\n using Proposal for Proposal.ProposalDetail;\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\\n\\n /// @dev Emitted when a proposal is created\\n event GlobalProposalCreated(\\n uint256 indexed round,\\n bytes32 indexed proposalHash,\\n Proposal.ProposalDetail proposal,\\n bytes32 globalProposalHash,\\n GlobalProposal.GlobalProposalDetail globalProposal,\\n address creator\\n );\\n\\n /// @dev Emitted when the target options are updated\\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\\n\\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\\n _updateManyTargetOption(targetOptions, addrs);\\n }\\n\\n /**\\n * @dev Proposes for a global proposal.\\n *\\n * Emits the `GlobalProposalCreated` event.\\n *\\n */\\n function _proposeGlobal(\\n uint256 expiryTimestamp,\\n GlobalProposal.TargetOption[] calldata targetOptions,\\n uint256[] memory values,\\n bytes[] memory calldatas,\\n uint256[] memory gasAmounts,\\n address creator\\n ) internal virtual {\\n uint256 round_ = _createVotingRound(0);\\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\\n round_,\\n expiryTimestamp,\\n targetOptions,\\n values,\\n calldatas,\\n gasAmounts\\n );\\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\\n _resolveTargets({ targetOptions: targetOptions, strict: true })\\n );\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\\n }\\n\\n /**\\n * @dev Proposes global proposal struct.\\n *\\n * Requirements:\\n * - The proposal nonce is equal to the new round.\\n *\\n * Emits the `GlobalProposalCreated` event.\\n *\\n */\\n function _proposeGlobalStruct(\\n GlobalProposal.GlobalProposalDetail memory globalProposal,\\n address creator\\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\\n proposal = globalProposal.intoProposalDetail(\\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\\n );\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n uint256 round_ = _createVotingRound(0);\\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\\n\\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\\n }\\n\\n /**\\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\\n */\\n function resolveTargets(\\n GlobalProposal.TargetOption[] calldata targetOptions\\n ) external view returns (address[] memory targets) {\\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\\n }\\n\\n /**\\n * @dev Internal helper of {resolveTargets}.\\n *\\n * @param strict When the param is set to `true`, revert on non-existent target.\\n */\\n function _resolveTargets(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n bool strict\\n ) internal view returns (address[] memory targets) {\\n targets = new address[](targetOptions.length);\\n\\n for (uint256 i; i < targetOptions.length; ) {\\n targets[i] = _targetOptionsMap[targetOptions[i]];\\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Updates list of `targetOptions` to `targets`.\\n *\\n * Requirement:\\n * - Only allow self-call through proposal.\\n * */\\n function updateManyTargetOption(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n ) external {\\n // HACK: Cannot reuse the existing library due to too deep stack\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n _updateManyTargetOption(targetOptions, targets);\\n }\\n\\n /**\\n * @dev Updates list of `targetOptions` to `targets`.\\n */\\n function _updateManyTargetOption(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n ) internal {\\n for (uint256 i; i < targetOptions.length; ) {\\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\\n _updateTargetOption(targetOptions[i], targets[i]);\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Updates `targetOption` to `target`.\\n *\\n * Requirement:\\n * - Emit a `TargetOptionUpdated` event.\\n */\\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\\n _targetOptionsMap[targetOption] = target;\\n emit TargetOptionUpdated(targetOption, target);\\n }\\n}\\n\",\"keccak256\":\"0x986444cade6313dd1ce4137f3338e4fc296769f5cf669f057cd2838e5ae0e54f\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../CoreGovernance.sol\\\";\\n\\nabstract contract CommonGovernanceRelay is CoreGovernance {\\n using Proposal for Proposal.ProposalDetail;\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n /**\\n * @dev Relays votes by signatures.\\n *\\n * @notice Does not store the voter signature into storage.\\n *\\n */\\n function _relayVotesBySignatures(\\n Proposal.ProposalDetail memory _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures,\\n bytes32 _forDigest,\\n bytes32 _againstDigest\\n ) internal {\\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\\n\\n uint256 _forVoteCount;\\n uint256 _againstVoteCount;\\n address[] memory _forVoteSigners = new address[](_signatures.length);\\n address[] memory _againstVoteSigners = new address[](_signatures.length);\\n\\n {\\n address _signer;\\n address _lastSigner;\\n Ballot.VoteType _support;\\n Signature calldata _sig;\\n\\n for (uint256 _i; _i < _signatures.length; ) {\\n _sig = _signatures[_i];\\n _support = _supports[_i];\\n\\n if (_support == Ballot.VoteType.For) {\\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\\n _forVoteSigners[_forVoteCount++] = _signer;\\n } else if (_support == Ballot.VoteType.Against) {\\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\\n _againstVoteSigners[_againstVoteCount++] = _signer;\\n } else revert ErrUnsupportedVoteType(msg.sig);\\n\\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\\n _lastSigner = _signer;\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n assembly {\\n mstore(_forVoteSigners, _forVoteCount)\\n mstore(_againstVoteSigners, _againstVoteCount)\\n }\\n\\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\\n _vote.status = VoteStatus.Approved;\\n emit ProposalApproved(_vote.hash);\\n _tryExecute(_vote, _proposal);\\n return;\\n }\\n\\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\\n _vote.status = VoteStatus.Rejected;\\n emit ProposalRejected(_vote.hash);\\n return;\\n }\\n\\n revert ErrRelayFailed(msg.sig);\\n }\\n\\n /**\\n * @dev Returns the weight of the governor list.\\n */\\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0x80c58038f403fd189647669c2f5f913c9c5dd16be3d1b60b296903ce70c9634b\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../GlobalCoreGovernance.sol\\\";\\nimport \\\"./CommonGovernanceRelay.sol\\\";\\n\\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n /**\\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\\n */\\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\\n return vote[0][_round].status != VoteStatus.Pending;\\n }\\n\\n /**\\n * @dev Relays voted global proposal.\\n *\\n * Requirements:\\n * - The relay proposal is finalized.\\n *\\n */\\n function _relayGlobalProposal(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures,\\n bytes32 domainSeparator,\\n address creator\\n ) internal {\\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\\n bytes32 globalProposalHash = globalProposal.hash();\\n _relayVotesBySignatures(\\n _proposal,\\n supports_,\\n signatures,\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\\n );\\n }\\n}\\n\",\"keccak256\":\"0xe2c192ec663e10953b2754fa154fef64e26b8c470d25272883a9c149623746c8\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../CoreGovernance.sol\\\";\\nimport \\\"./CommonGovernanceRelay.sol\\\";\\n\\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\\n using Proposal for Proposal.ProposalDetail;\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n /**\\n * @dev Relays voted proposal.\\n *\\n * Requirements:\\n * - The relay proposal is finalized.\\n *\\n */\\n function _relayProposal(\\n Proposal.ProposalDetail calldata _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures,\\n bytes32 _domainSeparator,\\n address _creator\\n ) internal {\\n _proposeProposalStruct(_proposal, _creator);\\n bytes32 _proposalHash = _proposal.hash();\\n _relayVotesBySignatures(\\n _proposal,\\n _supports,\\n _signatures,\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\\n );\\n }\\n}\\n\",\"keccak256\":\"0xb21d764010845c562d1554168cf103b332755764107f6510eeddc1f03c82bc33\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallback.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @title IBridgeManagerCallback\\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\\n */\\ninterface IBridgeManagerCallback is IERC165 {\\n /**\\n * @dev Handles the event when bridge operators are added.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsAdded(\\n address[] memory bridgeOperators,\\n bool[] memory addeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when bridge operators are removed.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsRemoved(\\n address[] memory bridgeOperators,\\n bool[] memory removeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when a bridge operator is updated.\\n * @param currentBridgeOperator The address of the current bridge operator.\\n * @param newbridgeOperator The new address of the bridge operator.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorUpdated(\\n address currentBridgeOperator,\\n address newbridgeOperator\\n ) external returns (bytes4 selector);\\n}\\n\",\"keccak256\":\"0xfd6868a1041577a463b6c96713edcb18063dc817154d09710abfd5783e4629ee\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerCallbackRegister {\\n /**\\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\\n */\\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\\n\\n /**\\n * @dev Retrieves the addresses of registered callbacks.\\n * @return registers An array containing the addresses of registered callbacks.\\n */\\n function getCallbackRegisters() external view returns (address[] memory registers);\\n\\n /**\\n * @dev Registers multiple callbacks with the bridge.\\n * @param registers The array of callback addresses to register.\\n * @return registereds An array indicating the success status of each registration.\\n */\\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\\n\\n /**\\n * @dev Unregisters multiple callbacks from the bridge.\\n * @param registers The array of callback addresses to unregister.\\n * @return unregistereds An array indicating the success status of each unregistration.\\n */\\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\\n}\\n\",\"keccak256\":\"0xadbcf65ee9d55f4aa037216d71a279fe41855fe572a4a8734e6f69954aea98f4\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/ChainTypeConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface ChainTypeConsumer {\\n enum ChainType {\\n RoninChain,\\n Mainchain\\n }\\n}\\n\",\"keccak256\":\"0xe0d20e00c8d237f8e0fb881abf1ff1ef114173bcb428f06f689c581666a22db7\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/SignatureConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface SignatureConsumer {\\n struct Signature {\\n uint8 v;\\n bytes32 r;\\n bytes32 s;\\n }\\n}\\n\",\"keccak256\":\"0xd370e350722067097dec1a5c31bda6e47e83417fa5c3288293bb910028cd136b\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/VoteStatusConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface VoteStatusConsumer {\\n enum VoteStatus {\\n Pending,\\n Approved,\\n Executed,\\n Rejected,\\n Expired\\n }\\n}\\n\",\"keccak256\":\"0xa5045232c0c053fcf31fb3fe71942344444159c48d5f1b2063dbb06b6a1c9752\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Ballot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\n\\nlibrary Ballot {\\n using ECDSA for bytes32;\\n\\n enum VoteType {\\n For,\\n Against\\n }\\n\\n // keccak256(\\\"Ballot(bytes32 proposalHash,uint8 support)\\\");\\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\\n\\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, BALLOT_TYPEHASH)\\n mstore(add(ptr, 0x20), _proposalHash)\\n mstore(add(ptr, 0x40), _support)\\n digest := keccak256(ptr, 0x60)\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaa1e66bcd86baa6f18c7c5e9b67496535f229cbd2e2ecb4c66bcbfed2b1365de\",\"license\":\"MIT\"},\"contracts/libraries/GlobalProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./Proposal.sol\\\";\\n\\nlibrary GlobalProposal {\\n /**\\n * @dev Error thrown when attempting to interact with an unsupported target.\\n */\\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\\n\\n enum TargetOption {\\n /* 0 */ BridgeManager,\\n /* 1 */ GatewayContract,\\n /* 2 */ BridgeReward,\\n /* 3 */ BridgeSlash,\\n /* 4 */ BridgeTracking\\n }\\n\\n struct GlobalProposalDetail {\\n // Nonce to make sure proposals are executed in order\\n uint256 nonce;\\n uint256 expiryTimestamp;\\n TargetOption[] targetOptions;\\n uint256[] values;\\n bytes[] calldatas;\\n uint256[] gasAmounts;\\n }\\n\\n // keccak256(\\\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\\\");\\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\\n\\n /**\\n * @dev Returns struct hash of the proposal.\\n */\\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\\n uint256[] memory values = self.values;\\n TargetOption[] memory targets = self.targetOptions;\\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\\n uint256[] memory gasAmounts = self.gasAmounts;\\n\\n for (uint256 i; i < calldataHashList.length; ) {\\n calldataHashList[i] = keccak256(self.calldatas[i]);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n /*\\n * return\\n * keccak256(\\n * abi.encode(\\n * TYPE_HASH,\\n * _proposal.nonce,\\n * _proposal.expiryTimestamp,\\n * _targetsHash,\\n * _valuesHash,\\n * _calldatasHash,\\n * _gasAmountsHash\\n * )\\n * );\\n */\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\\n\\n let arrayHashed\\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\\n mstore(add(ptr, 0x60), arrayHashed)\\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\\n mstore(add(ptr, 0x80), arrayHashed)\\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\\n mstore(add(ptr, 0xa0), arrayHashed)\\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\\n mstore(add(ptr, 0xc0), arrayHashed)\\n digest_ := keccak256(ptr, 0xe0)\\n }\\n }\\n\\n /**\\n * @dev Converts into the normal proposal.\\n */\\n function intoProposalDetail(\\n GlobalProposalDetail memory self,\\n address[] memory targets\\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\\n detail_.nonce = self.nonce;\\n detail_.expiryTimestamp = self.expiryTimestamp;\\n detail_.chainId = 0;\\n detail_.targets = new address[](self.targetOptions.length);\\n detail_.values = self.values;\\n detail_.calldatas = self.calldatas;\\n detail_.gasAmounts = self.gasAmounts;\\n\\n for (uint256 i; i < self.targetOptions.length; ) {\\n detail_.targets[i] = targets[i];\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2716e1baf467abab71d89efa01ce0dc9164531ab4221d2758233a81b6d906474\",\"license\":\"MIT\"},\"contracts/libraries/Proposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ErrInvalidChainId, ErrLengthMismatch } from \\\"../utils/CommonErrors.sol\\\";\\n\\nlibrary Proposal {\\n /**\\n * @dev Error thrown when there is insufficient gas to execute a function.\\n */\\n error ErrInsufficientGas(bytes32 proposalHash);\\n\\n /**\\n * @dev Error thrown when an invalid expiry timestamp is provided.\\n */\\n error ErrInvalidExpiryTimestamp();\\n\\n struct ProposalDetail {\\n // Nonce to make sure proposals are executed in order\\n uint256 nonce;\\n // Value 0: all chain should run this proposal\\n // Other values: only specifc chain has to execute\\n uint256 chainId;\\n uint256 expiryTimestamp;\\n address[] targets;\\n uint256[] values;\\n bytes[] calldatas;\\n uint256[] gasAmounts;\\n }\\n\\n // keccak256(\\\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\\\");\\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\\n\\n /**\\n * @dev Validates the proposal.\\n */\\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\\n if (\\n !(_proposal.targets.length > 0 &&\\n _proposal.targets.length == _proposal.values.length &&\\n _proposal.targets.length == _proposal.calldatas.length &&\\n _proposal.targets.length == _proposal.gasAmounts.length)\\n ) {\\n revert ErrLengthMismatch(msg.sig);\\n }\\n\\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\\n revert ErrInvalidExpiryTimestamp();\\n }\\n }\\n\\n /**\\n * @dev Returns struct hash of the proposal.\\n */\\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\\n uint256[] memory _values = _proposal.values;\\n address[] memory _targets = _proposal.targets;\\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\\n\\n for (uint256 _i; _i < _calldataHashList.length; ) {\\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n // return\\n // keccak256(\\n // abi.encode(\\n // TYPE_HASH,\\n // _proposal.nonce,\\n // _proposal.chainId,\\n // _targetsHash,\\n // _valuesHash,\\n // _calldatasHash,\\n // _gasAmountsHash\\n // )\\n // );\\n // /\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\\n\\n let arrayHashed\\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\\n mstore(add(ptr, 0x80), arrayHashed)\\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\\n mstore(add(ptr, 0xa0), arrayHashed)\\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\\n mstore(add(ptr, 0xc0), arrayHashed)\\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\\n mstore(add(ptr, 0xe0), arrayHashed)\\n digest_ := keccak256(ptr, 0x100)\\n }\\n }\\n\\n /**\\n * @dev Returns whether the proposal is executable for the current chain.\\n *\\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\\n *\\n */\\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\\n }\\n\\n /**\\n * @dev Executes the proposal.\\n */\\n function execute(\\n ProposalDetail memory _proposal\\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\\n\\n _successCalls = new bool[](_proposal.targets.length);\\n _returnDatas = new bytes[](_proposal.targets.length);\\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\\n\\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\\n value: _proposal.values[_i],\\n gas: _proposal.gasAmounts[_i]\\n }(_proposal.calldatas[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xbc29aa4e69db7eef0034fdb795181124f86bcf2bc07b5e4a202100dbdce7f7a1\",\"license\":\"MIT\"},\"contracts/mainchain/MainchainBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { CoreGovernance } from \\\"../extensions/sequential-governance/CoreGovernance.sol\\\";\\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \\\"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\\\";\\nimport { GovernanceRelay } from \\\"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\\\";\\nimport { ContractType, BridgeManager } from \\\"../extensions/bridge-operator-governance/BridgeManager.sol\\\";\\nimport { Ballot } from \\\"../libraries/Ballot.sol\\\";\\nimport { Proposal } from \\\"../libraries/Proposal.sol\\\";\\nimport { GlobalProposal } from \\\"../libraries/GlobalProposal.sol\\\";\\nimport \\\"../utils/CommonErrors.sol\\\";\\n\\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\\n\\n constructor(\\n uint256 num,\\n uint256 denom,\\n uint256 roninChainId,\\n address bridgeContract,\\n address[] memory callbackRegisters,\\n address[] memory bridgeOperators,\\n address[] memory governors,\\n uint96[] memory voteWeights,\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n )\\n payable\\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\\n GlobalCoreGovernance(targetOptions, targets)\\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\\n {}\\n\\n /**\\n * @dev See `GovernanceRelay-_relayProposal`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n */\\n function relayProposal(\\n Proposal.ProposalDetail calldata proposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures\\n ) external onlyGovernor {\\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\\n }\\n\\n /**\\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n */\\n function relayGlobalProposal(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures\\n ) external onlyGovernor {\\n _relayGlobalProposal({\\n globalProposal: globalProposal,\\n supports_: supports_,\\n signatures: signatures,\\n domainSeparator: DOMAIN_SEPARATOR,\\n creator: msg.sender\\n });\\n }\\n\\n /**\\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\\n */\\n function _getMinimumVoteWeight() internal view override returns (uint256) {\\n return minimumVoteWeight();\\n }\\n\\n /**\\n * @dev Returns the expiry duration for a new proposal.\\n */\\n function getProposalExpiryDuration() external view returns (uint256) {\\n return _getProposalExpiryDuration();\\n }\\n\\n /**\\n * @dev Internal function to retrieve the total weights of all governors.\\n * @return totalWeights The total weights of all governors combined.\\n */\\n function _getTotalWeight() internal view override returns (uint256) {\\n return getTotalWeight();\\n }\\n\\n /**\\n * @dev Internal function to calculate the sum of weights for a given array of governors.\\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\\n * @return sumWeights The sum of weights for the provided governors.\\n */\\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\\n return _sumGovernorsWeight(governors);\\n }\\n\\n /**\\n * @dev Internal function to retrieve the chain type of the contract.\\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\\n */\\n function _getChainType() internal pure override returns (ChainType) {\\n return ChainType.Mainchain;\\n }\\n}\\n\",\"keccak256\":\"0xb365eb9fefd1c284a86aa97f0bd0d7eb5406d09c87832d1048b2c18d6c08d48a\",\"license\":\"MIT\"},\"contracts/types/Types.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { LibTUint256Slot } from \\\"./operations/LibTUint256Slot.sol\\\";\\n\\ntype TUint256Slot is bytes32;\\n\\nusing {\\n LibTUint256Slot.add,\\n LibTUint256Slot.sub,\\n LibTUint256Slot.mul,\\n LibTUint256Slot.div,\\n LibTUint256Slot.load,\\n LibTUint256Slot.store,\\n LibTUint256Slot.addAssign,\\n LibTUint256Slot.subAssign,\\n LibTUint256Slot.preDecrement,\\n LibTUint256Slot.postDecrement,\\n LibTUint256Slot.preIncrement,\\n LibTUint256Slot.postIncrement\\n} for TUint256Slot global;\\n\",\"keccak256\":\"0x20ab58f1c9ae4936f9dd9891d064301d78ef508c1dd2ce0c19a7b5b81d530e36\",\"license\":\"MIT\"},\"contracts/types/operations/LibTUint256Slot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { TUint256Slot } from \\\"../Types.sol\\\";\\n\\n/**\\n * @title LibTUint256Slot\\n * @dev Library for handling unsigned 256-bit integers.\\n */\\nlibrary LibTUint256Slot {\\n /// @dev value is equal to bytes4(keccak256(\\\"Panic(uint256)\\\"))\\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\\n /// @dev error code for {Arithmetic over/underflow} error\\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\\n /// @dev error code for {Division or modulo by 0} error\\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\\n\\n /**\\n * @dev Loads the value of the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @return val The loaded value.\\n */\\n function load(TUint256Slot self) internal view returns (uint256 val) {\\n assembly {\\n val := sload(self)\\n }\\n }\\n\\n /**\\n * @dev Stores a value into the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to be stored.\\n */\\n function store(TUint256Slot self, uint256 other) internal {\\n assembly {\\n sstore(self, other)\\n }\\n }\\n\\n /**\\n * @dev Multiplies the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to multiply by.\\n * @return res The resulting value after multiplication.\\n */\\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n if iszero(iszero(storedVal)) {\\n res := mul(storedVal, other)\\n\\n // Overflow check\\n if iszero(eq(other, div(res, storedVal))) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n }\\n\\n /**\\n * @dev Divides the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to divide by.\\n * @return res The resulting value after division.\\n */\\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n // revert if divide by zero\\n if iszero(other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, DIVISION_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n res := div(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction.\\n */\\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n\\n // Underflow check\\n if lt(storedVal, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n\\n res := sub(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition.\\n */\\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n res := add(storedVal, other)\\n\\n // Overflow check\\n if lt(res, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after incrementing.\\n */\\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = addAssign(self, 1);\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\\n * @param self The TUint256Slot variable.\\n * @return res The original value before incrementing.\\n */\\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res + 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after decrementing.\\n */\\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = subAssign(self, 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value before decrementing.\\n */\\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res - 1);\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition and storage.\\n */\\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = add(self, other));\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction and storage.\\n */\\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = sub(self, other));\\n }\\n}\\n\",\"keccak256\":\"0xe10c089459baf373494d76b00e582d49f6e43c500ab0f1657d53afc2fa472cbb\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x60a06040526040516200668038038062006680833981016040819052620000269162001625565b8181600160ff1b8c8c8c8c8c8c8c8c836200004181620001bd565b50506200007060016000805160206200666083398151915260001b620002da60201b62000ed61790919060201c565b6200007c8888620002de565b506200008c90506002866200044e565b604080516020808201839052600c60608301526b212924a223a2afa0a226a4a760a11b6080808401919091528284018a905283518084038201815260a0840185528051908301207f599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf60c08501527f9d3fa1662ea89365eb7af36506f0ad5413bd7e078960d8481ff4718763aaa8e960e08501527fad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a561010085015261012080850191909152845180850390910181526101409093019093528151910120905262000177818385620004f8565b50505050505050505062000191816200098b60201b60201c565b506200019f600030620009be565b620001ab828262000a5a565b50505050505050505050505062001a6e565b606081620001cb8162000b1d565b8251806001600160401b03811115620001e857620001e862001444565b60405190808252806020026020018201604052801562000212578160200160208202803683370190505b50925080600003620002255750620002d4565b6000805160206200662083398151915260006314d72edb60e21b815b84811015620002ce578781815181106200025f576200025f62001760565b602002602001015192506200027a8362000b6460201b60201c565b62000286838362000b9c565b620002a0838562000d7b60201b62000eda1790919060201c565b878281518110620002b557620002b562001760565b9115156020928302919091019091015260010162000241565b50505050505b50919050565b9055565b6000808284111562000316576040516387f6f09560e01b81526001600160e01b03196000351660048201526024015b60405180910390fd5b6200033e6000805160206200664083398151915260001b62000d9b60201b62000eef1760201c565b9150620003797fac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff60001b62000d9b60201b62000eef1760201c565b9050620003a7846000805160206200664083398151915260001b620002da60201b62000ed61790919060201c565b620003e4837fac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff60001b620002da60201b62000ed61790919060201c565b82846200040e6000805160206200666083398151915260001b62000d9f60201b62000ef31760201c565b60408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111562000487576200048762001776565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115620004cb57620004cb62001776565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606062000514828462000dc360201b62000f0e1790919060201c565b6200051f8162000b1d565b8251855181148015620005325750845181145b6200055f576040516306b5667560e21b81526001600160e01b03196000351660048201526024016200030d565b806001600160401b038111156200057a576200057a62001444565b604051908082528060200260200182016040528015620005a4578160200160208202803683370190505b50925080600003620005b7575062000983565b604080518082019091526000808252602082018190527f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c917f8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3917fd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d917f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3919081908190815b89811015620008c4578d81815181106200067a576200067a62001760565b602002602001015194508c818151811062000699576200069962001760565b60200260200101519350620006b48562000ee160201b60201c565b620006bf8462000ee1565b8e8181518110620006d457620006d462001760565b60200260200101516001600160601b03166000036200071557604051637f11b8a360e11b81526001600160e01b03196000351660048201526024016200030d565b6200072f858a62000f1860201b620010181790919060201c565b8062000750575062000750848a62000f1860201b620010181790919060201c565b8062000771575062000771858862000f1860201b620010181790919060201c565b8062000792575062000792848862000f1860201b620010181790919060201c565b158c8281518110620007a857620007a862001760565b6020026020010190151590811515815250508b8181518110620007cf57620007cf62001760565b602002602001015115620008bb57620007f7858a62000d7b60201b62000eda1790919060201c565b5062000812848862000d7b60201b62000eda1790919060201c565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f90829081106200085b576200085b62001760565b6020908102919091018101516001600160601b03169083018190526200088290846200178c565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b6001016200065c565b5062000902827f6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c60001b62000f3b60201b6200103a1790919060201c565b506200093a635ebae8a060e01b8d8d6040516020016200092492919062001828565b60408051601f1981840301815291905262000f55565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f6040516200097194939291906200185a565b60405180910390a15050505050505050505b509392505050565b600281905560405181907fe5cd1c123a8cf63fa1b7229678db61fe8ae99dbbd27889370b6667c8cae97da190600090a250565b8060036000846004811115620009d857620009d862001776565b6004811115620009ec57620009ec62001776565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600481111562000a2d5762000a2d62001776565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b60005b825181101562000b1857306001600160a01b031682828151811062000a865762000a8662001760565b60200260200101516001600160a01b03160362000ac55760405163053265f160e01b81526001600160e01b03196000351660048201526024016200030d565b62000b0f83828151811062000ade5762000ade62001760565b602002602001015183838151811062000afb5762000afb62001760565b6020026020010151620009be60201b60201c565b60010162000a5d565b505050565b62000b33816200129b60201b620010511760201c565b1562000b6157604051630d697db160e11b81526001600160e01b03196000351660048201526024016200030d565b50565b806001600160a01b03163b60000362000b6157604051630bfc64a360e21b81526001600160a01b03821660048201526024016200030d565b6040516001600160e01b03198216602482015260009060440160408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b0386169062000c0090859062001910565b600060405180830381855afa9150503d806000811462000c3d576040519150601f19603f3d011682016040523d82523d6000602084013e62000c42565b606091505b50915091508162000d2457846001600160a01b03168360405160240162000c6a91906200195c565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b1790525162000ca1919062001910565b600060405180830381855afa9150503d806000811462000cde576040519150601f19603f3d011682016040523d82523d6000602084013e62000ce3565b606091505b5090925090508162000d245760405163069d427960e11b81526001600160e01b0319851660048201526001600160a01b03861660248201526044016200030d565b8080602001905181019062000d3a919062001971565b62000d745760405163069d427960e11b81526001600160e01b0319851660048201526001600160a01b03861660248201526044016200030d565b5050505050565b600062000d92836001600160a01b03841662001346565b90505b92915050565b5490565b600062000daa825490565b905062000dbe82620002da8360016200178c565b919050565b81518151606091908082016001600160401b0381111562000de85762000de862001444565b60405190808252806020026020018201604052801562000e12578160200160208202803683370190505b50925060005b8281101562000e745785818151811062000e365762000e3662001760565b602002602001015184828151811062000e535762000e5362001760565b6001600160a01b039092166020928302919091019091015260010162000e18565b60005b8281101562000ed75785818151811062000e955762000e9562001760565b602002602001015185838151811062000eb25762000eb262001760565b6001600160a01b03909216602092830291909101909101526001918201910162000e77565b5050505092915050565b6001600160a01b03811662000b615760405163104c66df60e31b81526001600160e01b03196000351660048201526024016200030d565b6001600160a01b0381166000908152600183016020526040812054151562000d92565b600062000d958362000f4e818562001398565b9250829055565b600062000f7c60008051602062006620833981519152620013b860201b620010f01760201c565b8051909150600081900362000f915750505050565b6000816001600160401b0381111562000fae5762000fae62001444565b60405190808252806020026020018201604052801562000fd8578160200160208202803683370190505b5090506000826001600160401b0381111562000ff85762000ff862001444565b6040519080825280602002602001820160405280156200102d57816020015b6060815260200190600190039081620010175790505b509050600086866040516020016200104792919062001995565b60405160208183030381529060405290506000816040516024016200106d91906200195c565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b858110156200125157868181518110620010ba57620010ba62001760565b60200260200101516001600160a01b031683604051620010db919062001910565b6000604051808303816000865af19150503d80600081146200111a576040519150601f19603f3d011682016040523d82523d6000602084013e6200111f565b606091505b5086838151811062001135576200113562001760565b6020026020010186848151811062001151576200115162001760565b60200260200101829052821515151581525050508481815181106200117a576200117a62001760565b602002602001015162001248578681815181106200119c576200119c62001760565b60200260200101516001600160a01b031682604051620011bd919062001910565b6000604051808303816000865af19150503d8060008114620011fc576040519150601f19603f3d011682016040523d82523d6000602084013e62001201565b606091505b5086838151811062001217576200121762001760565b6020026020010186848151811062001233576200123362001760565b60200260200101829052821515151581525050505b6001016200109c565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b6382878686604051620012899493929190620019c8565b60405180910390a15050505050505050565b60008151600003620012af57506000919050565b60005b60018351038110156200133d57600181015b83518110156200133357838181518110620012e357620012e362001760565b60200260200101516001600160a01b031684838151811062001309576200130962001760565b60200260200101516001600160a01b0316036200132a575060019392505050565b600101620012c4565b50600101620012b2565b50600092915050565b60008181526001830160205260408120546200138f5750815460018181018455600084815260208082209093018490558454848252828601909352604090209190915562000d95565b50600062000d95565b815481018181101562000d9557634e487b7160005260116020526024601cfd5b60606000620013c783620013ce565b9392505050565b6060816000018054806020026020016040519081016040528092919081815260200182805480156200142057602002820191906000526020600020905b8154815260200190600101908083116200140b575b50505050509050919050565b80516001600160a01b038116811462000dbe57600080fd5b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b038111828210171562001485576200148562001444565b604052919050565b60006001600160401b03821115620014a957620014a962001444565b5060051b60200190565b600082601f830112620014c557600080fd5b81516020620014de620014d8836200148d565b6200145a565b82815260059290921b84018101918181019086841115620014fe57600080fd5b8286015b84811015620015245762001516816200142c565b835291830191830162001502565b509695505050505050565b600082601f8301126200154157600080fd5b8151602062001554620014d8836200148d565b82815260059290921b840181019181810190868411156200157457600080fd5b8286015b84811015620015245780516001600160601b03811681146200159a5760008081fd5b835291830191830162001578565b600082601f830112620015ba57600080fd5b81516020620015cd620014d8836200148d565b828152600592831b8501820192828201919087851115620015ed57600080fd5b8387015b85811015620016185780518281106200160a5760008081fd5b8452928401928401620015f1565b5090979650505050505050565b6000806000806000806000806000806101408b8d0312156200164657600080fd5b8a51995060208b0151985060408b015197506200166660608c016200142c565b60808c01519097506001600160401b03808211156200168457600080fd5b620016928e838f01620014b3565b975060a08d0151915080821115620016a957600080fd5b620016b78e838f01620014b3565b965060c08d0151915080821115620016ce57600080fd5b620016dc8e838f01620014b3565b955060e08d0151915080821115620016f357600080fd5b620017018e838f016200152f565b94506101008d01519150808211156200171957600080fd5b620017278e838f01620015a8565b93506101208d01519150808211156200173f57600080fd5b506200174e8d828e01620014b3565b9150509295989b9194979a5092959850565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052602160045260246000fd5b8082018082111562000d9557634e487b7160e01b600052601160045260246000fd5b600081518084526020808501945080840160005b83811015620017e95781516001600160a01b031687529582019590820190600101620017c2565b509495945050505050565b600081518084526020808501945080840160005b83811015620017e957815115158752958201959082019060010162001808565b6040815260006200183d6040830185620017ae565b8281036020840152620018518185620017f4565b95945050505050565b6080815260006200186f6080830187620017f4565b82810360208481019190915286518083528782019282019060005b81811015620018b15784516001600160601b0316835293830193918301916001016200188a565b50508481036040860152620018c78188620017ae565b925050508281036060840152620018df8185620017ae565b979650505050505050565b60005b8381101562001907578181015183820152602001620018ed565b50506000910152565b6000825162001924818460208701620018ea565b9190910192915050565b6000815180845262001948816020860160208601620018ea565b601f01601f19169290920160200192915050565b60208152600062000d9260208301846200192e565b6000602082840312156200198457600080fd5b81518015158114620013c757600080fd5b6001600160e01b0319831681528151600090620019ba816004850160208701620018ea565b919091016004019392505050565b608081526000620019dd60808301876200192e565b602083820381850152620019f28288620017ae565b9150838203604085015262001a088287620017f4565b915083820360608501528185518084528284019150828160051b85010183880160005b8381101562001a5d57601f1987840301855262001a4a8383516200192e565b9486019492509085019060010162001a2b565b50909b9a5050505050505050505050565b608051614b8862001a98600039600081816102c5015281816107c501526108510152614b886000f3fe608060405234801561001057600080fd5b50600436106101fb5760003560e01c80639b19dbfd1161011a578063cc7e6b3b116100ad578063de981f1b1161007c578063de981f1b1461050c578063e75235b814610537578063e9c034981461053f578063f80b535214610552578063fdc4fa471461055a57600080fd5b8063cc7e6b3b146104be578063d0a50db0146104de578063d78392f8146104e6578063dafae408146104f957600080fd5b8063b9c36209116100e9578063b9c3620914610464578063bc9182fd1461048c578063bc96180b1461049f578063c441c4a8146104a757600080fd5b80639b19dbfd146103db5780639b2ee437146103e3578063b384abef146103f6578063b405aaf21461045157600080fd5b80633644e515116101925780637de5dedd116101615780637de5dedd14610332578063800eaab31461033a578063865e6fd31461034d578063901979d51461036057600080fd5b80633644e515146102c05780635e05cf9e146102e7578063776fb1ec146102fc5780637d465f791461031f57600080fd5b80631f425338116101ce5780631f425338146102675780632d6d7d731461027a57806334d5f37b1461028d57806335da8121146102ad57600080fd5b806301a5f43f1461020057806306aba0e1146102295780630a44fa431461023f5780630f7c318914610252575b600080fd5b61021361020e366004613b7d565b61056d565b6040516102209190613c53565b60405180910390f35b610231610620565b604051908152602001610220565b61023161024d366004613c66565b61063d565b61025a6106c2565b6040516102209190613ce0565b610213610275366004613c66565b6106db565b61025a610288366004613c66565b610728565b61023161029b366004613cf3565b60006020819052908152604090205481565b6102136102bb366004613c66565b61076c565b6102317f000000000000000000000000000000000000000000000000000000000000000081565b6102fa6102f5366004613d50565b6107b2565b005b61030f61030a366004613cf3565b6107f1565b6040519015158152602001610220565b6102fa61032d366004613dec565b61083e565b610231610876565b6102fa610348366004613fe0565b6108f2565b6102fa61035b366004614052565b610937565b6103c361036e366004614085565b6001600160a01b039081166000908152600080516020614af383398151915260209081526040808320549093168252600080516020614ad383398151915290522054600160a01b90046001600160601b031690565b6040516001600160601b039091168152602001610220565b61025a610952565b6102fa6103f1366004614085565b61095c565b6104406104043660046140a0565b600160208181526000938452604080852090915291835291208054918101546002820154600383015460069093015460ff909416939192909185565b6040516102209594939291906140e8565b61030f61045f366004614085565b610af3565b6104776104723660046140a0565b610b0d565b60408051928352602083019190915201610220565b61025a61049a366004614116565b610b2e565b610231610c1f565b6104af610c2a565b60405161022093929190614183565b6104d16104cc366004613c66565b610c54565b60405161022091906141c6565b610231610c92565b6103c36104f4366004614085565b610cab565b61030f610507366004613cf3565b610cb6565b61051f61051a3660046141d9565b610cf3565b6040516001600160a01b039091168152602001610220565b610477610d6e565b61021361054d366004613c66565b610d9f565b61025a610de5565b61025a610568366004613c66565b610def565b60606105776110fd565b61061587878080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808b0282810182019093528a82529093508a92508991829185019084908082843760009201919091525050604080516020808a0282810182019093528982529093508992508891829185019084908082843760009201919091525061112d92505050565b979650505050505050565b6000610638600080516020614b338339815191525490565b905090565b600082828080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061067e92508391506114a99050565b6106ba8484808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506114e192505050565b949350505050565b6060610638600080516020614a738339815191526110f0565b60606106e56110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061156592505050565b9392505050565b606061072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201829052509250611630915050565b92915050565b60606107766110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061178a92505050565b6107bb3361187c565b6107ea85858585857f0000000000000000000000000000000000000000000000000000000000000000336118be565b5050505050565b60008060008381527fa6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49602052604090205460ff166004811115610836576108366140c2565b141592915050565b6108473361187c565b6107ea85858585857f000000000000000000000000000000000000000000000000000000000000000033611963565b600061088e600080516020614a938339815191525490565b60016108a6600080516020614a938339815191525490565b6108d46108bf600080516020614b338339815191525490565b600080516020614ab3833981519152906119bf565b6108de919061420a565b6108e8919061421d565b6106389190614230565b333014610929576000356001600160e01b0319166040516307337e1960e41b81526004016109209190614252565b60405180910390fd5b61093382826119ea565b5050565b61093f6110fd565b61094881611a98565b6109338282611ace565b6060610638611b72565b6109653361187c565b61096e81611b8b565b336000908152600080516020614ad383398151915260208190526040909120546001600160a01b0390811690831681036109c657604051630669b93360e31b81526001600160a01b0384166004820152602401610920565b600080516020614b1383398151915260006109e18284611bc0565b80156109f257506109f28286610eda565b905080610a1d5760405163080fab4b60e31b81526001600160a01b0386166004820152602401610920565b6001600160a01b038381166000818152600080516020614af38339815191526020818152604080842080546001600160a01b0319908116909155958b16808552818520805488163390811790915585528a8352938190208054909616841790955584519081019390935292820152610ab0906364b18d0960e11b906060015b604051602081830303815290604052611bd5565b6040516001600160a01b03808816919086169033907fcef34cd748f30a1b7a2f214fd1651779f79bc6c1be02785cad5c1f0ee877213d90600090a4505050505050565b6000610766600080516020614b1383398151915283611018565b600080610b186110fd565b610b228484611edd565b915091505b9250929050565b8051606090806001600160401b03811115610b4b57610b4b613e2f565b604051908082528060200260200182016040528015610b74578160200160208202803683370190505b509150600080516020614ad383398151915260005b82811015610c1757816000868381518110610ba657610ba6614267565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160009054906101000a90046001600160a01b0316848281518110610bf757610bf7614267565b6001600160a01b0390921660209283029190910190910152600101610b89565b505050919050565b600061063860025490565b6060806060610c37611fd2565b9250610c4283610b2e565b9150610c4d83611ffd565b9050909192565b6060610721838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611ffd92505050565b6000610638600080516020614b138339815191526120e6565b6000610766826120f0565b6000610cd16108bf600080516020614b338339815191525490565b600080516020614a9383398151915254610ceb908461427d565b101592915050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610d2a57610d2a6140c2565b60ff1681526020810191909152604001600020546001600160a01b0316905080610d69578160405163409140df60e11b81526004016109209190614294565b919050565b600080610d87600080516020614ab38339815191525490565b600080516020614a9383398151915254915091509091565b6060610da96110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061212892505050565b6060610638611fd2565b606081806001600160401b03811115610e0a57610e0a613e2f565b604051908082528060200260200182016040528015610e33578160200160208202803683370190505b509150600080516020614af383398151915260005b82811015610ecd57816000878784818110610e6557610e65614267565b9050602002016020810190610e7a9190614085565b6001600160a01b0390811682526020820192909252604001600020548551911690859083908110610ead57610ead614267565b6001600160a01b0390921660209283029190910190910152600101610e48565b50505092915050565b9055565b6000610721836001600160a01b03841661240d565b5490565b6000610efd825490565b9050610d6982610ed683600161420a565b81518151606091908082016001600160401b03811115610f3057610f30613e2f565b604051908082528060200260200182016040528015610f59578160200160208202803683370190505b50925060005b82811015610fb357858181518110610f7957610f79614267565b6020026020010151848281518110610f9357610f93614267565b6001600160a01b0390921660209283029190910190910152600101610f5f565b60005b8281101561100e57858181518110610fd057610fd0614267565b6020026020010151858381518110610fea57610fea614267565b6001600160a01b039092166020928302919091019091015260019182019101610fb6565b5050505092915050565b6001600160a01b03811660009081526001830160205260408120541515610721565b60006107668361104a858561245c565b9250829055565b6000815160000361106457506000919050565b60005b60018351038110156110e757600181015b83518110156110de5783818151811061109357611093614267565b60200260200101516001600160a01b03168483815181106110b6576110b6614267565b60200260200101516001600160a01b0316036110d6575060019392505050565b600101611078565b50600101611067565b50600092915050565b606060006107218361247b565b33301461112b576000356001600160e01b0319166040516307337e1960e41b81526004016109209190614252565b565b60606111398383610f0e565b611142816114a9565b82518551811480156111545750845181145b61117f576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b806001600160401b0381111561119757611197613e2f565b6040519080825280602002602001820160405280156111c0578160200160208202803683370190505b509250806000036111d157506114a1565b604080518082019091526000808252602082018190527f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c91600080516020614af383398151915291600080516020614b1383398151915291600080516020614ad3833981519152919081908190815b89811015611422578d818151811061125a5761125a614267565b602002602001015194508c818151811061127657611276614267565b6020026020010151935061128985611b8b565b61129284611b8b565b8e81815181106112a4576112a4614267565b60200260200101516001600160601b03166000036112e3576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b6112ed8986611018565b806112fd57506112fd8985611018565b8061130d575061130d8786611018565b8061131d575061131d8785611018565b158c828151811061133057611330614267565b6020026020010190151590811515815250508b818151811061135457611354614267565b60200260200101511561141a5761136b8986610eda565b506113768785610eda565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f90829081106113bc576113bc614267565b6020908102919091018101516001600160601b03169083018190526113e1908461420a565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b600101611240565b5061143b600080516020614b338339815191528361103a565b5061145a635ebae8a060e01b8d8d604051602001610a9c9291906142ae565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f60405161148f94939291906142dc565b60405180910390a15050505050505050505b509392505050565b6114b281611051565b156114de576000356001600160e01b031916604051630d697db160e11b81526004016109209190614252565b50565b6000816114ed816114a9565b600080516020614ad383398151915260005b8451811015610c175781600086838151811061151d5761151d614267565b6020908102919091018101516001600160a01b031682528101919091526040016000205461155b90600160a01b90046001600160601b03168561420a565b93506001016114ff565b606081611571816114a9565b8251806001600160401b0381111561158b5761158b613e2f565b6040519080825280602002602001820160405280156115b4578160200160208202803683370190505b509250600080516020614a7383398151915260005b82811015611627576115fd8682815181106115e6576115e6614267565b602002602001015183611bc090919063ffffffff16565b85828151811061160f5761160f614267565b911515602092830291909101909101526001016115c9565b50505050919050565b606082516001600160401b0381111561164b5761164b613e2f565b604051908082528060200260200182016040528015611674578160200160208202803683370190505b50905060005b8351811015611783576003600085838151811061169957611699614267565b602002602001015160048111156116b2576116b26140c2565b60048111156116c3576116c36140c2565b815260200190815260200160002060009054906101000a90046001600160a01b03168282815181106116f7576116f7614267565b60200260200101906001600160a01b031690816001600160a01b03168152505082801561174f575060006001600160a01b031682828151811061173c5761173c614267565b60200260200101516001600160a01b0316145b1561177b576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b60010161167a565b5092915050565b606081611796816114a9565b8251806001600160401b038111156117b0576117b0613e2f565b6040519080825280602002602001820160405280156117d9578160200160208202803683370190505b509250806000036117ea5750611876565b600080516020614a7383398151915260006314d72edb60e21b815b848110156118705787818151811061181f5761181f614267565b6020026020010151925061183283611a98565b61183c83836124d7565b6118468484610eda565b87828151811061185857611858614267565b91151560209283029190910190910152600101611805565b50505050505b50919050565b611885816120f0565b6001600160601b03166000036114de576000356001600160e01b0319166003604051620f948f60ea1b8152600401610920929190614329565b6118d06118ca88614495565b8261266a565b5060006118e46118df89614495565b612770565b90506119596118f289614495565b88888888611945896119058960006128af565b60405161190160f01b6020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6119548a6119058a60016128af565b6128e8565b5050505050505050565b600061197761197189614569565b83612cdf565b9050600061198c6119878a614569565b612e29565b90506119b482898989896119a58a6119058960006128af565b6119548b6119058a60016128af565b505050505050505050565b600082548015611783578281029150808204831461178357634e487b7160005260116020526024601cfd5b60005b8251811015611a9357306001600160a01b0316828281518110611a1257611a12614267565b60200260200101516001600160a01b031603611a4f576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b611a8b838281518110611a6457611a64614267565b6020026020010151838381518110611a7e57611a7e614267565b6020026020010151612f60565b6001016119ed565b505050565b806001600160a01b03163b6000036114de57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610920565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115611b0457611b046140c2565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115611b4557611b456140c2565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6060610638600080516020614b138339815191526110f0565b6001600160a01b0381166114de576000356001600160e01b03191660405163104c66df60e31b81526004016109209190614252565b6000610721836001600160a01b038416612ff3565b6000611bee600080516020614a738339815191526110f0565b80519091506000819003611c025750505050565b6000816001600160401b03811115611c1c57611c1c613e2f565b604051908082528060200260200182016040528015611c45578160200160208202803683370190505b5090506000826001600160401b03811115611c6257611c62613e2f565b604051908082528060200260200182016040528015611c9557816020015b6060815260200190600190039081611c805790505b50905060008686604051602001611cad929190614657565b6040516020818303038152906040529050600081604051602401611cd191906146b4565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b85811015611e9557868181518110611d1a57611d1a614267565b60200260200101516001600160a01b031683604051611d3991906146c7565b6000604051808303816000865af19150503d8060008114611d76576040519150601f19603f3d011682016040523d82523d6000602084013e611d7b565b606091505b50868381518110611d8e57611d8e614267565b60200260200101868481518110611da757611da7614267565b6020026020010182905282151515158152505050848181518110611dcd57611dcd614267565b6020026020010151611e8d57868181518110611deb57611deb614267565b60200260200101516001600160a01b031682604051611e0a91906146c7565b6000604051808303816000865af19150503d8060008114611e47576040519150601f19603f3d011682016040523d82523d6000602084013e611e4c565b606091505b50868381518110611e5f57611e5f614267565b60200260200101868481518110611e7857611e78614267565b60200260200101829052821515151581525050505b600101611d00565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b6382878686604051611ecb9493929190614728565b60405180910390a15050505050505050565b60008082841115611f0f576000356001600160e01b0319166040516387f6f09560e01b81526004016109209190614252565b600080516020614ab3833981519152549150611f37600080516020614a938339815191525490565b9050611f50600080516020614ab3833981519152859055565b611f67600080516020614a93833981519152849055565b8284611f927f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d610ef3565b60408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b60606106387f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c6110f0565b8051606090806001600160401b0381111561201a5761201a613e2f565b604051908082528060200260200182016040528015612043578160200160208202803683370190505b509150600080516020614ad383398151915260005b82811015610c175781600086838151811061207557612075614267565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160149054906101000a90046001600160601b03168482815181106120c6576120c6614267565b6001600160601b0390921660209283029190910190910152600101612058565b6000610766825490565b6001600160a01b03166000908152600080516020614ad38339815191526020526040902054600160a01b90046001600160601b031690565b606081612134816114a9565b8251806001600160401b0381111561214e5761214e613e2f565b604051908082528060200260200182016040528015612177578160200160208202803683370190505b509250806000036121885750611876565b60408051808201909152600080825260208201819052600080516020614af3833981519152917f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c91600080516020614b1383398151915291600080516020614ad3833981519152919081908190815b8981101561238d578c818151811061221157612211614267565b6020908102919091018101516001600160a01b038082166000908152928c90526040909220549091169550935061224785611b8b565b61225084611b8b565b6001600160a01b0385811660009081526020888152604091829020825180840190935254808416808452600160a01b9091046001600160601b031691830191909152909350908516146122c4576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b6122ce8785611018565b80156122df57506122df8886611018565b8c82815181106122f1576122f1614267565b6020026020010190151590811515815250508b818151811061231557612315614267565b6020026020010151156123855761232c8886611bc0565b506123378785611bc0565b506001600160a01b03808516600090815260208b8152604080832080546001600160a01b0319169055928816825288815291812055820151612382906001600160601b03168461420a565b92505b6001016121f7565b506123a6600080516020614b33833981519152836130e6565b506123c563c48549de60e01b8d8d604051602001610a9c9291906142ae565b7fdf3dcd7987202f64648f3acdbf12401e3a2bb23e77e19f99826b5475cbb863698b8d6040516123f6929190614775565b60405180910390a150505050505050505050919050565b600081815260018301602052604081205461245457508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610766565b506000610766565b815481018181101561076657634e487b7160005260116020526024601cfd5b6060816000018054806020026020016040519081016040528092919081815260200182805480156124cb57602002820191906000526020600020905b8154815260200190600101908083116124b7575b50505050509050919050565b6000816040516024016124ea9190614252565b60408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b038616906125339085906146c7565b600060405180830381855afa9150503d806000811461256e576040519150601f19603f3d011682016040523d82523d6000602084013e612573565b606091505b50915091508161263557846001600160a01b03168360405160240161259891906146b4565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b179052516125cd91906146c7565b600060405180830381855afa9150503d8060008114612608576040519150601f19603f3d011682016040523d82523d6000602084013e61260d565b606091505b5090925090508161263557838560405163069d427960e11b815260040161092092919061479a565b8080602001905181019061264991906147bd565b6107ea57838560405163069d427960e11b815260040161092092919061479a565b60208201516000908082036126ac5760405163092048d160e11b8152600080356001600160e01b03191660048301526024820152466044820152606401610920565b6002546126ba9085906130f6565b60006126c585612770565b90506126d082613197565b6000838152600160208181526040808420858552909152918290209188015190820184905560069091015592508451831461272c576000356001600160e01b03191660405163d4cec26960e01b81526004016109209190614252565b8083837fa57d40f1496988cf60ab7c9d5ba4ff83647f67d3898d441a3aaf21b651678fd988886040516127609291906148c9565b60405180910390a4505092915050565b6080810151606082015160a083015151600092919083906001600160401b0381111561279e5761279e613e2f565b6040519080825280602002602001820160405280156127c7578160200160208202803683370190505b5060c086015190915060005b8251811015612826578660a0015181815181106127f2576127f2614267565b60200260200101518051906020012083828151811061281357612813614267565b60209081029190910101526001016127d3565b50604080517fd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a8152875160208083019190915280890151828401529790910151606082015283518702938701939093206080840152835186029386019390932060a0830152805185029085012060c082015281518402919093012060e083015250610100902090565b604080517fd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2815260208101939093528201526060902090565b84158015906128f657508483145b612921576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b60008080856001600160401b0381111561293d5761293d613e2f565b604051908082528060200260200182016040528015612966578160200160208202803683370190505b5090506000866001600160401b0381111561298357612983613e2f565b6040519080825280602002602001820160405280156129ac578160200160208202803683370190505b50905060008060003660005b8b811015612b3d578c8c828181106129d2576129d2614267565b90506060020191508e8e828181106129ec576129ec614267565b9050602002016020810190612a0191906148f3565b92506000836001811115612a1757612a176140c2565b03612a8157612a3c8b612a2d6020850185614914565b84602001358560400135613233565b945084878a612a4a81614937565b9b5081518110612a5c57612a5c614267565b60200260200101906001600160a01b031690816001600160a01b031681525050612af2565b6001836001811115612a9557612a956140c2565b03612acb57612aab8a612a2d6020850185614914565b9450848689612ab981614937565b9a5081518110612a5c57612a5c614267565b6000356001600160e01b031916604051630612418f60e11b81526004016109209190614252565b846001600160a01b0316846001600160a01b031610612b32576000356001600160e01b031916604051635d3dcd3160e01b81526004016109209190614252565b8493506001016129b8565b50505085845250508281526020808c015160009081526001825260408082208e51835290925290812090612b6f61325b565b90506000612b7c85613265565b9050818110612c035780600003612bb4576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b825460ff1916600190811784558301546040517f5c819725ea53655a3b898f3df59b66489761935454e9212ca1e5ebd759953d0b90600090a2612bf7838f613270565b50505050505050612cd6565b600082612c0e6132dd565b612c18919061421d565b612c2390600161420a565b90506000612c3086613265565b9050818110612caf5780600003612c68576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b845460ff1916600317855560018501546040517f55295d4ce992922fa2e5ffbf3a3dcdb367de0a15e125ace083456017fd22060f90600090a2505050505050505050612cd6565b6000356001600160e01b031916604051634ccfe64360e11b81526004016109209190614252565b50505050505050565b612d1f6040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b612d38612d3184604001516001611630565b84906132e7565b9050612d4f600254826130f690919063ffffffff16565b6000612d5a82612770565b90506000612d686000613197565b60008181527fa6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49602090815260409091209087015160018201859055600690910155905082518114612dda576000356001600160e01b03191660405163d4cec26960e01b81526004016109209190614252565b81817f771d78ae9e5fca95a532fb0971d575d0ce9b59d14823c063e08740137e0e0eca85612e0789612e29565b8989604051612e199493929190614950565b60405180910390a3505092915050565b60608101516040820151608083015151600092919083906001600160401b03811115612e5757612e57613e2f565b604051908082528060200260200182016040528015612e80578160200160208202803683370190505b5060a086015190915060005b8251811015612edf5786608001518181518110612eab57612eab614267565b602002602001015180519060200120838281518110612ecc57612ecc614267565b6020908102919091010152600101612e8c565b50604080517f1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee911413508152875160208083019190915297880151918101919091528351870293870193909320606084015283518602938601939093206080830152805185029085012060a082015281518402919093012060c08301525060e0902090565b8060036000846004811115612f7757612f776140c2565b6004811115612f8857612f886140c2565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b039283161790558116826004811115612fc657612fc66140c2565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b600081815260018301602052604081205480156130dc57600061301760018361421d565b855490915060009061302b9060019061421d565b905081811461309057600086600001828154811061304b5761304b614267565b906000526020600020015490508087600001848154811061306e5761306e614267565b6000918252602080832090910192909255918252600188019052604090208390555b85548690806130a1576130a1614a37565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610766565b6000915050610766565b60006107668361104a8585613411565b60008260600151511180156131145750816080015151826060015151145b801561312957508160a0015151826060015151145b801561313e57508160c0015151826060015151145b613169576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b613173814261420a565b826040015111156109335760405163ad89be9d60e01b815260040160405180910390fd5b600081815260208190526040812054908190036131c65750600090815260208190526040902060019081905590565b60008281526001602090815260408083208484529091528120906000825460ff1660048111156131f8576131f86140c2565b036132165760405163757a436360e01b815260040160405180910390fd5b505050600090815260208190526040902080546001019081905590565b6000806000613244878787876135ec565b91509150613251816136d9565b5095945050505050565b6000610638610876565b6000610766826114e1565b6132798161388f565b1561093357815460ff19166002178255600080613295836138a9565b9150915083600101547fe134987599ae266ec90edeff1b26125b287dbb57b10822649432d1bb26537fba83836040516132cf929190614a4d565b60405180910390a250505050565b6000610638610620565b6133276040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b82518152602080840151604080840191909152600091830191909152830151516001600160401b0381111561335e5761335e613e2f565b604051908082528060200260200182016040528015613387578160200160208202803683370190505b5060608083019190915283015160808083019190915283015160a08083019190915283015160c082015260005b836040015151811015611783578281815181106133d3576133d3614267565b6020026020010151826060015182815181106133f1576133f1614267565b6001600160a01b03909216602092830291909101909101526001016133b4565b600082548281101561343057634e487b7160005260116020526024601cfd5b9190910392915050565b60048301548110156134ed5782600801600084600401838154811061346157613461614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916905560048401805460078601929190849081106134aa576134aa614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916815560018181018390556002909101919091550161343a565b5060005b60058301548110156135a45782600801600084600501838154811061351857613518614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19169055600584018054600786019291908490811061356157613561614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff191681556001818101839055600290910191909155016134f1565b50815460ff1916825560006001830181905560028301819055600383018190556135d2906004840190613b07565b6135e0600583016000613b07565b60006006830155919050565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a083111561362357506000905060036136d0565b8460ff16601b1415801561363b57508460ff16601c14155b1561364c57506000905060046136d0565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa1580156136a0573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166136c9576000600192509250506136d0565b9150600090505b94509492505050565b60008160048111156136ed576136ed6140c2565b036136f55750565b6001816004811115613709576137096140c2565b036137565760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610920565b600281600481111561376a5761376a6140c2565b036137b75760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610920565b60038160048111156137cb576137cb6140c2565b036138235760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610920565b6004816004811115613837576138376140c2565b036114de5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610920565b600081602001516000148061076657505060200151461490565b6060806138b58361388f565b6138f357602083015160405163092048d160e11b81526000356001600160e01b03191660048201526024810191909152466044820152606401610920565b8260600151516001600160401b0381111561391057613910613e2f565b604051908082528060200260200182016040528015613939578160200160208202803683370190505b5091508260600151516001600160401b0381111561395957613959613e2f565b60405190808252806020026020018201604052801561398c57816020015b60608152602001906001900390816139775790505b50905060005b836060015151811015613b01578360c0015181815181106139b5576139b5614267565b60200260200101515a116139e8576139cc84612770565b6040516307aec4ab60e21b815260040161092091815260200190565b836060015181815181106139fe576139fe614267565b60200260200101516001600160a01b031684608001518281518110613a2557613a25614267565b60200260200101518560c001518381518110613a4357613a43614267565b6020026020010151908660a001518481518110613a6257613a62614267565b6020026020010151604051613a7791906146c7565b600060405180830381858888f193505050503d8060008114613ab5576040519150601f19603f3d011682016040523d82523d6000602084013e613aba565b606091505b50848381518110613acd57613acd614267565b60200260200101848481518110613ae657613ae6614267565b60209081029190910101919091529015159052600101613992565b50915091565b50805460008255906000526020600020908101906114de91905b80821115613b355760008155600101613b21565b5090565b60008083601f840112613b4b57600080fd5b5081356001600160401b03811115613b6257600080fd5b6020830191508360208260051b8501011115610b2757600080fd5b60008060008060008060608789031215613b9657600080fd5b86356001600160401b0380821115613bad57600080fd5b613bb98a838b01613b39565b90985096506020890135915080821115613bd257600080fd5b613bde8a838b01613b39565b90965094506040890135915080821115613bf757600080fd5b50613c0489828a01613b39565b979a9699509497509295939492505050565b600081518084526020808501945080840160005b83811015613c48578151151587529582019590820190600101613c2a565b509495945050505050565b6020815260006107216020830184613c16565b60008060208385031215613c7957600080fd5b82356001600160401b03811115613c8f57600080fd5b613c9b85828601613b39565b90969095509350505050565b600081518084526020808501945080840160005b83811015613c485781516001600160a01b031687529582019590820190600101613cbb565b6020815260006107216020830184613ca7565b600060208284031215613d0557600080fd5b5035919050565b60008083601f840112613d1e57600080fd5b5081356001600160401b03811115613d3557600080fd5b602083019150836020606083028501011115610b2757600080fd5b600080600080600060608688031215613d6857600080fd5b85356001600160401b0380821115613d7f57600080fd5b9087019060e0828a031215613d9357600080fd5b90955060208701359080821115613da957600080fd5b613db589838a01613b39565b90965094506040880135915080821115613dce57600080fd5b50613ddb88828901613d0c565b969995985093965092949392505050565b600080600080600060608688031215613e0457600080fd5b85356001600160401b0380821115613e1b57600080fd5b9087019060c0828a031215613d9357600080fd5b634e487b7160e01b600052604160045260246000fd5b60405160e081016001600160401b0381118282101715613e6757613e67613e2f565b60405290565b60405160c081016001600160401b0381118282101715613e6757613e67613e2f565b604051601f8201601f191681016001600160401b0381118282101715613eb757613eb7613e2f565b604052919050565b60006001600160401b03821115613ed857613ed8613e2f565b5060051b60200190565b600082601f830112613ef357600080fd5b81356020613f08613f0383613ebf565b613e8f565b828152600592831b8501820192828201919087851115613f2757600080fd5b8387015b85811015613f4f578035828110613f425760008081fd5b8452928401928401613f2b565b5090979650505050505050565b80356001600160a01b0381168114610d6957600080fd5b600082601f830112613f8457600080fd5b81356020613f94613f0383613ebf565b82815260059290921b84018101918181019086841115613fb357600080fd5b8286015b84811015613fd557613fc881613f5c565b8352918301918301613fb7565b509695505050505050565b60008060408385031215613ff357600080fd5b82356001600160401b038082111561400a57600080fd5b61401686838701613ee2565b9350602085013591508082111561402c57600080fd5b5061403985828601613f73565b9150509250929050565b803560108110610d6957600080fd5b6000806040838503121561406557600080fd5b61406e83614043565b915061407c60208401613f5c565b90509250929050565b60006020828403121561409757600080fd5b61072182613f5c565b600080604083850312156140b357600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b600581106114de576114de6140c2565b60a081016140f5876140d8565b95815260208101949094526040840192909252606083015260809091015290565b60006020828403121561412857600080fd5b81356001600160401b0381111561413e57600080fd5b6106ba84828501613f73565b600081518084526020808501945080840160005b83811015613c485781516001600160601b03168752958201959082019060010161415e565b6060815260006141966060830186613ca7565b82810360208401526141a88186613ca7565b905082810360408401526141bc818561414a565b9695505050505050565b602081526000610721602083018461414a565b6000602082840312156141eb57600080fd5b61072182614043565b634e487b7160e01b600052601160045260246000fd5b80820180821115610766576107666141f4565b81810381811115610766576107666141f4565b60008261424d57634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b031991909116815260200190565b634e487b7160e01b600052603260045260246000fd5b8082028115828204841417610766576107666141f4565b60208101601083106142a8576142a86140c2565b91905290565b6040815260006142c16040830185613ca7565b82810360208401526142d38185613c16565b95945050505050565b6080815260006142ef6080830187613c16565b8281036020840152614301818761414a565b905082810360408401526143158186613ca7565b905082810360608401526106158185613ca7565b6001600160e01b03198316815260408101600b831061434a5761434a6140c2565b8260208301529392505050565b600082601f83011261436857600080fd5b81356020614378613f0383613ebf565b82815260059290921b8401810191818101908684111561439757600080fd5b8286015b84811015613fd5578035835291830191830161439b565b6000601f83818401126143c457600080fd5b823560206143d4613f0383613ebf565b82815260059290921b850181019181810190878411156143f357600080fd5b8287015b848110156144895780356001600160401b03808211156144175760008081fd5b818a0191508a603f83011261442c5760008081fd5b8582013560408282111561444257614442613e2f565b614453828b01601f19168901613e8f565b92508183528c8183860101111561446a5760008081fd5b81818501898501375060009082018701528452509183019183016143f7565b50979650505050505050565b600060e082360312156144a757600080fd5b6144af613e45565b82358152602083013560208201526040830135604082015260608301356001600160401b03808211156144e157600080fd5b6144ed36838701613f73565b6060840152608085013591508082111561450657600080fd5b61451236838701614357565b608084015260a085013591508082111561452b57600080fd5b614537368387016143b2565b60a084015260c085013591508082111561455057600080fd5b5061455d36828601614357565b60c08301525092915050565b600060c0823603121561457b57600080fd5b614583613e6d565b823581526020830135602082015260408301356001600160401b03808211156145ab57600080fd5b6145b736838701613ee2565b604084015260608501359150808211156145d057600080fd5b6145dc36838701614357565b606084015260808501359150808211156145f557600080fd5b614601368387016143b2565b608084015260a085013591508082111561461a57600080fd5b5061462736828601614357565b60a08301525092915050565b60005b8381101561464e578181015183820152602001614636565b50506000910152565b6001600160e01b031983168152815160009061467a816004850160208701614633565b919091016004019392505050565b600081518084526146a0816020860160208601614633565b601f01601f19169290920160200192915050565b6020815260006107216020830184614688565b600082516146d9818460208701614633565b9190910192915050565b6000815180845260208085019450848260051b860182860160005b85811015613f4f578383038952614716838351614688565b988501989250908401906001016146fe565b60808152600061473b6080830187614688565b828103602084015261474d8187613ca7565b905082810360408401526147618186613c16565b9050828103606084015261061581856146e3565b6040815260006147886040830185613c16565b82810360208401526142d38185613ca7565b6001600160e01b03199290921682526001600160a01b0316602082015260400190565b6000602082840312156147cf57600080fd5b8151801515811461072157600080fd5b600081518084526020808501945080840160005b83811015613c48578151875295820195908201906001016147f3565b600060e08301825184526020808401518186015260408401516040860152606084015160e06060870152828151808552610100880191508383019450600092505b808310156148795784516001600160a01b03168252938301936001929092019190830190614850565b5060808601519350868103608088015261489381856147df565b935050505060a083015184820360a08601526148af82826146e3565b91505060c083015184820360c08601526142d382826147df565b6040815260006148dc604083018561480f565b905060018060a01b03831660208301529392505050565b60006020828403121561490557600080fd5b81356002811061072157600080fd5b60006020828403121561492657600080fd5b813560ff8116811461072157600080fd5b600060018201614949576149496141f4565b5060010190565b608081526000614963608083018761480f565b60208681850152838203604085015260c08201865183528187015182840152604087015160c0604085015281815180845260e0860191508483019350600092505b808310156149cd5783516149b7816140d8565b82529284019260019290920191908401906149a4565b506060890151935084810360608601526149e781856147df565b935050505060808601518282036080840152614a0382826146e3565b91505060a086015182820360a0840152614a1d82826147df565b93505050506142d360608301846001600160a01b03169052565b634e487b7160e01b600052603160045260246000fd5b604081526000614a606040830185613c16565b82810360208401526142d381856146e356fe5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240ac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ffc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e38400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3d38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644ca2646970667358221220e24c473cb9b7f8fce5e9e8b7bcf5aa6cef6921786fda11dfa2a2fe81c2fbf42764736f6c634300081100335da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240c55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101fb5760003560e01c80639b19dbfd1161011a578063cc7e6b3b116100ad578063de981f1b1161007c578063de981f1b1461050c578063e75235b814610537578063e9c034981461053f578063f80b535214610552578063fdc4fa471461055a57600080fd5b8063cc7e6b3b146104be578063d0a50db0146104de578063d78392f8146104e6578063dafae408146104f957600080fd5b8063b9c36209116100e9578063b9c3620914610464578063bc9182fd1461048c578063bc96180b1461049f578063c441c4a8146104a757600080fd5b80639b19dbfd146103db5780639b2ee437146103e3578063b384abef146103f6578063b405aaf21461045157600080fd5b80633644e515116101925780637de5dedd116101615780637de5dedd14610332578063800eaab31461033a578063865e6fd31461034d578063901979d51461036057600080fd5b80633644e515146102c05780635e05cf9e146102e7578063776fb1ec146102fc5780637d465f791461031f57600080fd5b80631f425338116101ce5780631f425338146102675780632d6d7d731461027a57806334d5f37b1461028d57806335da8121146102ad57600080fd5b806301a5f43f1461020057806306aba0e1146102295780630a44fa431461023f5780630f7c318914610252575b600080fd5b61021361020e366004613b7d565b61056d565b6040516102209190613c53565b60405180910390f35b610231610620565b604051908152602001610220565b61023161024d366004613c66565b61063d565b61025a6106c2565b6040516102209190613ce0565b610213610275366004613c66565b6106db565b61025a610288366004613c66565b610728565b61023161029b366004613cf3565b60006020819052908152604090205481565b6102136102bb366004613c66565b61076c565b6102317f000000000000000000000000000000000000000000000000000000000000000081565b6102fa6102f5366004613d50565b6107b2565b005b61030f61030a366004613cf3565b6107f1565b6040519015158152602001610220565b6102fa61032d366004613dec565b61083e565b610231610876565b6102fa610348366004613fe0565b6108f2565b6102fa61035b366004614052565b610937565b6103c361036e366004614085565b6001600160a01b039081166000908152600080516020614af383398151915260209081526040808320549093168252600080516020614ad383398151915290522054600160a01b90046001600160601b031690565b6040516001600160601b039091168152602001610220565b61025a610952565b6102fa6103f1366004614085565b61095c565b6104406104043660046140a0565b600160208181526000938452604080852090915291835291208054918101546002820154600383015460069093015460ff909416939192909185565b6040516102209594939291906140e8565b61030f61045f366004614085565b610af3565b6104776104723660046140a0565b610b0d565b60408051928352602083019190915201610220565b61025a61049a366004614116565b610b2e565b610231610c1f565b6104af610c2a565b60405161022093929190614183565b6104d16104cc366004613c66565b610c54565b60405161022091906141c6565b610231610c92565b6103c36104f4366004614085565b610cab565b61030f610507366004613cf3565b610cb6565b61051f61051a3660046141d9565b610cf3565b6040516001600160a01b039091168152602001610220565b610477610d6e565b61021361054d366004613c66565b610d9f565b61025a610de5565b61025a610568366004613c66565b610def565b60606105776110fd565b61061587878080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808b0282810182019093528a82529093508a92508991829185019084908082843760009201919091525050604080516020808a0282810182019093528982529093508992508891829185019084908082843760009201919091525061112d92505050565b979650505050505050565b6000610638600080516020614b338339815191525490565b905090565b600082828080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061067e92508391506114a99050565b6106ba8484808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506114e192505050565b949350505050565b6060610638600080516020614a738339815191526110f0565b60606106e56110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061156592505050565b9392505050565b606061072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201829052509250611630915050565b92915050565b60606107766110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061178a92505050565b6107bb3361187c565b6107ea85858585857f0000000000000000000000000000000000000000000000000000000000000000336118be565b5050505050565b60008060008381527fa6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49602052604090205460ff166004811115610836576108366140c2565b141592915050565b6108473361187c565b6107ea85858585857f000000000000000000000000000000000000000000000000000000000000000033611963565b600061088e600080516020614a938339815191525490565b60016108a6600080516020614a938339815191525490565b6108d46108bf600080516020614b338339815191525490565b600080516020614ab3833981519152906119bf565b6108de919061420a565b6108e8919061421d565b6106389190614230565b333014610929576000356001600160e01b0319166040516307337e1960e41b81526004016109209190614252565b60405180910390fd5b61093382826119ea565b5050565b61093f6110fd565b61094881611a98565b6109338282611ace565b6060610638611b72565b6109653361187c565b61096e81611b8b565b336000908152600080516020614ad383398151915260208190526040909120546001600160a01b0390811690831681036109c657604051630669b93360e31b81526001600160a01b0384166004820152602401610920565b600080516020614b1383398151915260006109e18284611bc0565b80156109f257506109f28286610eda565b905080610a1d5760405163080fab4b60e31b81526001600160a01b0386166004820152602401610920565b6001600160a01b038381166000818152600080516020614af38339815191526020818152604080842080546001600160a01b0319908116909155958b16808552818520805488163390811790915585528a8352938190208054909616841790955584519081019390935292820152610ab0906364b18d0960e11b906060015b604051602081830303815290604052611bd5565b6040516001600160a01b03808816919086169033907fcef34cd748f30a1b7a2f214fd1651779f79bc6c1be02785cad5c1f0ee877213d90600090a4505050505050565b6000610766600080516020614b1383398151915283611018565b600080610b186110fd565b610b228484611edd565b915091505b9250929050565b8051606090806001600160401b03811115610b4b57610b4b613e2f565b604051908082528060200260200182016040528015610b74578160200160208202803683370190505b509150600080516020614ad383398151915260005b82811015610c1757816000868381518110610ba657610ba6614267565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160009054906101000a90046001600160a01b0316848281518110610bf757610bf7614267565b6001600160a01b0390921660209283029190910190910152600101610b89565b505050919050565b600061063860025490565b6060806060610c37611fd2565b9250610c4283610b2e565b9150610c4d83611ffd565b9050909192565b6060610721838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611ffd92505050565b6000610638600080516020614b138339815191526120e6565b6000610766826120f0565b6000610cd16108bf600080516020614b338339815191525490565b600080516020614a9383398151915254610ceb908461427d565b101592915050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610d2a57610d2a6140c2565b60ff1681526020810191909152604001600020546001600160a01b0316905080610d69578160405163409140df60e11b81526004016109209190614294565b919050565b600080610d87600080516020614ab38339815191525490565b600080516020614a9383398151915254915091509091565b6060610da96110fd565b61072183838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061212892505050565b6060610638611fd2565b606081806001600160401b03811115610e0a57610e0a613e2f565b604051908082528060200260200182016040528015610e33578160200160208202803683370190505b509150600080516020614af383398151915260005b82811015610ecd57816000878784818110610e6557610e65614267565b9050602002016020810190610e7a9190614085565b6001600160a01b0390811682526020820192909252604001600020548551911690859083908110610ead57610ead614267565b6001600160a01b0390921660209283029190910190910152600101610e48565b50505092915050565b9055565b6000610721836001600160a01b03841661240d565b5490565b6000610efd825490565b9050610d6982610ed683600161420a565b81518151606091908082016001600160401b03811115610f3057610f30613e2f565b604051908082528060200260200182016040528015610f59578160200160208202803683370190505b50925060005b82811015610fb357858181518110610f7957610f79614267565b6020026020010151848281518110610f9357610f93614267565b6001600160a01b0390921660209283029190910190910152600101610f5f565b60005b8281101561100e57858181518110610fd057610fd0614267565b6020026020010151858381518110610fea57610fea614267565b6001600160a01b039092166020928302919091019091015260019182019101610fb6565b5050505092915050565b6001600160a01b03811660009081526001830160205260408120541515610721565b60006107668361104a858561245c565b9250829055565b6000815160000361106457506000919050565b60005b60018351038110156110e757600181015b83518110156110de5783818151811061109357611093614267565b60200260200101516001600160a01b03168483815181106110b6576110b6614267565b60200260200101516001600160a01b0316036110d6575060019392505050565b600101611078565b50600101611067565b50600092915050565b606060006107218361247b565b33301461112b576000356001600160e01b0319166040516307337e1960e41b81526004016109209190614252565b565b60606111398383610f0e565b611142816114a9565b82518551811480156111545750845181145b61117f576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b806001600160401b0381111561119757611197613e2f565b6040519080825280602002602001820160405280156111c0578160200160208202803683370190505b509250806000036111d157506114a1565b604080518082019091526000808252602082018190527f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c91600080516020614af383398151915291600080516020614b1383398151915291600080516020614ad3833981519152919081908190815b89811015611422578d818151811061125a5761125a614267565b602002602001015194508c818151811061127657611276614267565b6020026020010151935061128985611b8b565b61129284611b8b565b8e81815181106112a4576112a4614267565b60200260200101516001600160601b03166000036112e3576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b6112ed8986611018565b806112fd57506112fd8985611018565b8061130d575061130d8786611018565b8061131d575061131d8785611018565b158c828151811061133057611330614267565b6020026020010190151590811515815250508b818151811061135457611354614267565b60200260200101511561141a5761136b8986610eda565b506113768785610eda565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f90829081106113bc576113bc614267565b6020908102919091018101516001600160601b03169083018190526113e1908461420a565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b600101611240565b5061143b600080516020614b338339815191528361103a565b5061145a635ebae8a060e01b8d8d604051602001610a9c9291906142ae565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f60405161148f94939291906142dc565b60405180910390a15050505050505050505b509392505050565b6114b281611051565b156114de576000356001600160e01b031916604051630d697db160e11b81526004016109209190614252565b50565b6000816114ed816114a9565b600080516020614ad383398151915260005b8451811015610c175781600086838151811061151d5761151d614267565b6020908102919091018101516001600160a01b031682528101919091526040016000205461155b90600160a01b90046001600160601b03168561420a565b93506001016114ff565b606081611571816114a9565b8251806001600160401b0381111561158b5761158b613e2f565b6040519080825280602002602001820160405280156115b4578160200160208202803683370190505b509250600080516020614a7383398151915260005b82811015611627576115fd8682815181106115e6576115e6614267565b602002602001015183611bc090919063ffffffff16565b85828151811061160f5761160f614267565b911515602092830291909101909101526001016115c9565b50505050919050565b606082516001600160401b0381111561164b5761164b613e2f565b604051908082528060200260200182016040528015611674578160200160208202803683370190505b50905060005b8351811015611783576003600085838151811061169957611699614267565b602002602001015160048111156116b2576116b26140c2565b60048111156116c3576116c36140c2565b815260200190815260200160002060009054906101000a90046001600160a01b03168282815181106116f7576116f7614267565b60200260200101906001600160a01b031690816001600160a01b03168152505082801561174f575060006001600160a01b031682828151811061173c5761173c614267565b60200260200101516001600160a01b0316145b1561177b576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b60010161167a565b5092915050565b606081611796816114a9565b8251806001600160401b038111156117b0576117b0613e2f565b6040519080825280602002602001820160405280156117d9578160200160208202803683370190505b509250806000036117ea5750611876565b600080516020614a7383398151915260006314d72edb60e21b815b848110156118705787818151811061181f5761181f614267565b6020026020010151925061183283611a98565b61183c83836124d7565b6118468484610eda565b87828151811061185857611858614267565b91151560209283029190910190910152600101611805565b50505050505b50919050565b611885816120f0565b6001600160601b03166000036114de576000356001600160e01b0319166003604051620f948f60ea1b8152600401610920929190614329565b6118d06118ca88614495565b8261266a565b5060006118e46118df89614495565b612770565b90506119596118f289614495565b88888888611945896119058960006128af565b60405161190160f01b6020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6119548a6119058a60016128af565b6128e8565b5050505050505050565b600061197761197189614569565b83612cdf565b9050600061198c6119878a614569565b612e29565b90506119b482898989896119a58a6119058960006128af565b6119548b6119058a60016128af565b505050505050505050565b600082548015611783578281029150808204831461178357634e487b7160005260116020526024601cfd5b60005b8251811015611a9357306001600160a01b0316828281518110611a1257611a12614267565b60200260200101516001600160a01b031603611a4f576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b611a8b838281518110611a6457611a64614267565b6020026020010151838381518110611a7e57611a7e614267565b6020026020010151612f60565b6001016119ed565b505050565b806001600160a01b03163b6000036114de57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610920565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115611b0457611b046140c2565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115611b4557611b456140c2565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6060610638600080516020614b138339815191526110f0565b6001600160a01b0381166114de576000356001600160e01b03191660405163104c66df60e31b81526004016109209190614252565b6000610721836001600160a01b038416612ff3565b6000611bee600080516020614a738339815191526110f0565b80519091506000819003611c025750505050565b6000816001600160401b03811115611c1c57611c1c613e2f565b604051908082528060200260200182016040528015611c45578160200160208202803683370190505b5090506000826001600160401b03811115611c6257611c62613e2f565b604051908082528060200260200182016040528015611c9557816020015b6060815260200190600190039081611c805790505b50905060008686604051602001611cad929190614657565b6040516020818303038152906040529050600081604051602401611cd191906146b4565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b85811015611e9557868181518110611d1a57611d1a614267565b60200260200101516001600160a01b031683604051611d3991906146c7565b6000604051808303816000865af19150503d8060008114611d76576040519150601f19603f3d011682016040523d82523d6000602084013e611d7b565b606091505b50868381518110611d8e57611d8e614267565b60200260200101868481518110611da757611da7614267565b6020026020010182905282151515158152505050848181518110611dcd57611dcd614267565b6020026020010151611e8d57868181518110611deb57611deb614267565b60200260200101516001600160a01b031682604051611e0a91906146c7565b6000604051808303816000865af19150503d8060008114611e47576040519150601f19603f3d011682016040523d82523d6000602084013e611e4c565b606091505b50868381518110611e5f57611e5f614267565b60200260200101868481518110611e7857611e78614267565b60200260200101829052821515151581525050505b600101611d00565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b6382878686604051611ecb9493929190614728565b60405180910390a15050505050505050565b60008082841115611f0f576000356001600160e01b0319166040516387f6f09560e01b81526004016109209190614252565b600080516020614ab3833981519152549150611f37600080516020614a938339815191525490565b9050611f50600080516020614ab3833981519152859055565b611f67600080516020614a93833981519152849055565b8284611f927f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d610ef3565b60408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b60606106387f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c6110f0565b8051606090806001600160401b0381111561201a5761201a613e2f565b604051908082528060200260200182016040528015612043578160200160208202803683370190505b509150600080516020614ad383398151915260005b82811015610c175781600086838151811061207557612075614267565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160149054906101000a90046001600160601b03168482815181106120c6576120c6614267565b6001600160601b0390921660209283029190910190910152600101612058565b6000610766825490565b6001600160a01b03166000908152600080516020614ad38339815191526020526040902054600160a01b90046001600160601b031690565b606081612134816114a9565b8251806001600160401b0381111561214e5761214e613e2f565b604051908082528060200260200182016040528015612177578160200160208202803683370190505b509250806000036121885750611876565b60408051808201909152600080825260208201819052600080516020614af3833981519152917f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c91600080516020614b1383398151915291600080516020614ad3833981519152919081908190815b8981101561238d578c818151811061221157612211614267565b6020908102919091018101516001600160a01b038082166000908152928c90526040909220549091169550935061224785611b8b565b61225084611b8b565b6001600160a01b0385811660009081526020888152604091829020825180840190935254808416808452600160a01b9091046001600160601b031691830191909152909350908516146122c4576000356001600160e01b03191660405163053265f160e01b81526004016109209190614252565b6122ce8785611018565b80156122df57506122df8886611018565b8c82815181106122f1576122f1614267565b6020026020010190151590811515815250508b818151811061231557612315614267565b6020026020010151156123855761232c8886611bc0565b506123378785611bc0565b506001600160a01b03808516600090815260208b8152604080832080546001600160a01b0319169055928816825288815291812055820151612382906001600160601b03168461420a565b92505b6001016121f7565b506123a6600080516020614b33833981519152836130e6565b506123c563c48549de60e01b8d8d604051602001610a9c9291906142ae565b7fdf3dcd7987202f64648f3acdbf12401e3a2bb23e77e19f99826b5475cbb863698b8d6040516123f6929190614775565b60405180910390a150505050505050505050919050565b600081815260018301602052604081205461245457508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610766565b506000610766565b815481018181101561076657634e487b7160005260116020526024601cfd5b6060816000018054806020026020016040519081016040528092919081815260200182805480156124cb57602002820191906000526020600020905b8154815260200190600101908083116124b7575b50505050509050919050565b6000816040516024016124ea9190614252565b60408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b038616906125339085906146c7565b600060405180830381855afa9150503d806000811461256e576040519150601f19603f3d011682016040523d82523d6000602084013e612573565b606091505b50915091508161263557846001600160a01b03168360405160240161259891906146b4565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b179052516125cd91906146c7565b600060405180830381855afa9150503d8060008114612608576040519150601f19603f3d011682016040523d82523d6000602084013e61260d565b606091505b5090925090508161263557838560405163069d427960e11b815260040161092092919061479a565b8080602001905181019061264991906147bd565b6107ea57838560405163069d427960e11b815260040161092092919061479a565b60208201516000908082036126ac5760405163092048d160e11b8152600080356001600160e01b03191660048301526024820152466044820152606401610920565b6002546126ba9085906130f6565b60006126c585612770565b90506126d082613197565b6000838152600160208181526040808420858552909152918290209188015190820184905560069091015592508451831461272c576000356001600160e01b03191660405163d4cec26960e01b81526004016109209190614252565b8083837fa57d40f1496988cf60ab7c9d5ba4ff83647f67d3898d441a3aaf21b651678fd988886040516127609291906148c9565b60405180910390a4505092915050565b6080810151606082015160a083015151600092919083906001600160401b0381111561279e5761279e613e2f565b6040519080825280602002602001820160405280156127c7578160200160208202803683370190505b5060c086015190915060005b8251811015612826578660a0015181815181106127f2576127f2614267565b60200260200101518051906020012083828151811061281357612813614267565b60209081029190910101526001016127d3565b50604080517fd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a8152875160208083019190915280890151828401529790910151606082015283518702938701939093206080840152835186029386019390932060a0830152805185029085012060c082015281518402919093012060e083015250610100902090565b604080517fd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2815260208101939093528201526060902090565b84158015906128f657508483145b612921576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b60008080856001600160401b0381111561293d5761293d613e2f565b604051908082528060200260200182016040528015612966578160200160208202803683370190505b5090506000866001600160401b0381111561298357612983613e2f565b6040519080825280602002602001820160405280156129ac578160200160208202803683370190505b50905060008060003660005b8b811015612b3d578c8c828181106129d2576129d2614267565b90506060020191508e8e828181106129ec576129ec614267565b9050602002016020810190612a0191906148f3565b92506000836001811115612a1757612a176140c2565b03612a8157612a3c8b612a2d6020850185614914565b84602001358560400135613233565b945084878a612a4a81614937565b9b5081518110612a5c57612a5c614267565b60200260200101906001600160a01b031690816001600160a01b031681525050612af2565b6001836001811115612a9557612a956140c2565b03612acb57612aab8a612a2d6020850185614914565b9450848689612ab981614937565b9a5081518110612a5c57612a5c614267565b6000356001600160e01b031916604051630612418f60e11b81526004016109209190614252565b846001600160a01b0316846001600160a01b031610612b32576000356001600160e01b031916604051635d3dcd3160e01b81526004016109209190614252565b8493506001016129b8565b50505085845250508281526020808c015160009081526001825260408082208e51835290925290812090612b6f61325b565b90506000612b7c85613265565b9050818110612c035780600003612bb4576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b825460ff1916600190811784558301546040517f5c819725ea53655a3b898f3df59b66489761935454e9212ca1e5ebd759953d0b90600090a2612bf7838f613270565b50505050505050612cd6565b600082612c0e6132dd565b612c18919061421d565b612c2390600161420a565b90506000612c3086613265565b9050818110612caf5780600003612c68576000356001600160e01b031916604051637f11b8a360e11b81526004016109209190614252565b845460ff1916600317855560018501546040517f55295d4ce992922fa2e5ffbf3a3dcdb367de0a15e125ace083456017fd22060f90600090a2505050505050505050612cd6565b6000356001600160e01b031916604051634ccfe64360e11b81526004016109209190614252565b50505050505050565b612d1f6040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b612d38612d3184604001516001611630565b84906132e7565b9050612d4f600254826130f690919063ffffffff16565b6000612d5a82612770565b90506000612d686000613197565b60008181527fa6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49602090815260409091209087015160018201859055600690910155905082518114612dda576000356001600160e01b03191660405163d4cec26960e01b81526004016109209190614252565b81817f771d78ae9e5fca95a532fb0971d575d0ce9b59d14823c063e08740137e0e0eca85612e0789612e29565b8989604051612e199493929190614950565b60405180910390a3505092915050565b60608101516040820151608083015151600092919083906001600160401b03811115612e5757612e57613e2f565b604051908082528060200260200182016040528015612e80578160200160208202803683370190505b5060a086015190915060005b8251811015612edf5786608001518181518110612eab57612eab614267565b602002602001015180519060200120838281518110612ecc57612ecc614267565b6020908102919091010152600101612e8c565b50604080517f1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee911413508152875160208083019190915297880151918101919091528351870293870193909320606084015283518602938601939093206080830152805185029085012060a082015281518402919093012060c08301525060e0902090565b8060036000846004811115612f7757612f776140c2565b6004811115612f8857612f886140c2565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b039283161790558116826004811115612fc657612fc66140c2565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b600081815260018301602052604081205480156130dc57600061301760018361421d565b855490915060009061302b9060019061421d565b905081811461309057600086600001828154811061304b5761304b614267565b906000526020600020015490508087600001848154811061306e5761306e614267565b6000918252602080832090910192909255918252600188019052604090208390555b85548690806130a1576130a1614a37565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610766565b6000915050610766565b60006107668361104a8585613411565b60008260600151511180156131145750816080015151826060015151145b801561312957508160a0015151826060015151145b801561313e57508160c0015151826060015151145b613169576000356001600160e01b0319166040516306b5667560e21b81526004016109209190614252565b613173814261420a565b826040015111156109335760405163ad89be9d60e01b815260040160405180910390fd5b600081815260208190526040812054908190036131c65750600090815260208190526040902060019081905590565b60008281526001602090815260408083208484529091528120906000825460ff1660048111156131f8576131f86140c2565b036132165760405163757a436360e01b815260040160405180910390fd5b505050600090815260208190526040902080546001019081905590565b6000806000613244878787876135ec565b91509150613251816136d9565b5095945050505050565b6000610638610876565b6000610766826114e1565b6132798161388f565b1561093357815460ff19166002178255600080613295836138a9565b9150915083600101547fe134987599ae266ec90edeff1b26125b287dbb57b10822649432d1bb26537fba83836040516132cf929190614a4d565b60405180910390a250505050565b6000610638610620565b6133276040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b82518152602080840151604080840191909152600091830191909152830151516001600160401b0381111561335e5761335e613e2f565b604051908082528060200260200182016040528015613387578160200160208202803683370190505b5060608083019190915283015160808083019190915283015160a08083019190915283015160c082015260005b836040015151811015611783578281815181106133d3576133d3614267565b6020026020010151826060015182815181106133f1576133f1614267565b6001600160a01b03909216602092830291909101909101526001016133b4565b600082548281101561343057634e487b7160005260116020526024601cfd5b9190910392915050565b60048301548110156134ed5782600801600084600401838154811061346157613461614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916905560048401805460078601929190849081106134aa576134aa614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916815560018181018390556002909101919091550161343a565b5060005b60058301548110156135a45782600801600084600501838154811061351857613518614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19169055600584018054600786019291908490811061356157613561614267565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff191681556001818101839055600290910191909155016134f1565b50815460ff1916825560006001830181905560028301819055600383018190556135d2906004840190613b07565b6135e0600583016000613b07565b60006006830155919050565b6000807f7fffffffffffffffffffffffffffffff5d576e7357a4501ddfe92f46681b20a083111561362357506000905060036136d0565b8460ff16601b1415801561363b57508460ff16601c14155b1561364c57506000905060046136d0565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa1580156136a0573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166136c9576000600192509250506136d0565b9150600090505b94509492505050565b60008160048111156136ed576136ed6140c2565b036136f55750565b6001816004811115613709576137096140c2565b036137565760405162461bcd60e51b815260206004820152601860248201527f45434453413a20696e76616c6964207369676e617475726500000000000000006044820152606401610920565b600281600481111561376a5761376a6140c2565b036137b75760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610920565b60038160048111156137cb576137cb6140c2565b036138235760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610920565b6004816004811115613837576138376140c2565b036114de5760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610920565b600081602001516000148061076657505060200151461490565b6060806138b58361388f565b6138f357602083015160405163092048d160e11b81526000356001600160e01b03191660048201526024810191909152466044820152606401610920565b8260600151516001600160401b0381111561391057613910613e2f565b604051908082528060200260200182016040528015613939578160200160208202803683370190505b5091508260600151516001600160401b0381111561395957613959613e2f565b60405190808252806020026020018201604052801561398c57816020015b60608152602001906001900390816139775790505b50905060005b836060015151811015613b01578360c0015181815181106139b5576139b5614267565b60200260200101515a116139e8576139cc84612770565b6040516307aec4ab60e21b815260040161092091815260200190565b836060015181815181106139fe576139fe614267565b60200260200101516001600160a01b031684608001518281518110613a2557613a25614267565b60200260200101518560c001518381518110613a4357613a43614267565b6020026020010151908660a001518481518110613a6257613a62614267565b6020026020010151604051613a7791906146c7565b600060405180830381858888f193505050503d8060008114613ab5576040519150601f19603f3d011682016040523d82523d6000602084013e613aba565b606091505b50848381518110613acd57613acd614267565b60200260200101848481518110613ae657613ae6614267565b60209081029190910101919091529015159052600101613992565b50915091565b50805460008255906000526020600020908101906114de91905b80821115613b355760008155600101613b21565b5090565b60008083601f840112613b4b57600080fd5b5081356001600160401b03811115613b6257600080fd5b6020830191508360208260051b8501011115610b2757600080fd5b60008060008060008060608789031215613b9657600080fd5b86356001600160401b0380821115613bad57600080fd5b613bb98a838b01613b39565b90985096506020890135915080821115613bd257600080fd5b613bde8a838b01613b39565b90965094506040890135915080821115613bf757600080fd5b50613c0489828a01613b39565b979a9699509497509295939492505050565b600081518084526020808501945080840160005b83811015613c48578151151587529582019590820190600101613c2a565b509495945050505050565b6020815260006107216020830184613c16565b60008060208385031215613c7957600080fd5b82356001600160401b03811115613c8f57600080fd5b613c9b85828601613b39565b90969095509350505050565b600081518084526020808501945080840160005b83811015613c485781516001600160a01b031687529582019590820190600101613cbb565b6020815260006107216020830184613ca7565b600060208284031215613d0557600080fd5b5035919050565b60008083601f840112613d1e57600080fd5b5081356001600160401b03811115613d3557600080fd5b602083019150836020606083028501011115610b2757600080fd5b600080600080600060608688031215613d6857600080fd5b85356001600160401b0380821115613d7f57600080fd5b9087019060e0828a031215613d9357600080fd5b90955060208701359080821115613da957600080fd5b613db589838a01613b39565b90965094506040880135915080821115613dce57600080fd5b50613ddb88828901613d0c565b969995985093965092949392505050565b600080600080600060608688031215613e0457600080fd5b85356001600160401b0380821115613e1b57600080fd5b9087019060c0828a031215613d9357600080fd5b634e487b7160e01b600052604160045260246000fd5b60405160e081016001600160401b0381118282101715613e6757613e67613e2f565b60405290565b60405160c081016001600160401b0381118282101715613e6757613e67613e2f565b604051601f8201601f191681016001600160401b0381118282101715613eb757613eb7613e2f565b604052919050565b60006001600160401b03821115613ed857613ed8613e2f565b5060051b60200190565b600082601f830112613ef357600080fd5b81356020613f08613f0383613ebf565b613e8f565b828152600592831b8501820192828201919087851115613f2757600080fd5b8387015b85811015613f4f578035828110613f425760008081fd5b8452928401928401613f2b565b5090979650505050505050565b80356001600160a01b0381168114610d6957600080fd5b600082601f830112613f8457600080fd5b81356020613f94613f0383613ebf565b82815260059290921b84018101918181019086841115613fb357600080fd5b8286015b84811015613fd557613fc881613f5c565b8352918301918301613fb7565b509695505050505050565b60008060408385031215613ff357600080fd5b82356001600160401b038082111561400a57600080fd5b61401686838701613ee2565b9350602085013591508082111561402c57600080fd5b5061403985828601613f73565b9150509250929050565b803560108110610d6957600080fd5b6000806040838503121561406557600080fd5b61406e83614043565b915061407c60208401613f5c565b90509250929050565b60006020828403121561409757600080fd5b61072182613f5c565b600080604083850312156140b357600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b600581106114de576114de6140c2565b60a081016140f5876140d8565b95815260208101949094526040840192909252606083015260809091015290565b60006020828403121561412857600080fd5b81356001600160401b0381111561413e57600080fd5b6106ba84828501613f73565b600081518084526020808501945080840160005b83811015613c485781516001600160601b03168752958201959082019060010161415e565b6060815260006141966060830186613ca7565b82810360208401526141a88186613ca7565b905082810360408401526141bc818561414a565b9695505050505050565b602081526000610721602083018461414a565b6000602082840312156141eb57600080fd5b61072182614043565b634e487b7160e01b600052601160045260246000fd5b80820180821115610766576107666141f4565b81810381811115610766576107666141f4565b60008261424d57634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b031991909116815260200190565b634e487b7160e01b600052603260045260246000fd5b8082028115828204841417610766576107666141f4565b60208101601083106142a8576142a86140c2565b91905290565b6040815260006142c16040830185613ca7565b82810360208401526142d38185613c16565b95945050505050565b6080815260006142ef6080830187613c16565b8281036020840152614301818761414a565b905082810360408401526143158186613ca7565b905082810360608401526106158185613ca7565b6001600160e01b03198316815260408101600b831061434a5761434a6140c2565b8260208301529392505050565b600082601f83011261436857600080fd5b81356020614378613f0383613ebf565b82815260059290921b8401810191818101908684111561439757600080fd5b8286015b84811015613fd5578035835291830191830161439b565b6000601f83818401126143c457600080fd5b823560206143d4613f0383613ebf565b82815260059290921b850181019181810190878411156143f357600080fd5b8287015b848110156144895780356001600160401b03808211156144175760008081fd5b818a0191508a603f83011261442c5760008081fd5b8582013560408282111561444257614442613e2f565b614453828b01601f19168901613e8f565b92508183528c8183860101111561446a5760008081fd5b81818501898501375060009082018701528452509183019183016143f7565b50979650505050505050565b600060e082360312156144a757600080fd5b6144af613e45565b82358152602083013560208201526040830135604082015260608301356001600160401b03808211156144e157600080fd5b6144ed36838701613f73565b6060840152608085013591508082111561450657600080fd5b61451236838701614357565b608084015260a085013591508082111561452b57600080fd5b614537368387016143b2565b60a084015260c085013591508082111561455057600080fd5b5061455d36828601614357565b60c08301525092915050565b600060c0823603121561457b57600080fd5b614583613e6d565b823581526020830135602082015260408301356001600160401b03808211156145ab57600080fd5b6145b736838701613ee2565b604084015260608501359150808211156145d057600080fd5b6145dc36838701614357565b606084015260808501359150808211156145f557600080fd5b614601368387016143b2565b608084015260a085013591508082111561461a57600080fd5b5061462736828601614357565b60a08301525092915050565b60005b8381101561464e578181015183820152602001614636565b50506000910152565b6001600160e01b031983168152815160009061467a816004850160208701614633565b919091016004019392505050565b600081518084526146a0816020860160208601614633565b601f01601f19169290920160200192915050565b6020815260006107216020830184614688565b600082516146d9818460208701614633565b9190910192915050565b6000815180845260208085019450848260051b860182860160005b85811015613f4f578383038952614716838351614688565b988501989250908401906001016146fe565b60808152600061473b6080830187614688565b828103602084015261474d8187613ca7565b905082810360408401526147618186613c16565b9050828103606084015261061581856146e3565b6040815260006147886040830185613c16565b82810360208401526142d38185613ca7565b6001600160e01b03199290921682526001600160a01b0316602082015260400190565b6000602082840312156147cf57600080fd5b8151801515811461072157600080fd5b600081518084526020808501945080840160005b83811015613c48578151875295820195908201906001016147f3565b600060e08301825184526020808401518186015260408401516040860152606084015160e06060870152828151808552610100880191508383019450600092505b808310156148795784516001600160a01b03168252938301936001929092019190830190614850565b5060808601519350868103608088015261489381856147df565b935050505060a083015184820360a08601526148af82826146e3565b91505060c083015184820360c08601526142d382826147df565b6040815260006148dc604083018561480f565b905060018060a01b03831660208301529392505050565b60006020828403121561490557600080fd5b81356002811061072157600080fd5b60006020828403121561492657600080fd5b813560ff8116811461072157600080fd5b600060018201614949576149496141f4565b5060010190565b608081526000614963608083018761480f565b60208681850152838203604085015260c08201865183528187015182840152604087015160c0604085015281815180845260e0860191508483019350600092505b808310156149cd5783516149b7816140d8565b82529284019260019290920191908401906149a4565b506060890151935084810360608601526149e781856147df565b935050505060808601518282036080840152614a0382826146e3565b91505060a086015182820360a0840152614a1d82826147df565b93505050506142d360608301846001600160a01b03169052565b634e487b7160e01b600052603160045260246000fd5b604081526000614a606040830185613c16565b82810360208401526142d381856146e356fe5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240ac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ffc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e38400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3d38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644ca2646970667358221220e24c473cb9b7f8fce5e9e8b7bcf5aa6cef6921786fda11dfa2a2fe81c2fbf42764736f6c63430008110033", + "devdoc": { + "errors": { + "ErrBridgeOperatorAlreadyExisted(address)": [ + { + "details": "Error thrown when attempting to add a bridge operator that already exists in the contract. This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract." + } + ], + "ErrBridgeOperatorUpdateFailed(address)": [ + { + "details": "Error raised when a bridge operator update operation fails.", + "params": { + "bridgeOperator": "The address of the bridge operator that failed to update." + } + } + ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrCurrentProposalIsNotCompleted()": [ + { + "details": "Error thrown when the current proposal is not completed." + } + ], + "ErrDuplicated(bytes4)": [ + { + "details": "Error thrown when a duplicated element is detected in an array.", + "params": { + "msgSig": "The function signature that invoke the error." + } + } + ], + "ErrInsufficientGas(bytes32)": [ + { + "details": "Error thrown when there is insufficient gas to execute a function." + } + ], + "ErrInvalidArguments(bytes4)": [ + { + "details": "Error indicating that arguments are invalid." + } + ], + "ErrInvalidChainId(bytes4,uint256,uint256)": [ + { + "details": "Error indicating that the chain ID is invalid.", + "params": { + "actual": "Current chain ID that executing function.", + "expected": "Expected chain ID required for the tx to success.", + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid chain ID." + } + } + ], + "ErrInvalidExpiryTimestamp()": [ + { + "details": "Error thrown when an invalid expiry timestamp is provided." + } + ], + "ErrInvalidOrder(bytes4)": [ + { + "details": "Error indicating that an order is invalid.", + "params": { + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid order." + } + } + ], + "ErrInvalidProposalNonce(bytes4)": [ + { + "details": "Error indicating that the proposal nonce is invalid.", + "params": { + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid proposal nonce." + } + } + ], + "ErrInvalidThreshold(bytes4)": [ + { + "details": "Error indicating that the provided threshold is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that the invalid threshold applies to." + } + } + ], + "ErrInvalidVoteWeight(bytes4)": [ + { + "details": "Error indicating that a vote weight is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that encountered an invalid vote weight." + } + } + ], + "ErrLengthMismatch(bytes4)": [ + { + "details": "Error indicating a mismatch in the length of input parameters or arrays for a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that has a length mismatch." + } + } + ], + "ErrOnlySelfCall(bytes4)": [ + { + "details": "Error indicating that a function can only be called by the contract itself.", + "params": { + "msgSig": "The function signature (bytes4) that can only be called by the contract itself." + } + } + ], + "ErrRelayFailed(bytes4)": [ + { + "details": "Error indicating that a relay call has failed.", + "params": { + "msgSig": "The function signature (bytes4) of the relay call that failed." + } + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnsupportedInterface(bytes4,address)": [ + { + "details": "The error indicating an unsupported interface.", + "params": { + "addr": "The address where the unsupported interface was encountered.", + "interfaceId": "The bytes4 interface identifier that is not supported." + } + } + ], + "ErrUnsupportedVoteType(bytes4)": [ + { + "details": "Error indicating that a vote type is not supported.", + "params": { + "msgSig": "The function signature (bytes4) of the operation that encountered an unsupported vote type." + } + } + ], + "ErrVoteIsFinalized()": [ + { + "details": "Error thrown when attempting to interact with a finalized vote." + } + ], + "ErrZeroAddress(bytes4)": [ + { + "details": "Error indicating that given address is null when it should not." + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "addBridgeOperators(uint96[],address[],address[])": { + "details": "Adds multiple bridge operators.", + "params": { + "bridgeOperators": "An array of addresses representing the bridge operators to add.", + "governors": "An array of addresses of hot/cold wallets for bridge operator to update their node address." + }, + "returns": { + "addeds": "An array of booleans indicating whether each bridge operator was added successfully. Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators( voteWeights, governors, bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]); const filteredWeights = weights.filter((_, index) => addeds[index]); const filteredGovernors = governors.filter((_, index) => addeds[index]); // ... (Process or use the information as required) ... ```" + } + }, + "checkThreshold(uint256)": { + "details": "Checks whether the `_voteWeight` passes the threshold." + }, + "getBridgeOperatorOf(address[])": { + "details": "Returns an array of bridge operators correspoding to governor addresses.", + "returns": { + "bridgeOperators": "An array containing the addresses of all bridge operators." + } + }, + "getBridgeOperatorWeight(address)": { + "details": "External function to retrieve the vote weight of a specific bridge operator.", + "params": { + "bridgeOperator": "The address of the bridge operator to get the vote weight for." + }, + "returns": { + "weight": "The vote weight of the specified bridge operator." + } + }, + "getBridgeOperators()": { + "details": "Returns an array of all bridge operators.", + "returns": { + "_0": "An array containing the addresses of all bridge operators." + } + }, + "getCallbackRegisters()": { + "details": "Retrieves the addresses of registered callbacks.", + "returns": { + "registers": "An array containing the addresses of registered callbacks." + } + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getFullBridgeOperatorInfos()": { + "details": "Retrieves the full information of all registered bridge operators. This external function allows external callers to obtain the full information of all the registered bridge operators. The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.", + "returns": { + "bridgeOperators": "An array of addresses representing the registered bridge operators.", + "governors": "An array of addresses representing the governors of each bridge operator.", + "weights": "An array of uint256 values representing the vote weights of each bridge operator. Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator. Example Usage: ``` (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos(); for (uint256 i = 0; i < bridgeOperators.length; i++) { // Access individual information for each bridge operator. address governor = governors[i]; address bridgeOperator = bridgeOperators[i]; uint256 weight = weights[i]; // ... (Process or use the information as required) ... } ```" + } + }, + "getGovernorWeight(address)": { + "details": "External function to retrieve the vote weight of a specific governor.", + "params": { + "governor": "The address of the governor to get the vote weight for." + }, + "returns": { + "weight": "voteWeight The vote weight of the specified governor." + } + }, + "getGovernorWeights(address[])": { + "details": "Returns the weights of a list of governor addresses." + }, + "getGovernors()": { + "details": "Returns an array of all governors.", + "returns": { + "_0": "An array containing the addresses of all governors." + } + }, + "getGovernorsOf(address[])": { + "details": "Retrieves the governors corresponding to a given array of bridge operators. This external function allows external callers to obtain the governors associated with a given array of bridge operators. The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.", + "params": { + "bridgeOperators": "An array of bridge operator addresses for which governors are to be retrieved." + }, + "returns": { + "governors": "An array of addresses representing the governors corresponding to the provided bridge operators." + } + }, + "getProposalExpiryDuration()": { + "details": "Returns the expiry duration for a new proposal." + }, + "getThreshold()": { + "details": "Returns the threshold." + }, + "getTotalWeight()": { + "details": "Returns total weights." + }, + "globalProposalRelayed(uint256)": { + "details": "Returns whether the voter `_voter` casted vote for the proposal." + }, + "isBridgeOperator(address)": { + "details": "Checks if the given address is a bridge operator.", + "params": { + "addr": "The address to check." + }, + "returns": { + "_0": "A boolean indicating whether the address is a bridge operator." + } + }, + "minimumVoteWeight()": { + "details": "Returns the minimum vote weight to pass the threshold." + }, + "registerCallbacks(address[])": { + "details": "Registers multiple callbacks with the bridge.", + "params": { + "registers": "The array of callback addresses to register." + }, + "returns": { + "registereds": "An array indicating the success status of each registration." + } + }, + "relayGlobalProposal((uint256,uint256,uint8[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])": { + "details": "See `GovernanceRelay-_relayGlobalProposal`. Requirements: - The method caller is governor." + }, + "relayProposal((uint256,uint256,uint256,address[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])": { + "details": "See `GovernanceRelay-_relayProposal`. Requirements: - The method caller is governor." + }, + "removeBridgeOperators(address[])": { + "details": "Removes multiple bridge operators.", + "params": { + "bridgeOperators": "An array of addresses representing the bridge operators to remove." + }, + "returns": { + "removeds": "An array of booleans indicating whether each bridge operator was removed successfully. * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators( bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]); // ... (Process or use the information as required) ... ```" + } + }, + "resolveTargets(uint8[])": { + "details": "Returns corresponding address of target options. Return address(0) on non-existent target." + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, + "setThreshold(uint256,uint256)": { + "details": "Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event." + }, + "sumGovernorsWeight(address[])": { + "details": "Returns total weights of the governor list." + }, + "totalBridgeOperator()": { + "details": "Returns the total number of bridge operators.", + "returns": { + "_0": "The total number of bridge operators." + } + }, + "unregisterCallbacks(address[])": { + "details": "Unregisters multiple callbacks from the bridge.", + "params": { + "registers": "The array of callback addresses to unregister." + }, + "returns": { + "unregistereds": "An array indicating the success status of each unregistration." + } + }, + "updateBridgeOperator(address)": { + "details": "Governor updates their corresponding governor and/or operator address. Requirements: - The caller must the governor of the operator that is requested changes.", + "params": { + "bridgeOperator": "The address of the bridge operator to update." + } + }, + "updateManyTargetOption(uint8[],address[])": { + "details": "Updates list of `targetOptions` to `targets`. Requirement: - Only allow self-call through proposal. " + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "round(uint256)": { + "notice": "chain id = 0 for global proposal" + }, + "updateBridgeOperator(address)": { + "notice": "This method checks authorization by querying the corresponding operator of the msg.sender and then attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave their operator address blank null `address(0)`, consider add authorization check." + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 8181, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "round", + "offset": 0, + "slot": "0", + "type": "t_mapping(t_uint256,t_uint256)" + }, + { + "astId": 8189, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "vote", + "offset": 0, + "slot": "1", + "type": "t_mapping(t_uint256,t_mapping(t_uint256,t_struct(ProposalVote)8119_storage))" + }, + { + "astId": 8191, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "_proposalExpiryDuration", + "offset": 0, + "slot": "2", + "type": "t_uint256" + }, + { + "astId": 8928, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "_targetOptionsMap", + "offset": 0, + "slot": "3", + "type": "t_mapping(t_enum(TargetOption)15426,t_address)" + } + ], + "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, + "t_array(t_address)dyn_storage": { + "base": "t_address", + "encoding": "dynamic_array", + "label": "address[]", + "numberOfBytes": "32" + }, + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_bytes32": { + "encoding": "inplace", + "label": "bytes32", + "numberOfBytes": "32" + }, + "t_enum(TargetOption)15426": { + "encoding": "inplace", + "label": "enum GlobalProposal.TargetOption", + "numberOfBytes": "1" + }, + "t_enum(VoteStatus)13030": { + "encoding": "inplace", + "label": "enum VoteStatusConsumer.VoteStatus", + "numberOfBytes": "1" + }, + "t_mapping(t_address,t_bool)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => bool)", + "numberOfBytes": "32", + "value": "t_bool" + }, + "t_mapping(t_address,t_struct(Signature)13021_storage)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => struct SignatureConsumer.Signature)", + "numberOfBytes": "32", + "value": "t_struct(Signature)13021_storage" + }, + "t_mapping(t_enum(TargetOption)15426,t_address)": { + "encoding": "mapping", + "key": "t_enum(TargetOption)15426", + "label": "mapping(enum GlobalProposal.TargetOption => address)", + "numberOfBytes": "32", + "value": "t_address" + }, + "t_mapping(t_uint256,t_mapping(t_uint256,t_struct(ProposalVote)8119_storage))": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => mapping(uint256 => struct CoreGovernance.ProposalVote))", + "numberOfBytes": "32", + "value": "t_mapping(t_uint256,t_struct(ProposalVote)8119_storage)" + }, + "t_mapping(t_uint256,t_struct(ProposalVote)8119_storage)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => struct CoreGovernance.ProposalVote)", + "numberOfBytes": "32", + "value": "t_struct(ProposalVote)8119_storage" + }, + "t_mapping(t_uint256,t_uint256)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_struct(ProposalVote)8119_storage": { + "encoding": "inplace", + "label": "struct CoreGovernance.ProposalVote", + "members": [ + { + "astId": 8095, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "status", + "offset": 0, + "slot": "0", + "type": "t_enum(VoteStatus)13030" + }, + { + "astId": 8097, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "hash", + "offset": 0, + "slot": "1", + "type": "t_bytes32" + }, + { + "astId": 8099, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "againstVoteWeight", + "offset": 0, + "slot": "2", + "type": "t_uint256" + }, + { + "astId": 8101, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "forVoteWeight", + "offset": 0, + "slot": "3", + "type": "t_uint256" + }, + { + "astId": 8104, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "forVoteds", + "offset": 0, + "slot": "4", + "type": "t_array(t_address)dyn_storage" + }, + { + "astId": 8107, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "againstVoteds", + "offset": 0, + "slot": "5", + "type": "t_array(t_address)dyn_storage" + }, + { + "astId": 8109, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "expiryTimestamp", + "offset": 0, + "slot": "6", + "type": "t_uint256" + }, + { + "astId": 8114, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "sig", + "offset": 0, + "slot": "7", + "type": "t_mapping(t_address,t_struct(Signature)13021_storage)" + }, + { + "astId": 8118, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "voted", + "offset": 0, + "slot": "8", + "type": "t_mapping(t_address,t_bool)" + } + ], + "numberOfBytes": "288" + }, + "t_struct(Signature)13021_storage": { + "encoding": "inplace", + "label": "struct SignatureConsumer.Signature", + "members": [ + { + "astId": 13016, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "v", + "offset": 0, + "slot": "0", + "type": "t_uint8" + }, + { + "astId": 13018, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "r", + "offset": 0, + "slot": "1", + "type": "t_bytes32" + }, + { + "astId": 13020, + "contract": "contracts/mainchain/MainchainBridgeManager.sol:MainchainBridgeManager", + "label": "s", + "offset": 0, + "slot": "2", + "type": "t_bytes32" + } + ], + "numberOfBytes": "96" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ethereum/MainchainGatewayV3Logic.json b/deployments/ethereum/MainchainGatewayV3Logic.json new file mode 100644 index 000000000..24f09fe24 --- /dev/null +++ b/deployments/ethereum/MainchainGatewayV3Logic.json @@ -0,0 +1,2910 @@ +{ + "address": "0x72E28A9009Ad12dE019BFF418CD210D4bbc3D403", + "abi": [ + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrERC20MintingFailed", + "type": "error" + }, + { + "inputs": [], + "name": "ErrERC721MintingFailed", + "type": "error" + }, + { + "inputs": [], + "name": "ErrEmptyArray", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "actual", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expected", + "type": "uint256" + } + ], + "name": "ErrInvalidChainId", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidInfo", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidOrder", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidPercentage", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidReceipt", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidReceiptKind", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidRequest", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidTokenStandard", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForApprovedWithdrawal", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForInsufficientVoteWeight", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForProcessedWithdrawal", + "type": "error" + }, + { + "inputs": [], + "name": "ErrReachedDailyWithdrawalLimit", + "type": "error" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "tokenInfo", + "type": "tuple" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "address", + "name": "token", + "type": "address" + } + ], + "name": "ErrTokenCouldNotTransfer", + "type": "error" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "tokenInfo", + "type": "tuple" + }, + { + "internalType": "address", + "name": "from", + "type": "address" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "address", + "name": "token", + "type": "address" + } + ], + "name": "ErrTokenCouldNotTransferFrom", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [], + "name": "ErrUnsupportedStandard", + "type": "error" + }, + { + "inputs": [], + "name": "ErrUnsupportedToken", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "tokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "limits", + "type": "uint256[]" + } + ], + "name": "DailyWithdrawalLimitsUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "DepositRequested", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "tokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "thresholds", + "type": "uint256[]" + } + ], + "name": "HighTierThresholdsUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "HighTierVoteWeightThresholdUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "tokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "thresholds", + "type": "uint256[]" + } + ], + "name": "LockedThresholdsUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "Paused", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "previousAdminRole", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "newAdminRole", + "type": "bytes32" + } + ], + "name": "RoleAdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "account", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + } + ], + "name": "RoleGranted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "account", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + } + ], + "name": "RoleRevoked", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "ThresholdUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "mainchainTokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "roninTokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "enum Token.Standard[]", + "name": "standards", + "type": "uint8[]" + } + ], + "name": "TokenMapped", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "tokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "percentages", + "type": "uint256[]" + } + ], + "name": "UnlockFeePercentagesUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "Unpaused", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "WithdrawalLocked", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "WithdrawalUnlocked", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "Withdrew", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "contract IWETH", + "name": "weth", + "type": "address" + } + ], + "name": "WrappedNativeTokenContractUpdated", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "DEFAULT_ADMIN_ROLE", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "DOMAIN_SEPARATOR", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "WITHDRAWAL_UNLOCKER_ROLE", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "_MAX_PERCENTAGE", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_voteWeight", + "type": "uint256" + } + ], + "name": "checkHighTierVoteWeightThreshold", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_voteWeight", + "type": "uint256" + } + ], + "name": "checkThreshold", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "dailyWithdrawalLimit", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "depositCount", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "emergencyPauser", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getHighTierVoteWeightThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + } + ], + "name": "getRoleAdmin", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "index", + "type": "uint256" + } + ], + "name": "getRoleMember", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + } + ], + "name": "getRoleMemberCount", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_mainchainToken", + "type": "address" + } + ], + "name": "getRoninToken", + "outputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + } + ], + "internalType": "struct MappedTokenConsumer.MappedToken", + "name": "_token", + "type": "tuple" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "num_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "grantRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "hasRole", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "highTierThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_roleSetter", + "type": "address" + }, + { + "internalType": "contract IWETH", + "name": "_wrappedToken", + "type": "address" + }, + { + "internalType": "uint256", + "name": "_roninChainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_highTierVWNumerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_denominator", + "type": "uint256" + }, + { + "internalType": "address[][3]", + "name": "_addresses", + "type": "address[][3]" + }, + { + "internalType": "uint256[][4]", + "name": "_thresholds", + "type": "uint256[][4]" + }, + { + "internalType": "enum Token.Standard[]", + "name": "_standards", + "type": "uint8[]" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeManagerContract", + "type": "address" + } + ], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "lastDateSynced", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "lastSyncedWithdrawal", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "lockedThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_mainchainTokens", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "_roninTokens", + "type": "address[]" + }, + { + "internalType": "enum Token.Standard[]", + "name": "_standards", + "type": "uint8[]" + } + ], + "name": "mapTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_mainchainTokens", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "_roninTokens", + "type": "address[]" + }, + { + "internalType": "enum Token.Standard[]", + "name": "_standards", + "type": "uint8[]" + }, + { + "internalType": "uint256[][4]", + "name": "_thresholds", + "type": "uint256[][4]" + } + ], + "name": "mapTokensAndThresholds", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "minimumVoteWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "nonce", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "pause", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "paused", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_token", + "type": "address" + }, + { + "internalType": "uint256", + "name": "_quantity", + "type": "uint256" + } + ], + "name": "reachedWithdrawalLimit", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "receiveEther", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "renounceRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "address", + "name": "recipientAddr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Request", + "name": "_request", + "type": "tuple" + } + ], + "name": "requestDepositFor", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "revokeRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "roninChainId", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_tokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_limits", + "type": "uint256[]" + } + ], + "name": "setDailyWithdrawalLimits", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_addr", + "type": "address" + } + ], + "name": "setEmergencyPauser", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_tokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_thresholds", + "type": "uint256[]" + } + ], + "name": "setHighTierThresholds", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_denominator", + "type": "uint256" + } + ], + "name": "setHighTierVoteWeightThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "_previousNum", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_previousDenom", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_tokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_thresholds", + "type": "uint256[]" + } + ], + "name": "setLockedThresholds", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_denominator", + "type": "uint256" + } + ], + "name": "setThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "_previousNum", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_previousDenom", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_tokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_percentages", + "type": "uint256[]" + } + ], + "name": "setUnlockFeePercentages", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "contract IWETH", + "name": "_wrappedToken", + "type": "address" + } + ], + "name": "setWrappedNativeTokenContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Receipt", + "name": "_receipt", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "_signatures", + "type": "tuple[]" + } + ], + "name": "submitWithdrawal", + "outputs": [ + { + "internalType": "bool", + "name": "_locked", + "type": "bool" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "interfaceId", + "type": "bytes4" + } + ], + "name": "supportsInterface", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "unlockFeePercentages", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Receipt", + "name": "_receipt", + "type": "tuple" + } + ], + "name": "unlockWithdrawal", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "unpause", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "withdrawalHash", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "withdrawalLocked", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "wrappedNativeToken", + "outputs": [ + { + "internalType": "contract IWETH", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0x5280f78ad6f9662655f644e84e5a35c39c969786127fd62dd1dccf6c545b3c84", + "receipt": { + "to": null, + "from": "0xba0000a467FA5d2BCbB78209728dbD2753b41f25", + "contractAddress": "0x72E28A9009Ad12dE019BFF418CD210D4bbc3D403", + "transactionIndex": 98, + "gasUsed": "3993491", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0xc25401cfdea24b1ac9bec0830c2ceca037edab77300ed815a5b8ce31387d65c7", + "transactionHash": "0x5280f78ad6f9662655f644e84e5a35c39c969786127fd62dd1dccf6c545b3c84", + "logs": [], + "blockNumber": 18376297, + "cumulativeGasUsed": "15059425", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 1, + "solcInputHash": "f9f5036294d35a88da21dae55fc8b26c", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrERC20MintingFailed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrERC721MintingFailed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrEmptyArray\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"actual\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expected\",\"type\":\"uint256\"}],\"name\":\"ErrInvalidChainId\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidInfo\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidOrder\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidPercentage\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidReceipt\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidReceiptKind\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidRequest\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidTokenStandard\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForApprovedWithdrawal\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForInsufficientVoteWeight\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForProcessedWithdrawal\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrReachedDailyWithdrawalLimit\",\"type\":\"error\"},{\"inputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"tokenInfo\",\"type\":\"tuple\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"token\",\"type\":\"address\"}],\"name\":\"ErrTokenCouldNotTransfer\",\"type\":\"error\"},{\"inputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"tokenInfo\",\"type\":\"tuple\"},{\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"token\",\"type\":\"address\"}],\"name\":\"ErrTokenCouldNotTransferFrom\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnsupportedStandard\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnsupportedToken\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"tokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"limits\",\"type\":\"uint256[]\"}],\"name\":\"DailyWithdrawalLimitsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"DepositRequested\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"tokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"thresholds\",\"type\":\"uint256[]\"}],\"name\":\"HighTierThresholdsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"HighTierVoteWeightThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"tokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"thresholds\",\"type\":\"uint256[]\"}],\"name\":\"LockedThresholdsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"Paused\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"previousAdminRole\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"newAdminRole\",\"type\":\"bytes32\"}],\"name\":\"RoleAdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"}],\"name\":\"RoleGranted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"}],\"name\":\"RoleRevoked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"mainchainTokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"roninTokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"enum Token.Standard[]\",\"name\":\"standards\",\"type\":\"uint8[]\"}],\"name\":\"TokenMapped\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"tokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"percentages\",\"type\":\"uint256[]\"}],\"name\":\"UnlockFeePercentagesUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"Unpaused\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"WithdrawalLocked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"WithdrawalUnlocked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"Withdrew\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"contract IWETH\",\"name\":\"weth\",\"type\":\"address\"}],\"name\":\"WrappedNativeTokenContractUpdated\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADMIN_ROLE\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"DOMAIN_SEPARATOR\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"WITHDRAWAL_UNLOCKER_ROLE\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"_MAX_PERCENTAGE\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkHighTierVoteWeightThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"dailyWithdrawalLimit\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"depositCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyPauser\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getHighTierVoteWeightThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"}],\"name\":\"getRoleAdmin\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"index\",\"type\":\"uint256\"}],\"name\":\"getRoleMember\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"}],\"name\":\"getRoleMemberCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_mainchainToken\",\"type\":\"address\"}],\"name\":\"getRoninToken\",\"outputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"}],\"internalType\":\"struct MappedTokenConsumer.MappedToken\",\"name\":\"_token\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"grantRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"hasRole\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"highTierThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_roleSetter\",\"type\":\"address\"},{\"internalType\":\"contract IWETH\",\"name\":\"_wrappedToken\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_roninChainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_highTierVWNumerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"},{\"internalType\":\"address[][3]\",\"name\":\"_addresses\",\"type\":\"address[][3]\"},{\"internalType\":\"uint256[][4]\",\"name\":\"_thresholds\",\"type\":\"uint256[][4]\"},{\"internalType\":\"enum Token.Standard[]\",\"name\":\"_standards\",\"type\":\"uint8[]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeManagerContract\",\"type\":\"address\"}],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"lastDateSynced\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"lastSyncedWithdrawal\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"lockedThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_mainchainTokens\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_roninTokens\",\"type\":\"address[]\"},{\"internalType\":\"enum Token.Standard[]\",\"name\":\"_standards\",\"type\":\"uint8[]\"}],\"name\":\"mapTokens\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_mainchainTokens\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_roninTokens\",\"type\":\"address[]\"},{\"internalType\":\"enum Token.Standard[]\",\"name\":\"_standards\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[][4]\",\"name\":\"_thresholds\",\"type\":\"uint256[][4]\"}],\"name\":\"mapTokensAndThresholds\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"nonce\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"pause\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"paused\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_token\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_quantity\",\"type\":\"uint256\"}],\"name\":\"reachedWithdrawalLimit\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"receiveEther\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"renounceRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Request\",\"name\":\"_request\",\"type\":\"tuple\"}],\"name\":\"requestDepositFor\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"revokeRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"roninChainId\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_tokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_limits\",\"type\":\"uint256[]\"}],\"name\":\"setDailyWithdrawalLimits\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setEmergencyPauser\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_tokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_thresholds\",\"type\":\"uint256[]\"}],\"name\":\"setHighTierThresholds\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"}],\"name\":\"setHighTierVoteWeightThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_previousNum\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_previousDenom\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_tokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_thresholds\",\"type\":\"uint256[]\"}],\"name\":\"setLockedThresholds\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_previousNum\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_previousDenom\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_tokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_percentages\",\"type\":\"uint256[]\"}],\"name\":\"setUnlockFeePercentages\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"contract IWETH\",\"name\":\"_wrappedToken\",\"type\":\"address\"}],\"name\":\"setWrappedNativeTokenContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Receipt\",\"name\":\"_receipt\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"_signatures\",\"type\":\"tuple[]\"}],\"name\":\"submitWithdrawal\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_locked\",\"type\":\"bool\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"}],\"name\":\"supportsInterface\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"unlockFeePercentages\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Receipt\",\"name\":\"_receipt\",\"type\":\"tuple\"}],\"name\":\"unlockWithdrawal\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"unpause\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"withdrawalHash\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"withdrawalLocked\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"wrappedNativeToken\",\"outputs\":[{\"internalType\":\"contract IWETH\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrERC20MintingFailed()\":[{\"details\":\"Error indicating that the minting of ERC20 tokens has failed.\"}],\"ErrERC721MintingFailed()\":[{\"details\":\"Error indicating that the minting of ERC721 tokens has failed.\"}],\"ErrEmptyArray()\":[{\"details\":\"Error indicating that an array is empty when it should contain elements.\"}],\"ErrInvalidChainId(bytes4,uint256,uint256)\":[{\"details\":\"Error indicating that the chain ID is invalid.\",\"params\":{\"actual\":\"Current chain ID that executing function.\",\"expected\":\"Expected chain ID required for the tx to success.\",\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid chain ID.\"}}],\"ErrInvalidInfo()\":[{\"details\":\"Error indicating that the provided information is invalid.\"}],\"ErrInvalidOrder(bytes4)\":[{\"details\":\"Error indicating that an order is invalid.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid order.\"}}],\"ErrInvalidPercentage()\":[{\"details\":\"Error of invalid percentage.\"}],\"ErrInvalidReceipt()\":[{\"details\":\"Error indicating that a receipt is invalid.\"}],\"ErrInvalidReceiptKind()\":[{\"details\":\"Error indicating that a receipt kind is invalid.\"}],\"ErrInvalidRequest()\":[{\"details\":\"Error indicating that a request is invalid.\"}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrInvalidTokenStandard()\":[{\"details\":\"Error indicating that a token standard is invalid.\"}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrQueryForApprovedWithdrawal()\":[{\"details\":\"Error indicating that a query was made for an approved withdrawal.\"}],\"ErrQueryForInsufficientVoteWeight()\":[{\"details\":\"Error indicating that a query was made for insufficient vote weight.\"}],\"ErrQueryForProcessedWithdrawal()\":[{\"details\":\"Error indicating that a query was made for a processed withdrawal.\"}],\"ErrReachedDailyWithdrawalLimit()\":[{\"details\":\"Error indicating that the daily withdrawal limit has been reached.\"}],\"ErrTokenCouldNotTransfer((uint8,uint256,uint256),address,address)\":[{\"details\":\"Error indicating that the `transfer` has failed.\",\"params\":{\"to\":\"Receiver of the token value.\",\"token\":\"Address of the token.\",\"tokenInfo\":\"Info of the token including ERC standard, id or quantity.\"}}],\"ErrTokenCouldNotTransferFrom((uint8,uint256,uint256),address,address,address)\":[{\"details\":\"Error indicating that the `transferFrom` has failed.\",\"params\":{\"from\":\"Owner of the token value.\",\"to\":\"Receiver of the token value.\",\"token\":\"Address of the token.\",\"tokenInfo\":\"Info of the token including ERC standard, id or quantity.\"}}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnsupportedStandard()\":[{\"details\":\"Error indicating that an unsupported standard is encountered.\"}],\"ErrUnsupportedToken()\":[{\"details\":\"Error indicating that a token is not supported.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"DOMAIN_SEPARATOR()\":{\"details\":\"Returns the domain seperator.\"},\"checkHighTierVoteWeightThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\"},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getHighTierVoteWeightThreshold()\":{\"details\":\"Returns the high-tier vote weight threshold.\"},\"getRoleAdmin(bytes32)\":{\"details\":\"Returns the admin role that controls `role`. See {grantRole} and {revokeRole}. To change a role's admin, use {_setRoleAdmin}.\"},\"getRoleMember(bytes32,uint256)\":{\"details\":\"Returns one of the accounts that have `role`. `index` must be a value between 0 and {getRoleMemberCount}, non-inclusive. Role bearers are not sorted in any particular way, and their ordering may change at any point. WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure you perform all queries on the same block. See the following https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post] for more information.\"},\"getRoleMemberCount(bytes32)\":{\"details\":\"Returns the number of accounts that have `role`. Can be used together with {getRoleMember} to enumerate all bearers of a role.\"},\"getRoninToken(address)\":{\"details\":\"Returns token address on Ronin network. Note: Reverts for unsupported token.\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"grantRole(bytes32,address)\":{\"details\":\"Grants `role` to `account`. If `account` had not been already granted `role`, emits a {RoleGranted} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleGranted} event.\"},\"hasRole(bytes32,address)\":{\"details\":\"Returns `true` if `account` has been granted `role`.\"},\"initialize(address,address,uint256,uint256,uint256,uint256,address[][3],uint256[][4],uint8[])\":{\"details\":\"Initializes contract storage.\"},\"mapTokens(address[],address[],uint8[])\":{\"details\":\"Maps mainchain tokens to Ronin network. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event.\"},\"mapTokensAndThresholds(address[],address[],uint8[],uint256[][4])\":{\"details\":\"Maps mainchain tokens to Ronin network and sets thresholds. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event.\"},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"pause()\":{\"details\":\"Triggers paused state.\"},\"paused()\":{\"details\":\"Returns true if the contract is paused, and false otherwise.\"},\"reachedWithdrawalLimit(address,uint256)\":{\"details\":\"Checks whether the withdrawal reaches the limitation.\"},\"receiveEther()\":{\"details\":\"Receives ether without doing anything. Use this function to topup native token.\"},\"renounceRole(bytes32,address)\":{\"details\":\"Revokes `role` from the calling account. Roles are often managed via {grantRole} and {revokeRole}: this function's purpose is to provide a mechanism for accounts to lose their privileges if they are compromised (such as when a trusted device is misplaced). If the calling account had been revoked `role`, emits a {RoleRevoked} event. Requirements: - the caller must be `account`. May emit a {RoleRevoked} event.\"},\"requestDepositFor((address,address,(uint8,uint256,uint256)))\":{\"details\":\"Locks the assets and request deposit.\"},\"revokeRole(bytes32,address)\":{\"details\":\"Revokes `role` from `account`. If `account` had been granted `role`, emits a {RoleRevoked} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleRevoked} event.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setDailyWithdrawalLimits(address[],uint256[])\":{\"details\":\"Sets daily limit amounts for the withdrawals. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `DailyWithdrawalLimitsUpdated` event.\"},\"setEmergencyPauser(address)\":{\"details\":\"Grant emergency pauser role for `_addr`.\"},\"setHighTierThresholds(address[],uint256[])\":{\"details\":\"Sets the thresholds for high-tier withdrawals that requires high-tier vote weights. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `HighTierThresholdsUpdated` event.\"},\"setHighTierVoteWeightThreshold(uint256,uint256)\":{\"details\":\"Sets high-tier vote weight threshold and returns the old one. Requirements: - The method caller is admin. - The high-tier vote weight threshold must equal to or larger than the normal threshold. Emits the `HighTierVoteWeightThresholdUpdated` event.\"},\"setLockedThresholds(address[],uint256[])\":{\"details\":\"Sets the amount thresholds to lock withdrawal. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `LockedThresholdsUpdated` event.\"},\"setThreshold(uint256,uint256)\":{\"details\":\"Override `GatewayV3-setThreshold`. Requirements: - The high-tier vote weight threshold must equal to or larger than the normal threshold.\"},\"setUnlockFeePercentages(address[],uint256[])\":{\"details\":\"Sets fee percentages to unlock withdrawal. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `UnlockFeePercentagesUpdated` event.\"},\"setWrappedNativeTokenContract(address)\":{\"details\":\"Sets the wrapped native token contract. Requirements: - The method caller is admin. Emits the `WrappedNativeTokenContractUpdated` event.\"},\"submitWithdrawal((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)),(uint8,bytes32,bytes32)[])\":{\"details\":\"Withdraws based on the receipt and the validator signatures. Returns whether the withdrawal is locked. Emits the `Withdrew` once the assets are released.\"},\"supportsInterface(bytes4)\":{\"details\":\"See {IERC165-supportsInterface}.\"},\"unlockWithdrawal((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))\":{\"details\":\"Approves a specific withdrawal. Requirements: - The method caller is a validator. Emits the `Withdrew` once the assets are released.\"},\"unpause()\":{\"details\":\"Triggers unpaused state.\"}},\"stateVariables\":{\"WITHDRAWAL_UNLOCKER_ROLE\":{\"details\":\"Withdrawal unlocker role hash\"},\"______deprecatedBridgeOperatorAddedBlock\":{\"custom:deprecated\":\"Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\"},\"______deprecatedBridgeOperators\":{\"custom:deprecated\":\"Previously `_bridgeOperators` (uint256[])\"},\"_domainSeparator\":{\"details\":\"Domain seperator\"},\"_roninToken\":{\"details\":\"Mapping from mainchain token => token address on Ronin network\"},\"depositCount\":{\"details\":\"Total deposit\"},\"roninChainId\":{\"details\":\"Ronin network id\"},\"withdrawalHash\":{\"details\":\"Mapping from withdrawal id => withdrawal hash\"},\"withdrawalLocked\":{\"details\":\"Mapping from withdrawal id => locked\"},\"wrappedNativeToken\":{\"details\":\"Wrapped native token address\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"unlockFeePercentages(address)\":{\"notice\":\"Values 0-1,000,000 map to 0%-100%\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/mainchain/MainchainGatewayV3.sol\":\"MainchainGatewayV3\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/access/AccessControl.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControl.sol\\\";\\nimport \\\"../utils/Context.sol\\\";\\nimport \\\"../utils/Strings.sol\\\";\\nimport \\\"../utils/introspection/ERC165.sol\\\";\\n\\n/**\\n * @dev Contract module that allows children to implement role-based access\\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\\n * members except through off-chain means by accessing the contract event logs. Some\\n * applications may benefit from on-chain enumerability, for those cases see\\n * {AccessControlEnumerable}.\\n *\\n * Roles are referred to by their `bytes32` identifier. These should be exposed\\n * in the external API and be unique. The best way to achieve this is by\\n * using `public constant` hash digests:\\n *\\n * ```\\n * bytes32 public constant MY_ROLE = keccak256(\\\"MY_ROLE\\\");\\n * ```\\n *\\n * Roles can be used to represent a set of permissions. To restrict access to a\\n * function call, use {hasRole}:\\n *\\n * ```\\n * function foo() public {\\n * require(hasRole(MY_ROLE, msg.sender));\\n * ...\\n * }\\n * ```\\n *\\n * Roles can be granted and revoked dynamically via the {grantRole} and\\n * {revokeRole} functions. Each role has an associated admin role, and only\\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\\n *\\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\\n * that only accounts with this role will be able to grant or revoke other\\n * roles. More complex role relationships can be created by using\\n * {_setRoleAdmin}.\\n *\\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\\n * grant and revoke this role. Extra precautions should be taken to secure\\n * accounts that have been granted it.\\n */\\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\\n struct RoleData {\\n mapping(address => bool) members;\\n bytes32 adminRole;\\n }\\n\\n mapping(bytes32 => RoleData) private _roles;\\n\\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\\n\\n /**\\n * @dev Modifier that checks that an account has a specific role. Reverts\\n * with a standardized message including the required role.\\n *\\n * The format of the revert reason is given by the following regular expression:\\n *\\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\\n *\\n * _Available since v4.1._\\n */\\n modifier onlyRole(bytes32 role) {\\n _checkRole(role);\\n _;\\n }\\n\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\\n }\\n\\n /**\\n * @dev Returns `true` if `account` has been granted `role`.\\n */\\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\\n return _roles[role].members[account];\\n }\\n\\n /**\\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\\n * Overriding this function changes the behavior of the {onlyRole} modifier.\\n *\\n * Format of the revert message is described in {_checkRole}.\\n *\\n * _Available since v4.6._\\n */\\n function _checkRole(bytes32 role) internal view virtual {\\n _checkRole(role, _msgSender());\\n }\\n\\n /**\\n * @dev Revert with a standard message if `account` is missing `role`.\\n *\\n * The format of the revert reason is given by the following regular expression:\\n *\\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\\n */\\n function _checkRole(bytes32 role, address account) internal view virtual {\\n if (!hasRole(role, account)) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"AccessControl: account \\\",\\n Strings.toHexString(uint160(account), 20),\\n \\\" is missing role \\\",\\n Strings.toHexString(uint256(role), 32)\\n )\\n )\\n );\\n }\\n }\\n\\n /**\\n * @dev Returns the admin role that controls `role`. See {grantRole} and\\n * {revokeRole}.\\n *\\n * To change a role's admin, use {_setRoleAdmin}.\\n */\\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\\n return _roles[role].adminRole;\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n *\\n * May emit a {RoleGranted} event.\\n */\\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\\n _grantRole(role, account);\\n }\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\\n _revokeRole(role, account);\\n }\\n\\n /**\\n * @dev Revokes `role` from the calling account.\\n *\\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\\n * purpose is to provide a mechanism for accounts to lose their privileges\\n * if they are compromised (such as when a trusted device is misplaced).\\n *\\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must be `account`.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function renounceRole(bytes32 role, address account) public virtual override {\\n require(account == _msgSender(), \\\"AccessControl: can only renounce roles for self\\\");\\n\\n _revokeRole(role, account);\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event. Note that unlike {grantRole}, this function doesn't perform any\\n * checks on the calling account.\\n *\\n * May emit a {RoleGranted} event.\\n *\\n * [WARNING]\\n * ====\\n * This function should only be called from the constructor when setting\\n * up the initial roles for the system.\\n *\\n * Using this function in any other way is effectively circumventing the admin\\n * system imposed by {AccessControl}.\\n * ====\\n *\\n * NOTE: This function is deprecated in favor of {_grantRole}.\\n */\\n function _setupRole(bytes32 role, address account) internal virtual {\\n _grantRole(role, account);\\n }\\n\\n /**\\n * @dev Sets `adminRole` as ``role``'s admin role.\\n *\\n * Emits a {RoleAdminChanged} event.\\n */\\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\\n bytes32 previousAdminRole = getRoleAdmin(role);\\n _roles[role].adminRole = adminRole;\\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * Internal function without access restriction.\\n *\\n * May emit a {RoleGranted} event.\\n */\\n function _grantRole(bytes32 role, address account) internal virtual {\\n if (!hasRole(role, account)) {\\n _roles[role].members[account] = true;\\n emit RoleGranted(role, account, _msgSender());\\n }\\n }\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * Internal function without access restriction.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function _revokeRole(bytes32 role, address account) internal virtual {\\n if (hasRole(role, account)) {\\n _roles[role].members[account] = false;\\n emit RoleRevoked(role, account, _msgSender());\\n }\\n }\\n}\\n\",\"keccak256\":\"0x5b35d8e68aeaccc685239bd9dd79b9ba01a0357930f8a3307ab85511733d9724\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/AccessControlEnumerable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControlEnumerable.sol\\\";\\nimport \\\"./AccessControl.sol\\\";\\nimport \\\"../utils/structs/EnumerableSet.sol\\\";\\n\\n/**\\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\\n */\\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\\n\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\\n }\\n\\n /**\\n * @dev Returns one of the accounts that have `role`. `index` must be a\\n * value between 0 and {getRoleMemberCount}, non-inclusive.\\n *\\n * Role bearers are not sorted in any particular way, and their ordering may\\n * change at any point.\\n *\\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\\n * you perform all queries on the same block. See the following\\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\\n * for more information.\\n */\\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\\n return _roleMembers[role].at(index);\\n }\\n\\n /**\\n * @dev Returns the number of accounts that have `role`. Can be used\\n * together with {getRoleMember} to enumerate all bearers of a role.\\n */\\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\\n return _roleMembers[role].length();\\n }\\n\\n /**\\n * @dev Overload {_grantRole} to track enumerable memberships\\n */\\n function _grantRole(bytes32 role, address account) internal virtual override {\\n super._grantRole(role, account);\\n _roleMembers[role].add(account);\\n }\\n\\n /**\\n * @dev Overload {_revokeRole} to track enumerable memberships\\n */\\n function _revokeRole(bytes32 role, address account) internal virtual override {\\n super._revokeRole(role, account);\\n _roleMembers[role].remove(account);\\n }\\n}\\n\",\"keccak256\":\"0x13f5e15f2a0650c0b6aaee2ef19e89eaf4870d6e79662d572a393334c1397247\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/IAccessControl.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev External interface of AccessControl declared to support ERC165 detection.\\n */\\ninterface IAccessControl {\\n /**\\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\\n *\\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\\n * {RoleAdminChanged} not being emitted signaling this.\\n *\\n * _Available since v3.1._\\n */\\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\\n\\n /**\\n * @dev Emitted when `account` is granted `role`.\\n *\\n * `sender` is the account that originated the contract call, an admin role\\n * bearer except when using {AccessControl-_setupRole}.\\n */\\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\\n\\n /**\\n * @dev Emitted when `account` is revoked `role`.\\n *\\n * `sender` is the account that originated the contract call:\\n * - if using `revokeRole`, it is the admin role bearer\\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\\n */\\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\\n\\n /**\\n * @dev Returns `true` if `account` has been granted `role`.\\n */\\n function hasRole(bytes32 role, address account) external view returns (bool);\\n\\n /**\\n * @dev Returns the admin role that controls `role`. See {grantRole} and\\n * {revokeRole}.\\n *\\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\\n */\\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n */\\n function grantRole(bytes32 role, address account) external;\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n */\\n function revokeRole(bytes32 role, address account) external;\\n\\n /**\\n * @dev Revokes `role` from the calling account.\\n *\\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\\n * purpose is to provide a mechanism for accounts to lose their privileges\\n * if they are compromised (such as when a trusted device is misplaced).\\n *\\n * If the calling account had been granted `role`, emits a {RoleRevoked}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must be `account`.\\n */\\n function renounceRole(bytes32 role, address account) external;\\n}\\n\",\"keccak256\":\"0x59ce320a585d7e1f163cd70390a0ef2ff9cec832e2aa544293a00692465a7a57\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/IAccessControlEnumerable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControl.sol\\\";\\n\\n/**\\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\\n */\\ninterface IAccessControlEnumerable is IAccessControl {\\n /**\\n * @dev Returns one of the accounts that have `role`. `index` must be a\\n * value between 0 and {getRoleMemberCount}, non-inclusive.\\n *\\n * Role bearers are not sorted in any particular way, and their ordering may\\n * change at any point.\\n *\\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\\n * you perform all queries on the same block. See the following\\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\\n * for more information.\\n */\\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\\n\\n /**\\n * @dev Returns the number of accounts that have `role`. Can be used\\n * together with {getRoleMember} to enumerate all bearers of a role.\\n */\\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\\n}\\n\",\"keccak256\":\"0xba4459ab871dfa300f5212c6c30178b63898c03533a1ede28436f11546626676\",\"license\":\"MIT\"},\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/security/Pausable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../utils/Context.sol\\\";\\n\\n/**\\n * @dev Contract module which allows children to implement an emergency stop\\n * mechanism that can be triggered by an authorized account.\\n *\\n * This module is used through inheritance. It will make available the\\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\\n * the functions of your contract. Note that they will not be pausable by\\n * simply including this module, only once the modifiers are put in place.\\n */\\nabstract contract Pausable is Context {\\n /**\\n * @dev Emitted when the pause is triggered by `account`.\\n */\\n event Paused(address account);\\n\\n /**\\n * @dev Emitted when the pause is lifted by `account`.\\n */\\n event Unpaused(address account);\\n\\n bool private _paused;\\n\\n /**\\n * @dev Initializes the contract in unpaused state.\\n */\\n constructor() {\\n _paused = false;\\n }\\n\\n /**\\n * @dev Modifier to make a function callable only when the contract is not paused.\\n *\\n * Requirements:\\n *\\n * - The contract must not be paused.\\n */\\n modifier whenNotPaused() {\\n _requireNotPaused();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to make a function callable only when the contract is paused.\\n *\\n * Requirements:\\n *\\n * - The contract must be paused.\\n */\\n modifier whenPaused() {\\n _requirePaused();\\n _;\\n }\\n\\n /**\\n * @dev Returns true if the contract is paused, and false otherwise.\\n */\\n function paused() public view virtual returns (bool) {\\n return _paused;\\n }\\n\\n /**\\n * @dev Throws if the contract is paused.\\n */\\n function _requireNotPaused() internal view virtual {\\n require(!paused(), \\\"Pausable: paused\\\");\\n }\\n\\n /**\\n * @dev Throws if the contract is not paused.\\n */\\n function _requirePaused() internal view virtual {\\n require(paused(), \\\"Pausable: not paused\\\");\\n }\\n\\n /**\\n * @dev Triggers stopped state.\\n *\\n * Requirements:\\n *\\n * - The contract must not be paused.\\n */\\n function _pause() internal virtual whenNotPaused {\\n _paused = true;\\n emit Paused(_msgSender());\\n }\\n\\n /**\\n * @dev Returns to normal state.\\n *\\n * Requirements:\\n *\\n * - The contract must be paused.\\n */\\n function _unpause() internal virtual whenPaused {\\n _paused = false;\\n emit Unpaused(_msgSender());\\n }\\n}\\n\",\"keccak256\":\"0x0849d93b16c9940beb286a7864ed02724b248b93e0d80ef6355af5ef15c64773\",\"license\":\"MIT\"},\"@openzeppelin/contracts/token/ERC20/IERC20.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC20 standard as defined in the EIP.\\n */\\ninterface IERC20 {\\n /**\\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\\n * another (`to`).\\n *\\n * Note that `value` may be zero.\\n */\\n event Transfer(address indexed from, address indexed to, uint256 value);\\n\\n /**\\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\\n * a call to {approve}. `value` is the new allowance.\\n */\\n event Approval(address indexed owner, address indexed spender, uint256 value);\\n\\n /**\\n * @dev Returns the amount of tokens in existence.\\n */\\n function totalSupply() external view returns (uint256);\\n\\n /**\\n * @dev Returns the amount of tokens owned by `account`.\\n */\\n function balanceOf(address account) external view returns (uint256);\\n\\n /**\\n * @dev Moves `amount` tokens from the caller's account to `to`.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transfer(address to, uint256 amount) external returns (bool);\\n\\n /**\\n * @dev Returns the remaining number of tokens that `spender` will be\\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\\n * zero by default.\\n *\\n * This value changes when {approve} or {transferFrom} are called.\\n */\\n function allowance(address owner, address spender) external view returns (uint256);\\n\\n /**\\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\\n * that someone may use both the old and the new allowance by unfortunate\\n * transaction ordering. One possible solution to mitigate this race\\n * condition is to first reduce the spender's allowance to 0 and set the\\n * desired value afterwards:\\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\\n *\\n * Emits an {Approval} event.\\n */\\n function approve(address spender, uint256 amount) external returns (bool);\\n\\n /**\\n * @dev Moves `amount` tokens from `from` to `to` using the\\n * allowance mechanism. `amount` is then deducted from the caller's\\n * allowance.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transferFrom(\\n address from,\\n address to,\\n uint256 amount\\n ) external returns (bool);\\n}\\n\",\"keccak256\":\"0x9750c6b834f7b43000631af5cc30001c5f547b3ceb3635488f140f60e897ea6b\",\"license\":\"MIT\"},\"@openzeppelin/contracts/token/ERC721/IERC721.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @dev Required interface of an ERC721 compliant contract.\\n */\\ninterface IERC721 is IERC165 {\\n /**\\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\\n */\\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\\n\\n /**\\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\\n */\\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\\n\\n /**\\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\\n */\\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\\n\\n /**\\n * @dev Returns the number of tokens in ``owner``'s account.\\n */\\n function balanceOf(address owner) external view returns (uint256 balance);\\n\\n /**\\n * @dev Returns the owner of the `tokenId` token.\\n *\\n * Requirements:\\n *\\n * - `tokenId` must exist.\\n */\\n function ownerOf(uint256 tokenId) external view returns (address owner);\\n\\n /**\\n * @dev Safely transfers `tokenId` token from `from` to `to`.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must exist and be owned by `from`.\\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\\n *\\n * Emits a {Transfer} event.\\n */\\n function safeTransferFrom(\\n address from,\\n address to,\\n uint256 tokenId,\\n bytes calldata data\\n ) external;\\n\\n /**\\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must exist and be owned by `from`.\\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\\n *\\n * Emits a {Transfer} event.\\n */\\n function safeTransferFrom(\\n address from,\\n address to,\\n uint256 tokenId\\n ) external;\\n\\n /**\\n * @dev Transfers `tokenId` token from `from` to `to`.\\n *\\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must be owned by `from`.\\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transferFrom(\\n address from,\\n address to,\\n uint256 tokenId\\n ) external;\\n\\n /**\\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\\n * The approval is cleared when the token is transferred.\\n *\\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\\n *\\n * Requirements:\\n *\\n * - The caller must own the token or be an approved operator.\\n * - `tokenId` must exist.\\n *\\n * Emits an {Approval} event.\\n */\\n function approve(address to, uint256 tokenId) external;\\n\\n /**\\n * @dev Approve or remove `operator` as an operator for the caller.\\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\\n *\\n * Requirements:\\n *\\n * - The `operator` cannot be the caller.\\n *\\n * Emits an {ApprovalForAll} event.\\n */\\n function setApprovalForAll(address operator, bool _approved) external;\\n\\n /**\\n * @dev Returns the account approved for `tokenId` token.\\n *\\n * Requirements:\\n *\\n * - `tokenId` must exist.\\n */\\n function getApproved(uint256 tokenId) external view returns (address operator);\\n\\n /**\\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\\n *\\n * See {setApprovalForAll}\\n */\\n function isApprovedForAll(address owner, address operator) external view returns (bool);\\n}\\n\",\"keccak256\":\"0xed6a749c5373af398105ce6ee3ac4763aa450ea7285d268c85d9eeca809cdb1f\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Context.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Provides information about the current execution context, including the\\n * sender of the transaction and its data. While these are generally available\\n * via msg.sender and msg.data, they should not be accessed in such a direct\\n * manner, since when dealing with meta-transactions the account sending and\\n * paying for execution may not be the actual sender (as far as an application\\n * is concerned).\\n *\\n * This contract is only required for intermediate, library-like contracts.\\n */\\nabstract contract Context {\\n function _msgSender() internal view virtual returns (address) {\\n return msg.sender;\\n }\\n\\n function _msgData() internal view virtual returns (bytes calldata) {\\n return msg.data;\\n }\\n}\\n\",\"keccak256\":\"0xe2e337e6dde9ef6b680e07338c493ebea1b5fd09b43424112868e9cc1706bca7\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/ERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IERC165.sol\\\";\\n\\n/**\\n * @dev Implementation of the {IERC165} interface.\\n *\\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\\n * for the additional interface id that will be supported. For example:\\n *\\n * ```solidity\\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\\n * }\\n * ```\\n *\\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\\n */\\nabstract contract ERC165 is IERC165 {\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IERC165).interfaceId;\\n }\\n}\\n\",\"keccak256\":\"0xd10975de010d89fd1c78dc5e8a9a7e7f496198085c151648f20cba166b32582b\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for managing\\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\\n * types.\\n *\\n * Sets have the following properties:\\n *\\n * - Elements are added, removed, and checked for existence in constant time\\n * (O(1)).\\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\\n *\\n * ```\\n * contract Example {\\n * // Add the library methods\\n * using EnumerableSet for EnumerableSet.AddressSet;\\n *\\n * // Declare a set state variable\\n * EnumerableSet.AddressSet private mySet;\\n * }\\n * ```\\n *\\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\\n * and `uint256` (`UintSet`) are supported.\\n *\\n * [WARNING]\\n * ====\\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\\n *\\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\\n * ====\\n */\\nlibrary EnumerableSet {\\n // To implement this library for multiple types with as little code\\n // repetition as possible, we write it in terms of a generic Set type with\\n // bytes32 values.\\n // The Set implementation uses private functions, and user-facing\\n // implementations (such as AddressSet) are just wrappers around the\\n // underlying Set.\\n // This means that we can only create new EnumerableSets for types that fit\\n // in bytes32.\\n\\n struct Set {\\n // Storage of set values\\n bytes32[] _values;\\n // Position of the value in the `values` array, plus 1 because index 0\\n // means a value is not in the set.\\n mapping(bytes32 => uint256) _indexes;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function _add(Set storage set, bytes32 value) private returns (bool) {\\n if (!_contains(set, value)) {\\n set._values.push(value);\\n // The value is stored at length-1, but we add 1 to all indexes\\n // and use 0 as a sentinel value\\n set._indexes[value] = set._values.length;\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function _remove(Set storage set, bytes32 value) private returns (bool) {\\n // We read and store the value's index to prevent multiple reads from the same storage slot\\n uint256 valueIndex = set._indexes[value];\\n\\n if (valueIndex != 0) {\\n // Equivalent to contains(set, value)\\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\\n // the array, and then remove the last element (sometimes called as 'swap and pop').\\n // This modifies the order of the array, as noted in {at}.\\n\\n uint256 toDeleteIndex = valueIndex - 1;\\n uint256 lastIndex = set._values.length - 1;\\n\\n if (lastIndex != toDeleteIndex) {\\n bytes32 lastValue = set._values[lastIndex];\\n\\n // Move the last value to the index where the value to delete is\\n set._values[toDeleteIndex] = lastValue;\\n // Update the index for the moved value\\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\\n }\\n\\n // Delete the slot where the moved value was stored\\n set._values.pop();\\n\\n // Delete the index for the deleted slot\\n delete set._indexes[value];\\n\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\\n return set._indexes[value] != 0;\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function _length(Set storage set) private view returns (uint256) {\\n return set._values.length;\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\\n return set._values[index];\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function _values(Set storage set) private view returns (bytes32[] memory) {\\n return set._values;\\n }\\n\\n // Bytes32Set\\n\\n struct Bytes32Set {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _add(set._inner, value);\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _remove(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\\n return _contains(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(Bytes32Set storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\\n return _at(set._inner, index);\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\\n return _values(set._inner);\\n }\\n\\n // AddressSet\\n\\n struct AddressSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(AddressSet storage set, address value) internal returns (bool) {\\n return _add(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(AddressSet storage set, address value) internal returns (bool) {\\n return _remove(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(AddressSet storage set, address value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(AddressSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\\n return address(uint160(uint256(_at(set._inner, index))));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(AddressSet storage set) internal view returns (address[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n address[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n\\n // UintSet\\n\\n struct UintSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(UintSet storage set, uint256 value) internal returns (bool) {\\n return _add(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\\n return _remove(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function length(UintSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\\n return uint256(_at(set._inner, index));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(UintSet storage set) internal view returns (uint256[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n uint256[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n}\\n\",\"keccak256\":\"0x5050943b32b6a8f282573d166b2e9d87ab7eb4dbba4ab6acf36ecb54fe6995e4\",\"license\":\"MIT\"},\"contracts/extensions/GatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/security/Pausable.sol\\\";\\nimport \\\"../interfaces/IQuorum.sol\\\";\\nimport \\\"./collections/HasProxyAdmin.sol\\\";\\n\\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\\n uint256 internal _num;\\n uint256 internal _denom;\\n\\n address private ______deprecated;\\n uint256 public nonce;\\n\\n address public emergencyPauser;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[49] private ______gap;\\n\\n /**\\n * @dev Grant emergency pauser role for `_addr`.\\n */\\n function setEmergencyPauser(address _addr) external onlyAdmin {\\n emergencyPauser = _addr;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (_num, _denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * _denom >= _num * _getTotalWeight();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external virtual onlyAdmin returns (uint256, uint256) {\\n return _setThreshold(_numerator, _denominator);\\n }\\n\\n /**\\n * @dev Triggers paused state.\\n */\\n function pause() external {\\n _requireAuth();\\n _pause();\\n }\\n\\n /**\\n * @dev Triggers unpaused state.\\n */\\n function unpause() external {\\n _requireAuth();\\n _unpause();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() public view virtual returns (uint256) {\\n return _minimumVoteWeight(_getTotalWeight());\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\\n _previousNum = _num;\\n _previousDenom = _denom;\\n _num = _numerator;\\n _denom = _denominator;\\n unchecked {\\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\\n }\\n }\\n\\n /**\\n * @dev Returns minimum vote weight.\\n */\\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\\n return (_num * _totalWeight + _denom - 1) / _denom;\\n }\\n\\n /**\\n * @dev Internal method to check method caller.\\n *\\n * Requirements:\\n *\\n * - The method caller must be admin or pauser.\\n *\\n */\\n function _requireAuth() private view {\\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n }\\n\\n /**\\n * @dev Returns the total weight.\\n */\\n function _getTotalWeight() internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0xfcb8d4fa4358387c477a40da4d8a5108c298f23333c4161ce939c1b27a09ffde\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/WithdrawalLimitation.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./GatewayV3.sol\\\";\\n\\nabstract contract WithdrawalLimitation is GatewayV3 {\\n /// @dev Error of invalid percentage.\\n error ErrInvalidPercentage();\\n\\n /// @dev Emitted when the high-tier vote weight threshold is updated\\n event HighTierVoteWeightThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\\n /// @dev Emitted when the thresholds for locked withdrawals are updated\\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\\n /// @dev Emitted when the daily limit thresholds are updated\\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\\n\\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\\n\\n uint256 internal _highTierVWNum;\\n uint256 internal _highTierVWDenom;\\n\\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\\n mapping(address => uint256) public highTierThreshold;\\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\\n mapping(address => uint256) public lockedThreshold;\\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\\n /// @notice Values 0-1,000,000 map to 0%-100%\\n mapping(address => uint256) public unlockFeePercentages;\\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\\n mapping(address => uint256) public dailyWithdrawalLimit;\\n /// @dev Mapping from token address => today withdrawal amount\\n mapping(address => uint256) public lastSyncedWithdrawal;\\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\\n mapping(address => uint256) public lastDateSynced;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @dev Override `GatewayV3-setThreshold`.\\n *\\n * Requirements:\\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\\n _verifyThresholds();\\n }\\n\\n /**\\n * @dev Returns the high-tier vote weight threshold.\\n */\\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\\n return (_highTierVWNum, _highTierVWDenom);\\n }\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\\n */\\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\\n }\\n\\n /**\\n * @dev Sets high-tier vote weight threshold and returns the old one.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\\n *\\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\\n *\\n */\\n function setHighTierVoteWeightThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\\n _verifyThresholds();\\n }\\n\\n /**\\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `HighTierThresholdsUpdated` event.\\n *\\n */\\n function setHighTierThresholds(\\n address[] calldata _tokens,\\n uint256[] calldata _thresholds\\n ) external virtual onlyAdmin {\\n if (_tokens.length == 0) revert ErrEmptyArray();\\n _setHighTierThresholds(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Sets the amount thresholds to lock withdrawal.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `LockedThresholdsUpdated` event.\\n *\\n */\\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\\n if (_tokens.length == 0) revert ErrEmptyArray();\\n _setLockedThresholds(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Sets fee percentages to unlock withdrawal.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `UnlockFeePercentagesUpdated` event.\\n *\\n */\\n function setUnlockFeePercentages(\\n address[] calldata _tokens,\\n uint256[] calldata _percentages\\n ) external virtual onlyAdmin {\\n if (_tokens.length == 0) revert ErrEmptyArray();\\n _setUnlockFeePercentages(_tokens, _percentages);\\n }\\n\\n /**\\n * @dev Sets daily limit amounts for the withdrawals.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `DailyWithdrawalLimitsUpdated` event.\\n *\\n */\\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\\n if (_tokens.length == 0) revert ErrEmptyArray();\\n _setDailyWithdrawalLimits(_tokens, _limits);\\n }\\n\\n /**\\n * @dev Checks whether the withdrawal reaches the limitation.\\n */\\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\\n return _reachedWithdrawalLimit(_token, _quantity);\\n }\\n\\n /**\\n * @dev Sets high-tier vote weight threshold and returns the old one.\\n *\\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\\n *\\n */\\n function _setHighTierVoteWeightThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\\n\\n _previousNum = _highTierVWNum;\\n _previousDenom = _highTierVWDenom;\\n _highTierVWNum = _numerator;\\n _highTierVWDenom = _denominator;\\n\\n unchecked {\\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\\n }\\n }\\n\\n /**\\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\\n *\\n * Requirements:\\n * - The array lengths are equal.\\n *\\n * Emits the `HighTierThresholdsUpdated` event.\\n *\\n */\\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _tokens.length; ) {\\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Sets the amount thresholds to lock withdrawal.\\n *\\n * Requirements:\\n * - The array lengths are equal.\\n *\\n * Emits the `LockedThresholdsUpdated` event.\\n *\\n */\\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _tokens.length; ) {\\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit LockedThresholdsUpdated(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Sets fee percentages to unlock withdrawal.\\n *\\n * Requirements:\\n * - The array lengths are equal.\\n * - The percentage is equal to or less than 100_000.\\n *\\n * Emits the `UnlockFeePercentagesUpdated` event.\\n *\\n */\\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _tokens.length; ) {\\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\\n\\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\\n }\\n\\n /**\\n * @dev Sets daily limit amounts for the withdrawals.\\n *\\n * Requirements:\\n * - The array lengths are equal.\\n *\\n * Emits the `DailyWithdrawalLimitsUpdated` event.\\n *\\n */\\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _tokens.length; ) {\\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\\n }\\n\\n /**\\n * @dev Checks whether the withdrawal reaches the daily limitation.\\n *\\n * Requirements:\\n * - The daily withdrawal threshold should not apply for locked withdrawals.\\n *\\n */\\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\\n if (_lockedWithdrawalRequest(_token, _quantity)) {\\n return false;\\n }\\n\\n uint256 _currentDate = block.timestamp / 1 days;\\n if (_currentDate > lastDateSynced[_token]) {\\n return dailyWithdrawalLimit[_token] <= _quantity;\\n } else {\\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\\n }\\n }\\n\\n /**\\n * @dev Record withdrawal token.\\n */\\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\\n uint256 _currentDate = block.timestamp / 1 days;\\n if (_currentDate > lastDateSynced[_token]) {\\n lastDateSynced[_token] = _currentDate;\\n lastSyncedWithdrawal[_token] = _quantity;\\n } else {\\n lastSyncedWithdrawal[_token] += _quantity;\\n }\\n }\\n\\n /**\\n * @dev Returns whether the withdrawal request is locked or not.\\n */\\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\\n return lockedThreshold[_token] <= _quantity;\\n }\\n\\n /**\\n * @dev Computes fee percentage.\\n */\\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\\n return (_amount * _percentage) / _MAX_PERCENTAGE;\\n }\\n\\n /**\\n * @dev Returns high-tier vote weight.\\n */\\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\\n }\\n\\n /**\\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\\n */\\n function _verifyThresholds() internal view {\\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\\n }\\n}\\n\",\"keccak256\":\"0xb574848e6c3fa2ceeb7f5e907bc76dc096ef577315dbf78452f9640bd92d8a32\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IMainchainGatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IWETH.sol\\\";\\nimport \\\"./consumers/SignatureConsumer.sol\\\";\\nimport \\\"./consumers/MappedTokenConsumer.sol\\\";\\nimport \\\"../libraries/Transfer.sol\\\";\\n\\ninterface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer {\\n /**\\n * @dev Error indicating that a query was made for an approved withdrawal.\\n */\\n error ErrQueryForApprovedWithdrawal();\\n\\n /**\\n * @dev Error indicating that the daily withdrawal limit has been reached.\\n */\\n error ErrReachedDailyWithdrawalLimit();\\n\\n /**\\n * @dev Error indicating that a query was made for a processed withdrawal.\\n */\\n error ErrQueryForProcessedWithdrawal();\\n\\n /**\\n * @dev Error indicating that a query was made for insufficient vote weight.\\n */\\n error ErrQueryForInsufficientVoteWeight();\\n\\n /// @dev Emitted when the deposit is requested\\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\\n /// @dev Emitted when the assets are withdrawn\\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\\n /// @dev Emitted when the tokens are mapped\\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\\n /// @dev Emitted when the wrapped native token contract is updated\\n event WrappedNativeTokenContractUpdated(IWETH weth);\\n /// @dev Emitted when the withdrawal is locked\\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\\n /// @dev Emitted when the withdrawal is unlocked\\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\\n\\n /**\\n * @dev Returns the domain seperator.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns deposit count.\\n */\\n function depositCount() external view returns (uint256);\\n\\n /**\\n * @dev Sets the wrapped native token contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `WrappedNativeTokenContractUpdated` event.\\n *\\n */\\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\\n\\n /**\\n * @dev Returns whether the withdrawal is locked.\\n */\\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\\n\\n /**\\n * @dev Returns the withdrawal hash.\\n */\\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\\n\\n /**\\n * @dev Locks the assets and request deposit.\\n */\\n function requestDepositFor(Transfer.Request calldata _request) external payable;\\n\\n /**\\n * @dev Withdraws based on the receipt and the validator signatures.\\n * Returns whether the withdrawal is locked.\\n *\\n * Emits the `Withdrew` once the assets are released.\\n *\\n */\\n function submitWithdrawal(\\n Transfer.Receipt memory _receipt,\\n Signature[] memory _signatures\\n ) external returns (bool _locked);\\n\\n /**\\n * @dev Approves a specific withdrawal.\\n *\\n * Requirements:\\n * - The method caller is a validator.\\n *\\n * Emits the `Withdrew` once the assets are released.\\n *\\n */\\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\\n\\n /**\\n * @dev Maps mainchain tokens to Ronin network.\\n *\\n * Requirement:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `TokenMapped` event.\\n *\\n */\\n function mapTokens(\\n address[] calldata _mainchainTokens,\\n address[] calldata _roninTokens,\\n Token.Standard[] calldata _standards\\n ) external;\\n\\n /**\\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\\n *\\n * Requirement:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `TokenMapped` event.\\n *\\n */\\n function mapTokensAndThresholds(\\n address[] calldata _mainchainTokens,\\n address[] calldata _roninTokens,\\n Token.Standard[] calldata _standards,\\n uint256[][4] calldata _thresholds\\n ) external;\\n\\n /**\\n * @dev Returns token address on Ronin network.\\n * Note: Reverts for unsupported token.\\n */\\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\\n}\\n\",\"keccak256\":\"0xa82b8172f40ec733e5a03b019a8a7d597af284779c872c620ecc91a28af55461\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/IWETH.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IWETH {\\n function deposit() external payable;\\n\\n function withdraw(uint256 _wad) external;\\n\\n function balanceOf(address) external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x8acead2ae4364dee80c9bc76d52cc04d3763105e1743728e67d237f816155142\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallback.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @title IBridgeManagerCallback\\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\\n */\\ninterface IBridgeManagerCallback is IERC165 {\\n /**\\n * @dev Handles the event when bridge operators are added.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsAdded(\\n address[] memory bridgeOperators,\\n bool[] memory addeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when bridge operators are removed.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsRemoved(\\n address[] memory bridgeOperators,\\n bool[] memory removeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when a bridge operator is updated.\\n * @param currentBridgeOperator The address of the current bridge operator.\\n * @param newbridgeOperator The new address of the bridge operator.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorUpdated(\\n address currentBridgeOperator,\\n address newbridgeOperator\\n ) external returns (bytes4 selector);\\n}\\n\",\"keccak256\":\"0xfd6868a1041577a463b6c96713edcb18063dc817154d09710abfd5783e4629ee\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/MappedTokenConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Token.sol\\\";\\n\\ninterface MappedTokenConsumer {\\n struct MappedToken {\\n Token.Standard erc;\\n address tokenAddr;\\n }\\n}\\n\",\"keccak256\":\"0xfa220e968221af9b789e6c1dc4133631e90600c4a2bd63b7f01e96cb01f13e9b\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/SignatureConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface SignatureConsumer {\\n struct Signature {\\n uint8 v;\\n bytes32 r;\\n bytes32 s;\\n }\\n}\\n\",\"keccak256\":\"0xd370e350722067097dec1a5c31bda6e47e83417fa5c3288293bb910028cd136b\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Token.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/token/ERC20/IERC20.sol\\\";\\nimport \\\"@openzeppelin/contracts/token/ERC721/IERC721.sol\\\";\\nimport \\\"../interfaces/IWETH.sol\\\";\\n\\nlibrary Token {\\n /// @dev Error indicating that the provided information is invalid.\\n error ErrInvalidInfo();\\n\\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\\n error ErrERC20MintingFailed();\\n\\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\\n error ErrERC721MintingFailed();\\n\\n /// @dev Error indicating that an unsupported standard is encountered.\\n error ErrUnsupportedStandard();\\n\\n /**\\n * @dev Error indicating that the `transfer` has failed.\\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\\n * @param to Receiver of the token value.\\n * @param token Address of the token.\\n */\\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\\n\\n /**\\n * @dev Error indicating that the `transferFrom` has failed.\\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\\n * @param from Owner of the token value.\\n * @param to Receiver of the token value.\\n * @param token Address of the token.\\n */\\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\\n\\n enum Standard {\\n ERC20,\\n ERC721\\n }\\n\\n struct Info {\\n Standard erc;\\n // For ERC20: the id must be 0 and the quantity is larger than 0.\\n // For ERC721: the quantity must be 0.\\n uint256 id;\\n uint256 quantity;\\n }\\n\\n // keccak256(\\\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\\\");\\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\\n\\n /**\\n * @dev Returns token info struct hash.\\n */\\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, INFO_TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\\n digest := keccak256(ptr, 0x80)\\n }\\n }\\n\\n /**\\n * @dev Validates the token info.\\n */\\n function validate(Info memory _info) internal pure {\\n if (\\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\\n ) revert ErrInvalidInfo();\\n }\\n\\n /**\\n * @dev Transfer asset from.\\n *\\n * Requirements:\\n * - The `_from` address must approve for the contract using this library.\\n *\\n */\\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\\n bool _success;\\n bytes memory _data;\\n if (_info.erc == Standard.ERC20) {\\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\\n } else if (_info.erc == Standard.ERC721) {\\n // bytes4(keccak256(\\\"transferFrom(address,address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\\n } else revert ErrUnsupportedStandard();\\n\\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\\n }\\n\\n /**\\n * @dev Transfers ERC721 token and returns the result.\\n */\\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\\n }\\n\\n /**\\n * @dev Transfers ERC20 token and returns the result.\\n */\\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\\n bytes memory _data;\\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\\n }\\n\\n /**\\n * @dev Transfer assets from current address to `_to` address.\\n */\\n function transfer(Info memory _info, address _to, address _token) internal {\\n bool _success;\\n if (_info.erc == Standard.ERC20) {\\n _success = tryTransferERC20(_token, _to, _info.quantity);\\n } else if (_info.erc == Standard.ERC721) {\\n _success = tryTransferERC721(_token, _to, _info.id);\\n } else revert ErrUnsupportedStandard();\\n\\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\\n }\\n\\n /**\\n * @dev Tries minting and transfering assets.\\n *\\n * @notice Prioritizes transfer native token if the token is wrapped.\\n *\\n */\\n function handleAssetTransfer(\\n Info memory _info,\\n address payable _to,\\n address _token,\\n IWETH _wrappedNativeToken\\n ) internal {\\n bool _success;\\n if (_token == address(_wrappedNativeToken)) {\\n // Try sending the native token before transferring the wrapped token\\n if (!_to.send(_info.quantity)) {\\n _wrappedNativeToken.deposit{ value: _info.quantity }();\\n transfer(_info, _to, _token);\\n }\\n } else if (_info.erc == Token.Standard.ERC20) {\\n uint256 _balance = IERC20(_token).balanceOf(address(this));\\n\\n if (_balance < _info.quantity) {\\n // bytes4(keccak256(\\\"mint(address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\\n if (!_success) revert ErrERC20MintingFailed();\\n }\\n\\n transfer(_info, _to, _token);\\n } else if (_info.erc == Token.Standard.ERC721) {\\n if (!tryTransferERC721(_token, _to, _info.id)) {\\n // bytes4(keccak256(\\\"mint(address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\\n if (!_success) revert ErrERC721MintingFailed();\\n }\\n } else revert ErrUnsupportedStandard();\\n }\\n\\n struct Owner {\\n address addr;\\n address tokenAddr;\\n uint256 chainId;\\n }\\n\\n // keccak256(\\\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\\\");\\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\\n\\n /**\\n * @dev Returns ownership struct hash.\\n */\\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, OWNER_TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\\n digest := keccak256(ptr, 0x80)\\n }\\n }\\n}\\n\",\"keccak256\":\"0x8d11e48d878ba37ea2ca7395dceaa5591bb9ba2d4e5fdac1565760456e104991\",\"license\":\"MIT\"},\"contracts/libraries/Transfer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\nimport \\\"@openzeppelin/contracts/token/ERC20/IERC20.sol\\\";\\nimport \\\"./Token.sol\\\";\\n\\nlibrary Transfer {\\n using ECDSA for bytes32;\\n\\n enum Kind {\\n Deposit,\\n Withdrawal\\n }\\n\\n struct Request {\\n // For deposit request: Recipient address on Ronin network\\n // For withdrawal request: Recipient address on mainchain network\\n address recipientAddr;\\n // Token address to deposit/withdraw\\n // Value 0: native token\\n address tokenAddr;\\n Token.Info info;\\n }\\n\\n /**\\n * @dev Converts the transfer request into the deposit receipt.\\n */\\n function into_deposit_receipt(\\n Request memory _request,\\n address _requester,\\n uint256 _id,\\n address _roninTokenAddr,\\n uint256 _roninChainId\\n ) internal view returns (Receipt memory _receipt) {\\n _receipt.id = _id;\\n _receipt.kind = Kind.Deposit;\\n _receipt.mainchain.addr = _requester;\\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\\n _receipt.mainchain.chainId = block.chainid;\\n _receipt.ronin.addr = _request.recipientAddr;\\n _receipt.ronin.tokenAddr = _roninTokenAddr;\\n _receipt.ronin.chainId = _roninChainId;\\n _receipt.info = _request.info;\\n }\\n\\n /**\\n * @dev Converts the transfer request into the withdrawal receipt.\\n */\\n function into_withdrawal_receipt(\\n Request memory _request,\\n address _requester,\\n uint256 _id,\\n address _mainchainTokenAddr,\\n uint256 _mainchainId\\n ) internal view returns (Receipt memory _receipt) {\\n _receipt.id = _id;\\n _receipt.kind = Kind.Withdrawal;\\n _receipt.ronin.addr = _requester;\\n _receipt.ronin.tokenAddr = _request.tokenAddr;\\n _receipt.ronin.chainId = block.chainid;\\n _receipt.mainchain.addr = _request.recipientAddr;\\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\\n _receipt.mainchain.chainId = _mainchainId;\\n _receipt.info = _request.info;\\n }\\n\\n struct Receipt {\\n uint256 id;\\n Kind kind;\\n Token.Owner mainchain;\\n Token.Owner ronin;\\n Token.Info info;\\n }\\n\\n // keccak256(\\\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\\\");\\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\\n\\n /**\\n * @dev Returns token info struct hash.\\n */\\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\\n\\n /*\\n * return\\n * keccak256(\\n * abi.encode(\\n * TYPE_HASH,\\n * _receipt.id,\\n * _receipt.kind,\\n * Token.hash(_receipt.mainchain),\\n * Token.hash(_receipt.ronin),\\n * Token.hash(_receipt.info)\\n * )\\n * );\\n */\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\\n mstore(add(ptr, 0x80), hashedReceiptRonin)\\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\\n digest := keccak256(ptr, 0xc0)\\n }\\n }\\n\\n /**\\n * @dev Returns the receipt digest.\\n */\\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\\n return _domainSeparator.toTypedDataHash(_receiptHash);\\n }\\n}\\n\",\"keccak256\":\"0xe73e11942bcae9034abc2058e9976a583e3518bdfeefa863e97cb6e51edf4522\",\"license\":\"MIT\"},\"contracts/mainchain/MainchainGatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/access/AccessControlEnumerable.sol\\\";\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport { IBridgeManager } from \\\"../interfaces/bridge/IBridgeManager.sol\\\";\\nimport { IBridgeManagerCallback } from \\\"../interfaces/bridge/IBridgeManagerCallback.sol\\\";\\nimport { HasContracts, ContractType } from \\\"../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../extensions/WithdrawalLimitation.sol\\\";\\nimport \\\"../libraries/Transfer.sol\\\";\\nimport \\\"../interfaces/IMainchainGatewayV3.sol\\\";\\n\\ncontract MainchainGatewayV3 is\\n WithdrawalLimitation,\\n Initializable,\\n AccessControlEnumerable,\\n IMainchainGatewayV3,\\n HasContracts\\n{\\n using Token for Token.Info;\\n using Transfer for Transfer.Request;\\n using Transfer for Transfer.Receipt;\\n\\n /// @dev Withdrawal unlocker role hash\\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\\\"WITHDRAWAL_UNLOCKER_ROLE\\\");\\n\\n /// @dev Wrapped native token address\\n IWETH public wrappedNativeToken;\\n /// @dev Ronin network id\\n uint256 public roninChainId;\\n /// @dev Total deposit\\n uint256 public depositCount;\\n /// @dev Domain seperator\\n bytes32 internal _domainSeparator;\\n /// @dev Mapping from mainchain token => token address on Ronin network\\n mapping(address => MappedToken) internal _roninToken;\\n /// @dev Mapping from withdrawal id => withdrawal hash\\n mapping(uint256 => bytes32) public withdrawalHash;\\n /// @dev Mapping from withdrawal id => locked\\n mapping(uint256 => bool) public withdrawalLocked;\\n\\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\\n uint256 private ______deprecatedBridgeOperators;\\n\\n fallback() external payable {\\n _fallback();\\n }\\n\\n receive() external payable {\\n _fallback();\\n }\\n\\n /**\\n * @dev Initializes contract storage.\\n */\\n function initialize(\\n address _roleSetter,\\n IWETH _wrappedToken,\\n uint256 _roninChainId,\\n uint256 _numerator,\\n uint256 _highTierVWNumerator,\\n uint256 _denominator,\\n // _addresses[0]: mainchainTokens\\n // _addresses[1]: roninTokens\\n // _addresses[2]: withdrawalUnlockers\\n address[][3] calldata _addresses,\\n // _thresholds[0]: highTierThreshold\\n // _thresholds[1]: lockedThreshold\\n // _thresholds[2]: unlockFeePercentages\\n // _thresholds[3]: dailyWithdrawalLimit\\n uint256[][4] calldata _thresholds,\\n Token.Standard[] calldata _standards\\n ) external payable virtual initializer {\\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\\n roninChainId = _roninChainId;\\n\\n _setWrappedNativeTokenContract(_wrappedToken);\\n _updateDomainSeparator();\\n _setThreshold(_numerator, _denominator);\\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\\n _verifyThresholds();\\n\\n if (_addresses[0].length > 0) {\\n // Map mainchain tokens to ronin tokens\\n _mapTokens(_addresses[0], _addresses[1], _standards);\\n // Sets thresholds based on the mainchain tokens\\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\\n _setLockedThresholds(_addresses[0], _thresholds[1]);\\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\\n }\\n\\n // Grant role for withdrawal unlocker\\n for (uint256 _i; _i < _addresses[2].length; ) {\\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\\n }\\n\\n /**\\n * @dev Receives ether without doing anything. Use this function to topup native token.\\n */\\n function receiveEther() external payable {}\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\\n return _domainSeparator;\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\\n _setWrappedNativeTokenContract(_wrappedToken);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\\n _requestDepositFor(_request, msg.sender);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function submitWithdrawal(\\n Transfer.Receipt calldata _receipt,\\n Signature[] calldata _signatures\\n ) external virtual whenNotPaused returns (bool _locked) {\\n return _submitWithdrawal(_receipt, _signatures);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\\n bytes32 _receiptHash = _receipt.hash();\\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\\n revert ErrInvalidReceipt();\\n }\\n if (!withdrawalLocked[_receipt.id]) {\\n revert ErrQueryForApprovedWithdrawal();\\n }\\n delete withdrawalLocked[_receipt.id];\\n emit WithdrawalUnlocked(_receiptHash, _receipt);\\n\\n address _token = _receipt.mainchain.tokenAddr;\\n if (_receipt.info.erc == Token.Standard.ERC20) {\\n Token.Info memory _feeInfo = _receipt.info;\\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\\n Token.Info memory _withdrawInfo = _receipt.info;\\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\\n\\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\\n } else {\\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\\n }\\n\\n emit Withdrew(_receiptHash, _receipt);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function mapTokens(\\n address[] calldata _mainchainTokens,\\n address[] calldata _roninTokens,\\n Token.Standard[] calldata _standards\\n ) external virtual onlyAdmin {\\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function mapTokensAndThresholds(\\n address[] calldata _mainchainTokens,\\n address[] calldata _roninTokens,\\n Token.Standard[] calldata _standards,\\n // _thresholds[0]: highTierThreshold\\n // _thresholds[1]: lockedThreshold\\n // _thresholds[2]: unlockFeePercentages\\n // _thresholds[3]: dailyWithdrawalLimit\\n uint256[][4] calldata _thresholds\\n ) external virtual onlyAdmin {\\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\\n }\\n\\n /**\\n * @inheritdoc IMainchainGatewayV3\\n */\\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\\n _token = _roninToken[_mainchainToken];\\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\\n }\\n\\n /**\\n * @dev Maps mainchain tokens to Ronin network.\\n *\\n * Requirement:\\n * - The arrays have the same length.\\n *\\n * Emits the `TokenMapped` event.\\n *\\n */\\n function _mapTokens(\\n address[] calldata _mainchainTokens,\\n address[] calldata _roninTokens,\\n Token.Standard[] calldata _standards\\n ) internal virtual {\\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\\n revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _mainchainTokens.length; ) {\\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\\n }\\n\\n /**\\n * @dev Submits withdrawal receipt.\\n *\\n * Requirements:\\n * - The receipt kind is withdrawal.\\n * - The receipt is to withdraw on this chain.\\n * - The receipt is not used to withdraw before.\\n * - The withdrawal is not reached the limit threshold.\\n * - The signer weight total is larger than or equal to the minimum threshold.\\n * - The signature signers are in order.\\n *\\n * Emits the `Withdrew` once the assets are released.\\n *\\n */\\n function _submitWithdrawal(\\n Transfer.Receipt calldata _receipt,\\n Signature[] memory _signatures\\n ) internal virtual returns (bool _locked) {\\n uint256 _id = _receipt.id;\\n uint256 _quantity = _receipt.info.quantity;\\n address _tokenAddr = _receipt.mainchain.tokenAddr;\\n\\n _receipt.info.validate();\\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\\n\\n if (_receipt.mainchain.chainId != block.chainid) {\\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\\n }\\n\\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\\n\\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\\n\\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\\n\\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\\n revert ErrReachedDailyWithdrawalLimit();\\n }\\n\\n bytes32 _receiptHash = _receipt.hash();\\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\\n\\n uint256 _minimumVoteWeight;\\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\\n\\n {\\n bool _passed;\\n address _signer;\\n address _lastSigner;\\n Signature memory _sig;\\n uint256 _weight;\\n for (uint256 _i; _i < _signatures.length; ) {\\n _sig = _signatures[_i];\\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\\n\\n _lastSigner = _signer;\\n\\n _weight += _getWeight(_signer);\\n if (_weight >= _minimumVoteWeight) {\\n _passed = true;\\n break;\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\\n withdrawalHash[_id] = _receiptHash;\\n }\\n\\n if (_locked) {\\n withdrawalLocked[_id] = true;\\n emit WithdrawalLocked(_receiptHash, _receipt);\\n return _locked;\\n }\\n\\n _recordWithdrawal(_tokenAddr, _quantity);\\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\\n emit Withdrew(_receiptHash, _receipt);\\n }\\n\\n /**\\n * @dev Requests deposit made by `_requester` address.\\n *\\n * Requirements:\\n * - The token info is valid.\\n * - The `msg.value` is 0 while depositing ERC20 token.\\n * - The `msg.value` is equal to deposit quantity while depositing native token.\\n *\\n * Emits the `DepositRequested` event.\\n *\\n */\\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\\n MappedToken memory _token;\\n address _weth = address(wrappedNativeToken);\\n\\n _request.info.validate();\\n if (_request.tokenAddr == address(0)) {\\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\\n\\n _token = getRoninToken(_weth);\\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\\n\\n _request.tokenAddr = _weth;\\n } else {\\n if (msg.value != 0) revert ErrInvalidRequest();\\n\\n _token = getRoninToken(_request.tokenAddr);\\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\\n\\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\\n // Withdraw if token is WETH\\n if (_weth == _request.tokenAddr) {\\n IWETH(_weth).withdraw(_request.info.quantity);\\n }\\n }\\n\\n uint256 _depositId = depositCount++;\\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\\n _requester,\\n _depositId,\\n _token.tokenAddr,\\n roninChainId\\n );\\n\\n emit DepositRequested(_receipt.hash(), _receipt);\\n }\\n\\n /**\\n * @dev Returns the minimum vote weight for the token.\\n */\\n function _computeMinVoteWeight(\\n Token.Standard _erc,\\n address _token,\\n uint256 _quantity\\n ) internal virtual returns (uint256 _weight, bool _locked) {\\n uint256 _totalWeight = _getTotalWeight();\\n _weight = _minimumVoteWeight(_totalWeight);\\n if (_erc == Token.Standard.ERC20) {\\n if (highTierThreshold[_token] <= _quantity) {\\n _weight = _highTierVoteWeight(_totalWeight);\\n }\\n _locked = _lockedWithdrawalRequest(_token, _quantity);\\n }\\n }\\n\\n /**\\n * @dev Update domain seperator.\\n */\\n function _updateDomainSeparator() internal {\\n /*\\n * _domainSeparator = keccak256(\\n * abi.encode(\\n * keccak256(\\\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\\\"),\\n * keccak256(\\\"MainchainGatewayV2\\\"),\\n * keccak256(\\\"2\\\"),\\n * block.chainid,\\n * address(this)\\n * )\\n * );\\n */\\n assembly {\\n let ptr := mload(0x40)\\n // keccak256(\\\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\\\")\\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\\n // keccak256(\\\"MainchainGatewayV2\\\")\\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\\n // keccak256(\\\"2\\\")\\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\\n mstore(add(ptr, 0x60), chainid())\\n mstore(add(ptr, 0x80), address())\\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\\n }\\n }\\n\\n /**\\n * @dev Sets the WETH contract.\\n *\\n * Emits the `WrappedNativeTokenContractUpdated` event.\\n *\\n */\\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\\n wrappedNativeToken = _wrapedToken;\\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\\n }\\n\\n /**\\n * @dev Receives ETH from WETH or creates deposit request.\\n */\\n function _fallback() internal virtual whenNotPaused {\\n if (msg.sender != address(wrappedNativeToken)) {\\n Transfer.Request memory _request;\\n _request.recipientAddr = msg.sender;\\n _request.info.quantity = msg.value;\\n _requestDepositFor(_request, _request.recipientAddr);\\n }\\n }\\n\\n /**\\n * @inheritdoc GatewayV3\\n */\\n function _getTotalWeight() internal view override returns (uint256) {\\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\\n }\\n\\n /**\\n * @dev Returns the weight of an address.\\n */\\n function _getWeight(address _addr) internal view returns (uint256) {\\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x5081ea8d3ae575c55c344ea48edebbd5726fb459bfbcd27914e9a4bf6da57896\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b506000805460ff191690556147378061002a6000396000f3fe60806040526004361061031e5760003560e01c8063865e6fd3116101ab578063b1d08a03116100f7578063d55ed10311610095578063de981f1b1161006f578063de981f1b14610999578063dff525e1146109b9578063e400327c146109d9578063e75235b8146109f95761032d565b8063d55ed1031461092c578063d64af2a614610959578063dafae408146109795761032d565b8063ca15c873116100d1578063ca15c873146108a7578063cdb67444146108c7578063d19773d2146108df578063d547741f1461090c5761032d565b8063b1d08a031461082d578063b29757941461085a578063b9c36209146108875761032d565b80639dcc4da311610164578063ab7965661161013e578063ab796566146107aa578063ac78dfe8146107d7578063affed0e0146107f7578063b1a2567e1461080d5761032d565b80639dcc4da314610760578063a217fddf14610795578063a3912ec81461032b5761032d565b8063865e6fd31461068c5780638f34e347146106ac5780639010d07c146106e05780639157921c1461070057806391d148541461072057806393c5678f146107405761032d565b806336568abe1161026a578063504af48c116102235780636932be98116101fd5780636932be98146106155780636c1ce670146106425780637de5dedd146106625780638456cb59146106775761032d565b8063504af48c146105bd57806359122f6b146105d05780635c975abb146105fd5761032d565b806336568abe146105055780633e70838b146105255780633f4ba83a146105455780634b14557e1461055a5780634d0d66731461056d5780634d493f4e1461058d5761032d565b80631d4a7210116102d75780632dfdf0b5116102b15780632dfdf0b5146104a35780632f2ff15d146104b9578063302d12db146104d95780633644e515146104f05761032d565b80631d4a721014610426578063248a9ca31461045357806329b6eca9146104835761032d565b806301ffc9a714610335578063065b3adf1461036a57806317ce2dd4146103a257806317fcb39b146103c65780631a8e55b0146103e65780631b6e7594146104065761032d565b3661032d5761032b610a11565b005b61032b610a11565b34801561034157600080fd5b506103556103503660046138ea565b610a51565b60405190151581526020015b60405180910390f35b34801561037657600080fd5b5060055461038a906001600160a01b031681565b6040516001600160a01b039091168152602001610361565b3480156103ae57600080fd5b506103b860755481565b604051908152602001610361565b3480156103d257600080fd5b5060745461038a906001600160a01b031681565b3480156103f257600080fd5b5061032b610401366004613959565b610a7c565b34801561041257600080fd5b5061032b6104213660046139c5565b610ab8565b34801561043257600080fd5b506103b8610441366004613a7f565b603e6020526000908152604090205481565b34801561045f57600080fd5b506103b861046e366004613a9c565b60009081526072602052604090206001015490565b34801561048f57600080fd5b5061032b61049e366004613a7f565b610af8565b3480156104af57600080fd5b506103b860765481565b3480156104c557600080fd5b5061032b6104d4366004613ab5565b610ba3565b3480156104e557600080fd5b506103b8620f424081565b3480156104fc57600080fd5b506077546103b8565b34801561051157600080fd5b5061032b610520366004613ab5565b610bcd565b34801561053157600080fd5b5061032b610540366004613a7f565b610c4b565b34801561055157600080fd5b5061032b610c75565b61032b610568366004613ae5565b610c85565b34801561057957600080fd5b50610355610588366004613b10565b610ca5565b34801561059957600080fd5b506103556105a8366004613a9c565b607a6020526000908152604090205460ff1681565b61032b6105cb366004613bbb565b610d13565b3480156105dc57600080fd5b506103b86105eb366004613a7f565b603a6020526000908152604090205481565b34801561060957600080fd5b5060005460ff16610355565b34801561062157600080fd5b506103b8610630366004613a9c565b60796020526000908152604090205481565b34801561064e57600080fd5b5061035561065d366004613c96565b610fed565b34801561066e57600080fd5b506103b8611000565b34801561068357600080fd5b5061032b611017565b34801561069857600080fd5b5061032b6106a7366004613cd1565b611027565b3480156106b857600080fd5b506103b87f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e481565b3480156106ec57600080fd5b5061038a6106fb366004613cfd565b611042565b34801561070c57600080fd5b5061032b61071b366004613d1f565b61105a565b34801561072c57600080fd5b5061035561073b366004613ab5565b6112de565b34801561074c57600080fd5b5061032b61075b366004613959565b611309565b34801561076c57600080fd5b5061078061077b366004613cfd565b61133f565b60408051928352602083019190915201610361565b3480156107a157600080fd5b506103b8600081565b3480156107b657600080fd5b506103b86107c5366004613a7f565b603c6020526000908152604090205481565b3480156107e357600080fd5b506103556107f2366004613a9c565b611368565b34801561080357600080fd5b506103b860045481565b34801561081957600080fd5b5061032b610828366004613959565b611394565b34801561083957600080fd5b506103b8610848366004613a7f565b60396020526000908152604090205481565b34801561086657600080fd5b5061087a610875366004613a7f565b6113ca565b6040516103619190613d62565b34801561089357600080fd5b506107806108a2366004613cfd565b61146d565b3480156108b357600080fd5b506103b86108c2366004613a9c565b611482565b3480156108d357600080fd5b50603754603854610780565b3480156108eb57600080fd5b506103b86108fa366004613a7f565b603b6020526000908152604090205481565b34801561091857600080fd5b5061032b610927366004613ab5565b611499565b34801561093857600080fd5b506103b8610947366004613a7f565b603d6020526000908152604090205481565b34801561096557600080fd5b5061032b610974366004613a7f565b6114be565b34801561098557600080fd5b50610355610994366004613a9c565b6114cf565b3480156109a557600080fd5b5061038a6109b4366004613d8e565b6114f3565b3480156109c557600080fd5b5061032b6109d4366004613da9565b611569565b3480156109e557600080fd5b5061032b6109f4366004613959565b6115de565b348015610a0557600080fd5b50600154600254610780565b610a19611614565b6074546001600160a01b03163314610a4f57610a336138a9565b338152604080820151349101528051610a4d90829061165a565b505b565b60006001600160e01b03198216635a05180f60e01b1480610a765750610a76826118bb565b92915050565b610a846118f0565b6000839003610aa6576040516316ee9d3b60e11b815260040160405180910390fd5b610ab28484848461194a565b50505050565b610ac06118f0565b6000859003610ae2576040516316ee9d3b60e11b815260040160405180910390fd5b610af0868686868686611a1f565b505050505050565b607154600290610100900460ff16158015610b1a575060715460ff8083169116105b610b3f5760405162461bcd60e51b8152600401610b3690613e67565b60405180910390fd5b6071805461ffff191660ff831617610100179055610b5e600b83611bb6565b6071805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b600082815260726020526040902060010154610bbe81611c5a565b610bc88383611c64565b505050565b6001600160a01b0381163314610c3d5760405162461bcd60e51b815260206004820152602f60248201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560448201526e103937b632b9903337b91039b2b63360891b6064820152608401610b36565b610c478282611c86565b5050565b610c536118f0565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b610c7d611ca8565b610a4f611d17565b610c8d611614565b610a4d610c9f36839003830183613f54565b3361165a565b6000610caf611614565b610d0b848484808060200260200160405190810160405280939291908181526020016000905b82821015610d0157610cf260608302860136819003810190613fa7565b81526020019060010190610cd5565b5050505050611d69565b949350505050565b607154610100900460ff1615808015610d335750607154600160ff909116105b80610d4d5750303b158015610d4d575060715460ff166001145b610d695760405162461bcd60e51b8152600401610b3690613e67565b6071805460ff191660011790558015610d8c576071805461ff0019166101001790555b610d9760008c6121d3565b6075899055610da58a6121dd565b610e306040517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81527f159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b60208201527fad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5604082015246606082015230608082015260a0812060775550565b610e3a8887612231565b5050610e4687876122c8565b5050610e50612355565b6000610e5c8680614033565b90501115610f1d57610e85610e718680614033565b610e7e6020890189614033565b8787611a1f565b610eab610e928680614033565b8660005b602002810190610ea69190614033565b6123a2565b610ed1610eb88680614033565b8660015b602002810190610ecc9190614033565b61194a565b610ef7610ede8680614033565b8660025b602002810190610ef29190614033565b612477565b610f1d610f048680614033565b8660035b602002810190610f189190614033565b612588565b60005b610f2d6040870187614033565b9050811015610f9957610f917f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4610f676040890189614033565b84818110610f7757610f7761401d565b9050602002016020810190610f8c9190613a7f565b611c64565b600101610f20565b508015610fe0576071805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050505050565b6000610ff9838361265d565b9392505050565b600061101261100d612721565b61278e565b905090565b61101f611ca8565b610a4f6127c4565b61102f6118f0565b61103881612801565b610c478282611bb6565b6000828152607360205260408120610ff99083612837565b7f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e461108481611c5a565b600061109d611098368590038501856140cb565b612843565b90506110b1611098368590038501856140cb565b8335600090815260796020526040902054146110e05760405163f4b8742f60e01b815260040160405180910390fd5b82356000908152607a602052604090205460ff166111115760405163147bfe0760e01b815260040160405180910390fd5b82356000908152607a602052604090819020805460ff19169055517fd639511b37b3b002cca6cfe6bca0d833945a5af5a045578a0627fc43b79b26309061115b908390869061419f565b60405180910390a160006111756080850160608601613a7f565b9050600061118b6101208601610100870161422c565b600181111561119c5761119c613d3c565b036112635760006111b63686900386016101008701614249565b6001600160a01b0383166000908152603b60205260409020549091506111e2906101408701359061290d565b604082015260006111fc3687900387016101008801614249565b60408301519091506112139061014088013561427b565b6040820152607454611233908390339086906001600160a01b0316612927565b61125c6112466060880160408901613a7f565b60745483919086906001600160a01b0316612927565b505061129f565b61129f6112766060860160408701613a7f565b60745483906001600160a01b03166112973689900389016101008a01614249565b929190612927565b7f21e88e956aa3e086f6388e899965cef814688f99ad8bb29b08d396571016372d82856040516112d092919061419f565b60405180910390a150505050565b60009182526072602090815260408084206001600160a01b0393909316845291905290205460ff1690565b6113116118f0565b6000839003611333576040516316ee9d3b60e11b815260040160405180910390fd5b610ab2848484846123a2565b60008061134a6118f0565b61135484846122c8565b9092509050611361612355565b9250929050565b6000611372612721565b60375461137f919061428e565b60385461138c908461428e565b101592915050565b61139c6118f0565b60008390036113be576040516316ee9d3b60e11b815260040160405180910390fd5b610ab284848484612477565b60408051808201909152600080825260208201526001600160a01b0382166000908152607860205260409081902081518083019092528054829060ff16600181111561141857611418613d3c565b600181111561142957611429613d3c565b815290546001600160a01b036101009091048116602092830152908201519192501661146857604051631b79f53b60e21b815260040160405180910390fd5b919050565b6000806114786118f0565b6113548484612231565b6000818152607360205260408120610a7690612c63565b6000828152607260205260409020600101546114b481611c5a565b610bc88383611c86565b6114c66118f0565b610a4d816121dd565b60006114d9612721565b6001546114e6919061428e565b60025461138c908461428e565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561152a5761152a613d3c565b60ff1681526020810191909152604001600020546001600160a01b0316905080611468578160405163409140df60e11b8152600401610b3691906142a5565b6115716118f0565b6000869003611593576040516316ee9d3b60e11b815260040160405180910390fd5b6115a1878787878787611a1f565b6115ae8787836000610e96565b6115bb8787836001610ebc565b6115c88787836002610ee2565b6115d58787836003610f08565b50505050505050565b6115e66118f0565b6000839003611608576040516316ee9d3b60e11b815260040160405180910390fd5b610ab284848484612588565b60005460ff1615610a4f5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610b36565b604080518082018252600080825260208201526074549184015190916001600160a01b03169061168990612c6d565b60208401516001600160a01b031661172a5734846040015160400151146116c35760405163129c2ce160e31b815260040160405180910390fd5b6116cc816113ca565b60408501515190925060018111156116e6576116e6613d3c565b825160018111156116f9576116f9613d3c565b146117165760405162035e2b60ea1b815260040160405180910390fd5b6001600160a01b0381166020850152611838565b34156117495760405163129c2ce160e31b815260040160405180910390fd5b61175684602001516113ca565b604085015151909250600181111561177057611770613d3c565b8251600181111561178357611783613d3c565b146117a05760405162035e2b60ea1b815260040160405180910390fd5b602084015160408501516117b79185903090612ce8565b83602001516001600160a01b0316816001600160a01b031603611838576040848101518101519051632e1a7d4d60e01b815260048101919091526001600160a01b03821690632e1a7d4d90602401600060405180830381600087803b15801561181f57600080fd5b505af1158015611833573d6000803e3d6000fd5b505050505b6076805460009182611849836142bf565b9190505590506000611870858386602001516075548a612ec990949392919063ffffffff16565b90507fd7b25068d9dc8d00765254cfb7f5070f98d263c8d68931d937c7362fa738048b61189c82612843565b826040516118ab9291906142fa565b60405180910390a1505050505050565b60006001600160e01b03198216637965db0b60e01b1480610a7657506301ffc9a760e01b6001600160e01b0319831614610a76565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610a4f576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b36929190614398565b828114611978576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b838110156119e9578282828181106119955761199561401d565b90506020020135603a60008787858181106119b2576119b261401d565b90506020020160208101906119c79190613a7f565b6001600160a01b0316815260208101919091526040016000205560010161197b565b507f64557254143204d91ba2d95acb9fda1e5fea55f77efd028685765bc1e94dd4b5848484846040516112d09493929190614424565b8483148015611a2d57508481145b611a58576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b85811015611b7c57848482818110611a7557611a7561401d565b9050602002016020810190611a8a9190613a7f565b60786000898985818110611aa057611aa061401d565b9050602002016020810190611ab59190613a7f565b6001600160a01b03908116825260208201929092526040016000208054610100600160a81b0319166101009390921692909202179055828282818110611afd57611afd61401d565b9050602002016020810190611b12919061422c565b60786000898985818110611b2857611b2861401d565b9050602002016020810190611b3d9190613a7f565b6001600160a01b031681526020810191909152604001600020805460ff191660018381811115611b6f57611b6f613d3c565b0217905550600101611a5b565b507fa4f03cc9c0e0aeb5b71b4ec800702753f65748c2cf3064695ba8e8b46be704448686868686866040516118ab96959493929190614470565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115611bec57611bec613d3c565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115611c2d57611c2d613d3c565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610a4d8133612f9e565b611c6e8282613002565b6000828152607360205260409020610bc89082613088565b611c90828261309d565b6000828152607360205260409020610bc89082613104565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b0316331480611cea57506005546001600160a01b031633145b610a4f576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b36929190614398565b611d1f613119565b6000805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b6000823561014084013582611d846080870160608801613a7f565b9050611da1611d9c3688900388016101008901614249565b612c6d565b6001611db3604088016020890161422c565b6001811115611dc457611dc4613d3c565b14611de25760405163182f3d8760e11b815260040160405180910390fd5b60808601354614611e245760405163092048d160e11b81526000356001600160e01b031916600482015260808701356024820152466044820152606401610b36565b6000611e396108756080890160608a01613a7f565b9050611e4d6101208801610100890161422c565b6001811115611e5e57611e5e613d3c565b81516001811115611e7157611e71613d3c565b148015611ea25750611e8960e0880160c08901613a7f565b6001600160a01b031681602001516001600160a01b0316145b611ebf5760405163f4b8742f60e01b815260040160405180910390fd5b60008481526079602052604090205415611eec57604051634f13df6160e01b815260040160405180910390fd5b6001611f0061012089016101008a0161422c565b6001811115611f1157611f11613d3c565b1480611f245750611f22828461265d565b155b611f415760405163c51297b760e01b815260040160405180910390fd5b6000611f55611098368a90038a018a6140cb565b90506000611f6560775483613162565b90506000611f85611f7e6101208c016101008d0161422c565b86886131a3565b60408051606081018252600080825260208201819052918101829052919a50919250819081906000805b8e518110156120aa578e8181518110611fca57611fca61401d565b6020908102919091018101518051818301516040808401518151600081529586018083528e905260ff9093169085015260608401526080830152935060019060a0016020604051602081039080840390855afa15801561202e573d6000803e3d6000fd5b505050602060405103519450846001600160a01b0316846001600160a01b03161061207a576000356001600160e01b031916604051635d3dcd3160e01b8152600401610b3691906143c6565b84935061208685613229565b61209090836144e8565b91508682106120a257600195506120aa565b600101611faf565b50846120c957604051639e8f5f6360e01b815260040160405180910390fd5b505050600089815260796020526040902085905550508715612144576000878152607a602052604090819020805460ff19166001179055517f89e52969465b1f1866fc5d46fd62de953962e9cb33552443cd999eba05bd20dc906121309085908d9061419f565b60405180910390a150505050505050610a76565b61214e85876132b5565b61218d61216160608c0160408d01613a7f565b86607460009054906101000a90046001600160a01b03168d610100018036038101906112979190614249565b7f21e88e956aa3e086f6388e899965cef814688f99ad8bb29b08d396571016372d838b6040516121be92919061419f565b60405180910390a15050505050505092915050565b610c478282611c64565b607480546001600160a01b0319166001600160a01b0383169081179091556040519081527f9d2334c23be647e994f27a72c5eee42a43d5bdcfe15bb88e939103c2b114cbaf9060200160405180910390a150565b60008082841115612263576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f891015b60405180910390a49250929050565b600080828411156122fa576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b5050603780546038805492859055839055600480546001810190915560408051838152602081018590529293928592879290917f31312c97b89cc751b832d98fd459b967a2c3eef3b49757d1cf5ebaa12bb6eee191016122b9565b600254603754612365919061428e565b603854600154612375919061428e565b1115610a4f576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b8281146123d0576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b83811015612441578282828181106123ed576123ed61401d565b905060200201356039600087878581811061240a5761240a61401d565b905060200201602081019061241f9190613a7f565b6001600160a01b031681526020810191909152604001600020556001016123d3565b507f80bc635c452ae67f12f9b6f12ad4daa6dbbc04eeb9ebb87d354ce10c0e210dc0848484846040516112d09493929190614424565b8281146124a5576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b8381101561255257620f42408383838181106124c6576124c661401d565b9050602002013511156124ec5760405163572d3bd360e11b815260040160405180910390fd5b8282828181106124fe576124fe61401d565b90506020020135603b600087878581811061251b5761251b61401d565b90506020020160208101906125309190613a7f565b6001600160a01b031681526020810191909152604001600020556001016124a8565b507fb05f5de88ae0294ebb6f67c5af2fcbbd593cc6bdfe543e2869794a4c8ce3ea50848484846040516112d09493929190614424565b8281146125b6576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b83811015612627578282828181106125d3576125d361401d565b90506020020135603c60008787858181106125f0576125f061401d565b90506020020160208101906126059190613a7f565b6001600160a01b031681526020810191909152604001600020556001016125b9565b507fb5d2963614d72181b4df1f993d45b83edf42fa19710f0204217ba1b3e183bb73848484846040516112d09493929190614424565b6001600160a01b0382166000908152603a6020526040812054821061268457506000610a76565b600061269362015180426144fb565b6001600160a01b0385166000908152603e60205260409020549091508111156126d95750506001600160a01b0382166000908152603c6020526040902054811015610a76565b6001600160a01b0384166000908152603d60205260409020546126fd9084906144e8565b6001600160a01b0385166000908152603c602052604090205411159150610a769050565b600061272d600b6114f3565b6001600160a01b03166306aba0e16040518163ffffffff1660e01b8152600401602060405180830381865afa15801561276a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611012919061451d565b60006002546001600254846001546127a6919061428e565b6127b091906144e8565b6127ba919061427b565b610a7691906144fb565b6127cc611614565b6000805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a258611d4c3390565b806001600160a01b03163b600003610a4d57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610b36565b6000610ff98383613345565b600080612853836040015161336f565b90506000612864846060015161336f565b905060006128b88560800151604080517f1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d815282516020808301919091528301518183015291015160608201526080902090565b604080517fb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea815287516020808301919091529097015190870152606086019390935250608084015260a08301525060c0902090565b6000620f424061291d838561428e565b610ff991906144fb565b6000816001600160a01b0316836001600160a01b0316036129d65760408086015190516001600160a01b0386169180156108fc02916000818181858888f193505050506129d157816001600160a01b031663d0e30db086604001516040518263ffffffff1660e01b81526004016000604051808303818588803b1580156129ad57600080fd5b505af11580156129c1573d6000803e3d6000fd5b50505050506129d18585856133b7565b612c5c565b6000855160018111156129eb576129eb613d3c565b03612b54576040516370a0823160e01b81523060048201526000906001600160a01b038516906370a0823190602401602060405180830381865afa158015612a37573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a5b919061451d565b90508560400151811015612b4357836001600160a01b03166340c10f1930838960400151612a89919061427b565b6040516001600160a01b03909216602483015260448201526064016040516020818303038152906040529060e01b6020820180516001600160e01b038381831617835250505050604051612add919061455a565b6000604051808303816000865af19150503d8060008114612b1a576040519150601f19603f3d011682016040523d82523d6000602084013e612b1f565b606091505b50508092505081612b4357604051632f739fff60e11b815260040160405180910390fd5b612b4e8686866133b7565b50612c5c565b600185516001811115612b6957612b69613d3c565b03612c4357612b7d83858760200151613435565b6129d157602085810151604080516001600160a01b038881166024830152604480830194909452825180830390940184526064909101825292820180516001600160e01b03166340c10f1960e01b1790525191851691612bdd919061455a565b6000604051808303816000865af19150503d8060008114612c1a576040519150601f19603f3d011682016040523d82523d6000602084013e612c1f565b606091505b505080915050806129d15760405163c8e3a09f60e01b815260040160405180910390fd5b6040516361e411a760e11b815260040160405180910390fd5b5050505050565b6000610a76825490565b600081516001811115612c8257612c82613d3c565b148015612c93575060008160400151115b8015612ca157506020810151155b80612ccb5750600181516001811115612cbc57612cbc613d3c565b148015612ccb57506040810151155b610a4d5760405163034992a760e51b815260040160405180910390fd5b600060608186516001811115612d0057612d00613d3c565b03612ddd5760408681015181516001600160a01b038881166024830152878116604483015260648083019390935283518083039093018352608490910183526020820180516001600160e01b03166323b872dd60e01b179052915191851691612d69919061455a565b6000604051808303816000865af19150503d8060008114612da6576040519150601f19603f3d011682016040523d82523d6000602084013e612dab565b606091505b509092509050818015612dd6575080511580612dd6575080806020019051810190612dd69190614576565b9150612ea3565b600186516001811115612df257612df2613d3c565b03612c4357602086810151604080516001600160a01b0389811660248301528881166044830152606480830194909452825180830390940184526084909101825292820180516001600160e01b03166323b872dd60e01b1790525191851691612e5b919061455a565b6000604051808303816000865af19150503d8060008114612e98576040519150601f19603f3d011682016040523d82523d6000602084013e612e9d565b606091505b50909250505b81610af05785858585604051639d2e4c6760e01b8152600401610b369493929190614598565b612f396040805160a08101825260008082526020808301829052835160608082018652838252818301849052818601849052848601919091528451808201865283815280830184905280860184905281850152845190810185528281529081018290529283015290608082015290565b83815260006020820181905250604080820180516001600160a01b039788169052602080890151825190891690820152905146908301528751606084018051918916909152805195909716940193909352935182015292909201516080820152919050565b612fa882826112de565b610c4757612fc0816001600160a01b031660146134e0565b612fcb8360206134e0565b604051602001612fdc9291906145ce565b60408051601f198184030181529082905262461bcd60e51b8252610b3691600401614643565b61300c82826112de565b610c475760008281526072602090815260408083206001600160a01b03851684529091529020805460ff191660011790556130443390565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b6000610ff9836001600160a01b03841661367c565b6130a782826112de565b15610c475760008281526072602090815260408083206001600160a01b0385168085529252808320805460ff1916905551339285917ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b9190a45050565b6000610ff9836001600160a01b0384166136cb565b60005460ff16610a4f5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610b36565b6040805161190160f01b6020808301919091526022820185905260428083018590528351808403909101815260629092019092528051910120600090610ff9565b60008060006131b0612721565b90506131bb8161278e565b925060008660018111156131d1576131d1613d3c565b03613220576001600160a01b0385166000908152603960205260409020548410613201576131fe816137be565b92505b6001600160a01b0385166000908152603a602052604090205484101591505b50935093915050565b6000613235600b6114f3565b60405163901979d560e01b81526001600160a01b038481166004830152919091169063901979d590602401602060405180830381865afa15801561327d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906132a19190614676565b6bffffffffffffffffffffffff1692915050565b60006132c462015180426144fb565b6001600160a01b0384166000908152603e6020526040902054909150811115613313576001600160a01b03929092166000908152603e6020908152604080832094909455603d90529190912055565b6001600160a01b0383166000908152603d60205260408120805484929061333b9084906144e8565b9091555050505050565b600082600001828154811061335c5761335c61401d565b9060005260206000200154905092915050565b604080517f353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764815282516020808301919091528301518183015291015160608201526080902090565b600080845160018111156133cd576133cd613d3c565b036133e8576133e1828486604001516137d6565b9050613411565b6001845160018111156133fd576133fd613d3c565b03612c43576133e182848660200151613435565b80610ab2578383836040516341bd7d9160e11b8152600401610b36939291906146a4565b604080513060248201526001600160a01b038481166044830152606480830185905283518084039091018152608490920183526020820180516001600160e01b03166323b872dd60e01b17905291516000928616916134939161455a565b6000604051808303816000865af19150503d80600081146134d0576040519150601f19603f3d011682016040523d82523d6000602084013e6134d5565b606091505b509095945050505050565b606060006134ef83600261428e565b6134fa9060026144e8565b67ffffffffffffffff81111561351257613512613eb5565b6040519080825280601f01601f19166020018201604052801561353c576020820181803683370190505b509050600360fc1b816000815181106135575761355761401d565b60200101906001600160f81b031916908160001a905350600f60fb1b816001815181106135865761358661401d565b60200101906001600160f81b031916908160001a90535060006135aa84600261428e565b6135b59060016144e8565b90505b600181111561362d576f181899199a1a9b1b9c1cb0b131b232b360811b85600f16601081106135e9576135e961401d565b1a60f81b8282815181106135ff576135ff61401d565b60200101906001600160f81b031916908160001a90535060049490941c93613626816146d4565b90506135b8565b508315610ff95760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610b36565b60008181526001830160205260408120546136c357508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610a76565b506000610a76565b600081815260018301602052604081205480156137b45760006136ef60018361427b565b85549091506000906137039060019061427b565b90508181146137685760008660000182815481106137235761372361401d565b90600052602060002001549050808760000184815481106137465761374661401d565b6000918252602080832090910192909255918252600188019052604090208390555b8554869080613779576137796146eb565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610a76565b6000915050610a76565b60006038546001603854846037546127a6919061428e565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663a9059cbb60e01b179052915160009260609290871691613833919061455a565b6000604051808303816000865af19150503d8060008114613870576040519150601f19603f3d011682016040523d82523d6000602084013e613875565b606091505b5090925090508180156138a05750805115806138a05750808060200190518101906138a09190614576565b95945050505050565b60408051606081018252600080825260208201529081016138e56040805160608101909152806000815260200160008152602001600081525090565b905290565b6000602082840312156138fc57600080fd5b81356001600160e01b031981168114610ff957600080fd5b60008083601f84011261392657600080fd5b50813567ffffffffffffffff81111561393e57600080fd5b6020830191508360208260051b850101111561136157600080fd5b6000806000806040858703121561396f57600080fd5b843567ffffffffffffffff8082111561398757600080fd5b61399388838901613914565b909650945060208701359150808211156139ac57600080fd5b506139b987828801613914565b95989497509550505050565b600080600080600080606087890312156139de57600080fd5b863567ffffffffffffffff808211156139f657600080fd5b613a028a838b01613914565b90985096506020890135915080821115613a1b57600080fd5b613a278a838b01613914565b90965094506040890135915080821115613a4057600080fd5b50613a4d89828a01613914565b979a9699509497509295939492505050565b6001600160a01b0381168114610a4d57600080fd5b803561146881613a5f565b600060208284031215613a9157600080fd5b8135610ff981613a5f565b600060208284031215613aae57600080fd5b5035919050565b60008060408385031215613ac857600080fd5b823591506020830135613ada81613a5f565b809150509250929050565b600060a08284031215613af757600080fd5b50919050565b60006101608284031215613af757600080fd5b60008060006101808486031215613b2657600080fd5b613b308585613afd565b925061016084013567ffffffffffffffff80821115613b4e57600080fd5b818601915086601f830112613b6257600080fd5b813581811115613b7157600080fd5b876020606083028501011115613b8657600080fd5b6020830194508093505050509250925092565b8060608101831015610a7657600080fd5b8060808101831015610a7657600080fd5b6000806000806000806000806000806101208b8d031215613bdb57600080fd5b613be48b613a74565b9950613bf260208c01613a74565b985060408b0135975060608b0135965060808b0135955060a08b0135945060c08b013567ffffffffffffffff80821115613c2b57600080fd5b613c378e838f01613b99565b955060e08d0135915080821115613c4d57600080fd5b613c598e838f01613baa565b94506101008d0135915080821115613c7057600080fd5b50613c7d8d828e01613914565b915080935050809150509295989b9194979a5092959850565b60008060408385031215613ca957600080fd5b8235613cb481613a5f565b946020939093013593505050565b80356010811061146857600080fd5b60008060408385031215613ce457600080fd5b613ced83613cc2565b91506020830135613ada81613a5f565b60008060408385031215613d1057600080fd5b50508035926020909101359150565b60006101608284031215613d3257600080fd5b610ff98383613afd565b634e487b7160e01b600052602160045260246000fd5b60028110610a4d57610a4d613d3c565b81516040820190613d7281613d52565b82526020928301516001600160a01b0316929091019190915290565b600060208284031215613da057600080fd5b610ff982613cc2565b60008060008060008060006080888a031215613dc457600080fd5b873567ffffffffffffffff80821115613ddc57600080fd5b613de88b838c01613914565b909950975060208a0135915080821115613e0157600080fd5b613e0d8b838c01613914565b909750955060408a0135915080821115613e2657600080fd5b613e328b838c01613914565b909550935060608a0135915080821115613e4b57600080fd5b50613e588a828b01613baa565b91505092959891949750929550565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b6040516060810167ffffffffffffffff81118282101715613efc57634e487b7160e01b600052604160045260246000fd5b60405290565b60028110610a4d57600080fd5b600060608284031215613f2157600080fd5b613f29613ecb565b90508135613f3681613f02565b80825250602082013560208201526040820135604082015292915050565b600060a08284031215613f6657600080fd5b613f6e613ecb565b8235613f7981613a5f565b81526020830135613f8981613a5f565b6020820152613f9b8460408501613f0f565b60408201529392505050565b600060608284031215613fb957600080fd5b6040516060810181811067ffffffffffffffff82111715613fea57634e487b7160e01b600052604160045260246000fd5b604052823560ff81168114613ffe57600080fd5b8152602083810135908201526040928301359281019290925250919050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261404a57600080fd5b83018035915067ffffffffffffffff82111561406557600080fd5b6020019150600581901b360382131561136157600080fd5b60006060828403121561408f57600080fd5b614097613ecb565b905081356140a481613a5f565b815260208201356140b481613a5f565b806020830152506040820135604082015292915050565b600061016082840312156140de57600080fd5b60405160a0810181811067ffffffffffffffff8211171561410f57634e487b7160e01b600052604160045260246000fd5b60405282358152602083013561412481613f02565b6020820152614136846040850161407d565b60408201526141488460a0850161407d565b606082015261415b846101008501613f0f565b60808201529392505050565b803561417281613a5f565b6001600160a01b03908116835260208201359061418e82613a5f565b166020830152604090810135910152565b6000610180820190508382528235602083015260208301356141c081613f02565b6141c981613d52565b806040840152506141e06060830160408501614167565b6141f060c0830160a08501614167565b61012061010084013561420281613f02565b61420b81613d52565b81840152830135610140808401919091529092013561016090910152919050565b60006020828403121561423e57600080fd5b8135610ff981613f02565b60006060828403121561425b57600080fd5b610ff98383613f0f565b634e487b7160e01b600052601160045260246000fd5b81810381811115610a7657610a76614265565b8082028115828204841417610a7657610a76614265565b60208101601083106142b9576142b9613d3c565b91905290565b6000600182016142d1576142d1614265565b5060010190565b80516142e381613d52565b825260208181015190830152604090810151910152565b60006101808201905083825282516020830152602083015161431b81613d52565b6040838101919091528381015180516001600160a01b03908116606086015260208201511660808501529081015160a084015250606083015180516001600160a01b0390811660c085015260208201511660e084015260408101516101008401525060808301516143906101208401826142d8565b509392505050565b6001600160e01b03198316815260408101600b83106143b9576143b9613d3c565b8260208301529392505050565b6001600160e01b031991909116815260200190565b8183526000602080850194508260005b858110156144195781356143fe81613a5f565b6001600160a01b0316875295820195908201906001016143eb565b509495945050505050565b6040815260006144386040830186886143db565b82810360208401528381526001600160fb1b0384111561445757600080fd5b8360051b80866020840137016020019695505050505050565b60608152600061448460608301888a6143db565b60208382038185015261449882888a6143db565b8481036040860152858152869250810160005b868110156144d95783356144be81613f02565b6144c781613d52565b825292820192908201906001016144ab565b509a9950505050505050505050565b80820180821115610a7657610a76614265565b60008261451857634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561452f57600080fd5b5051919050565b60005b83811015614551578181015183820152602001614539565b50506000910152565b6000825161456c818460208701614536565b9190910192915050565b60006020828403121561458857600080fd5b81518015158114610ff957600080fd5b60c081016145a682876142d8565b6001600160a01b0394851660608301529284166080820152921660a090920191909152919050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000815260008351614606816017850160208801614536565b7001034b99036b4b9b9b4b733903937b6329607d1b6017918401918201528351614637816028840160208801614536565b01602801949350505050565b6020815260008251806020840152614662816040850160208701614536565b601f01601f19169190910160400192915050565b60006020828403121561468857600080fd5b81516bffffffffffffffffffffffff81168114610ff957600080fd5b60a081016146b282866142d8565b6001600160a01b03938416606083015291909216608090920191909152919050565b6000816146e3576146e3614265565b506000190190565b634e487b7160e01b600052603160045260246000fdfea264697066735822122067a7e41e0d11cc4f13027848a796f28bc789f50aade1ce98bb6b3473be92478464736f6c63430008110033", + "deployedBytecode": "0x60806040526004361061031e5760003560e01c8063865e6fd3116101ab578063b1d08a03116100f7578063d55ed10311610095578063de981f1b1161006f578063de981f1b14610999578063dff525e1146109b9578063e400327c146109d9578063e75235b8146109f95761032d565b8063d55ed1031461092c578063d64af2a614610959578063dafae408146109795761032d565b8063ca15c873116100d1578063ca15c873146108a7578063cdb67444146108c7578063d19773d2146108df578063d547741f1461090c5761032d565b8063b1d08a031461082d578063b29757941461085a578063b9c36209146108875761032d565b80639dcc4da311610164578063ab7965661161013e578063ab796566146107aa578063ac78dfe8146107d7578063affed0e0146107f7578063b1a2567e1461080d5761032d565b80639dcc4da314610760578063a217fddf14610795578063a3912ec81461032b5761032d565b8063865e6fd31461068c5780638f34e347146106ac5780639010d07c146106e05780639157921c1461070057806391d148541461072057806393c5678f146107405761032d565b806336568abe1161026a578063504af48c116102235780636932be98116101fd5780636932be98146106155780636c1ce670146106425780637de5dedd146106625780638456cb59146106775761032d565b8063504af48c146105bd57806359122f6b146105d05780635c975abb146105fd5761032d565b806336568abe146105055780633e70838b146105255780633f4ba83a146105455780634b14557e1461055a5780634d0d66731461056d5780634d493f4e1461058d5761032d565b80631d4a7210116102d75780632dfdf0b5116102b15780632dfdf0b5146104a35780632f2ff15d146104b9578063302d12db146104d95780633644e515146104f05761032d565b80631d4a721014610426578063248a9ca31461045357806329b6eca9146104835761032d565b806301ffc9a714610335578063065b3adf1461036a57806317ce2dd4146103a257806317fcb39b146103c65780631a8e55b0146103e65780631b6e7594146104065761032d565b3661032d5761032b610a11565b005b61032b610a11565b34801561034157600080fd5b506103556103503660046138ea565b610a51565b60405190151581526020015b60405180910390f35b34801561037657600080fd5b5060055461038a906001600160a01b031681565b6040516001600160a01b039091168152602001610361565b3480156103ae57600080fd5b506103b860755481565b604051908152602001610361565b3480156103d257600080fd5b5060745461038a906001600160a01b031681565b3480156103f257600080fd5b5061032b610401366004613959565b610a7c565b34801561041257600080fd5b5061032b6104213660046139c5565b610ab8565b34801561043257600080fd5b506103b8610441366004613a7f565b603e6020526000908152604090205481565b34801561045f57600080fd5b506103b861046e366004613a9c565b60009081526072602052604090206001015490565b34801561048f57600080fd5b5061032b61049e366004613a7f565b610af8565b3480156104af57600080fd5b506103b860765481565b3480156104c557600080fd5b5061032b6104d4366004613ab5565b610ba3565b3480156104e557600080fd5b506103b8620f424081565b3480156104fc57600080fd5b506077546103b8565b34801561051157600080fd5b5061032b610520366004613ab5565b610bcd565b34801561053157600080fd5b5061032b610540366004613a7f565b610c4b565b34801561055157600080fd5b5061032b610c75565b61032b610568366004613ae5565b610c85565b34801561057957600080fd5b50610355610588366004613b10565b610ca5565b34801561059957600080fd5b506103556105a8366004613a9c565b607a6020526000908152604090205460ff1681565b61032b6105cb366004613bbb565b610d13565b3480156105dc57600080fd5b506103b86105eb366004613a7f565b603a6020526000908152604090205481565b34801561060957600080fd5b5060005460ff16610355565b34801561062157600080fd5b506103b8610630366004613a9c565b60796020526000908152604090205481565b34801561064e57600080fd5b5061035561065d366004613c96565b610fed565b34801561066e57600080fd5b506103b8611000565b34801561068357600080fd5b5061032b611017565b34801561069857600080fd5b5061032b6106a7366004613cd1565b611027565b3480156106b857600080fd5b506103b87f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e481565b3480156106ec57600080fd5b5061038a6106fb366004613cfd565b611042565b34801561070c57600080fd5b5061032b61071b366004613d1f565b61105a565b34801561072c57600080fd5b5061035561073b366004613ab5565b6112de565b34801561074c57600080fd5b5061032b61075b366004613959565b611309565b34801561076c57600080fd5b5061078061077b366004613cfd565b61133f565b60408051928352602083019190915201610361565b3480156107a157600080fd5b506103b8600081565b3480156107b657600080fd5b506103b86107c5366004613a7f565b603c6020526000908152604090205481565b3480156107e357600080fd5b506103556107f2366004613a9c565b611368565b34801561080357600080fd5b506103b860045481565b34801561081957600080fd5b5061032b610828366004613959565b611394565b34801561083957600080fd5b506103b8610848366004613a7f565b60396020526000908152604090205481565b34801561086657600080fd5b5061087a610875366004613a7f565b6113ca565b6040516103619190613d62565b34801561089357600080fd5b506107806108a2366004613cfd565b61146d565b3480156108b357600080fd5b506103b86108c2366004613a9c565b611482565b3480156108d357600080fd5b50603754603854610780565b3480156108eb57600080fd5b506103b86108fa366004613a7f565b603b6020526000908152604090205481565b34801561091857600080fd5b5061032b610927366004613ab5565b611499565b34801561093857600080fd5b506103b8610947366004613a7f565b603d6020526000908152604090205481565b34801561096557600080fd5b5061032b610974366004613a7f565b6114be565b34801561098557600080fd5b50610355610994366004613a9c565b6114cf565b3480156109a557600080fd5b5061038a6109b4366004613d8e565b6114f3565b3480156109c557600080fd5b5061032b6109d4366004613da9565b611569565b3480156109e557600080fd5b5061032b6109f4366004613959565b6115de565b348015610a0557600080fd5b50600154600254610780565b610a19611614565b6074546001600160a01b03163314610a4f57610a336138a9565b338152604080820151349101528051610a4d90829061165a565b505b565b60006001600160e01b03198216635a05180f60e01b1480610a765750610a76826118bb565b92915050565b610a846118f0565b6000839003610aa6576040516316ee9d3b60e11b815260040160405180910390fd5b610ab28484848461194a565b50505050565b610ac06118f0565b6000859003610ae2576040516316ee9d3b60e11b815260040160405180910390fd5b610af0868686868686611a1f565b505050505050565b607154600290610100900460ff16158015610b1a575060715460ff8083169116105b610b3f5760405162461bcd60e51b8152600401610b3690613e67565b60405180910390fd5b6071805461ffff191660ff831617610100179055610b5e600b83611bb6565b6071805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b600082815260726020526040902060010154610bbe81611c5a565b610bc88383611c64565b505050565b6001600160a01b0381163314610c3d5760405162461bcd60e51b815260206004820152602f60248201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560448201526e103937b632b9903337b91039b2b63360891b6064820152608401610b36565b610c478282611c86565b5050565b610c536118f0565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b610c7d611ca8565b610a4f611d17565b610c8d611614565b610a4d610c9f36839003830183613f54565b3361165a565b6000610caf611614565b610d0b848484808060200260200160405190810160405280939291908181526020016000905b82821015610d0157610cf260608302860136819003810190613fa7565b81526020019060010190610cd5565b5050505050611d69565b949350505050565b607154610100900460ff1615808015610d335750607154600160ff909116105b80610d4d5750303b158015610d4d575060715460ff166001145b610d695760405162461bcd60e51b8152600401610b3690613e67565b6071805460ff191660011790558015610d8c576071805461ff0019166101001790555b610d9760008c6121d3565b6075899055610da58a6121dd565b610e306040517f8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f81527f159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b60208201527fad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5604082015246606082015230608082015260a0812060775550565b610e3a8887612231565b5050610e4687876122c8565b5050610e50612355565b6000610e5c8680614033565b90501115610f1d57610e85610e718680614033565b610e7e6020890189614033565b8787611a1f565b610eab610e928680614033565b8660005b602002810190610ea69190614033565b6123a2565b610ed1610eb88680614033565b8660015b602002810190610ecc9190614033565b61194a565b610ef7610ede8680614033565b8660025b602002810190610ef29190614033565b612477565b610f1d610f048680614033565b8660035b602002810190610f189190614033565b612588565b60005b610f2d6040870187614033565b9050811015610f9957610f917f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4610f676040890189614033565b84818110610f7757610f7761401d565b9050602002016020810190610f8c9190613a7f565b611c64565b600101610f20565b508015610fe0576071805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050505050565b6000610ff9838361265d565b9392505050565b600061101261100d612721565b61278e565b905090565b61101f611ca8565b610a4f6127c4565b61102f6118f0565b61103881612801565b610c478282611bb6565b6000828152607360205260408120610ff99083612837565b7f5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e461108481611c5a565b600061109d611098368590038501856140cb565b612843565b90506110b1611098368590038501856140cb565b8335600090815260796020526040902054146110e05760405163f4b8742f60e01b815260040160405180910390fd5b82356000908152607a602052604090205460ff166111115760405163147bfe0760e01b815260040160405180910390fd5b82356000908152607a602052604090819020805460ff19169055517fd639511b37b3b002cca6cfe6bca0d833945a5af5a045578a0627fc43b79b26309061115b908390869061419f565b60405180910390a160006111756080850160608601613a7f565b9050600061118b6101208601610100870161422c565b600181111561119c5761119c613d3c565b036112635760006111b63686900386016101008701614249565b6001600160a01b0383166000908152603b60205260409020549091506111e2906101408701359061290d565b604082015260006111fc3687900387016101008801614249565b60408301519091506112139061014088013561427b565b6040820152607454611233908390339086906001600160a01b0316612927565b61125c6112466060880160408901613a7f565b60745483919086906001600160a01b0316612927565b505061129f565b61129f6112766060860160408701613a7f565b60745483906001600160a01b03166112973689900389016101008a01614249565b929190612927565b7f21e88e956aa3e086f6388e899965cef814688f99ad8bb29b08d396571016372d82856040516112d092919061419f565b60405180910390a150505050565b60009182526072602090815260408084206001600160a01b0393909316845291905290205460ff1690565b6113116118f0565b6000839003611333576040516316ee9d3b60e11b815260040160405180910390fd5b610ab2848484846123a2565b60008061134a6118f0565b61135484846122c8565b9092509050611361612355565b9250929050565b6000611372612721565b60375461137f919061428e565b60385461138c908461428e565b101592915050565b61139c6118f0565b60008390036113be576040516316ee9d3b60e11b815260040160405180910390fd5b610ab284848484612477565b60408051808201909152600080825260208201526001600160a01b0382166000908152607860205260409081902081518083019092528054829060ff16600181111561141857611418613d3c565b600181111561142957611429613d3c565b815290546001600160a01b036101009091048116602092830152908201519192501661146857604051631b79f53b60e21b815260040160405180910390fd5b919050565b6000806114786118f0565b6113548484612231565b6000818152607360205260408120610a7690612c63565b6000828152607260205260409020600101546114b481611c5a565b610bc88383611c86565b6114c66118f0565b610a4d816121dd565b60006114d9612721565b6001546114e6919061428e565b60025461138c908461428e565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561152a5761152a613d3c565b60ff1681526020810191909152604001600020546001600160a01b0316905080611468578160405163409140df60e11b8152600401610b3691906142a5565b6115716118f0565b6000869003611593576040516316ee9d3b60e11b815260040160405180910390fd5b6115a1878787878787611a1f565b6115ae8787836000610e96565b6115bb8787836001610ebc565b6115c88787836002610ee2565b6115d58787836003610f08565b50505050505050565b6115e66118f0565b6000839003611608576040516316ee9d3b60e11b815260040160405180910390fd5b610ab284848484612588565b60005460ff1615610a4f5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610b36565b604080518082018252600080825260208201526074549184015190916001600160a01b03169061168990612c6d565b60208401516001600160a01b031661172a5734846040015160400151146116c35760405163129c2ce160e31b815260040160405180910390fd5b6116cc816113ca565b60408501515190925060018111156116e6576116e6613d3c565b825160018111156116f9576116f9613d3c565b146117165760405162035e2b60ea1b815260040160405180910390fd5b6001600160a01b0381166020850152611838565b34156117495760405163129c2ce160e31b815260040160405180910390fd5b61175684602001516113ca565b604085015151909250600181111561177057611770613d3c565b8251600181111561178357611783613d3c565b146117a05760405162035e2b60ea1b815260040160405180910390fd5b602084015160408501516117b79185903090612ce8565b83602001516001600160a01b0316816001600160a01b031603611838576040848101518101519051632e1a7d4d60e01b815260048101919091526001600160a01b03821690632e1a7d4d90602401600060405180830381600087803b15801561181f57600080fd5b505af1158015611833573d6000803e3d6000fd5b505050505b6076805460009182611849836142bf565b9190505590506000611870858386602001516075548a612ec990949392919063ffffffff16565b90507fd7b25068d9dc8d00765254cfb7f5070f98d263c8d68931d937c7362fa738048b61189c82612843565b826040516118ab9291906142fa565b60405180910390a1505050505050565b60006001600160e01b03198216637965db0b60e01b1480610a7657506301ffc9a760e01b6001600160e01b0319831614610a76565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610a4f576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b36929190614398565b828114611978576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b838110156119e9578282828181106119955761199561401d565b90506020020135603a60008787858181106119b2576119b261401d565b90506020020160208101906119c79190613a7f565b6001600160a01b0316815260208101919091526040016000205560010161197b565b507f64557254143204d91ba2d95acb9fda1e5fea55f77efd028685765bc1e94dd4b5848484846040516112d09493929190614424565b8483148015611a2d57508481145b611a58576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b85811015611b7c57848482818110611a7557611a7561401d565b9050602002016020810190611a8a9190613a7f565b60786000898985818110611aa057611aa061401d565b9050602002016020810190611ab59190613a7f565b6001600160a01b03908116825260208201929092526040016000208054610100600160a81b0319166101009390921692909202179055828282818110611afd57611afd61401d565b9050602002016020810190611b12919061422c565b60786000898985818110611b2857611b2861401d565b9050602002016020810190611b3d9190613a7f565b6001600160a01b031681526020810191909152604001600020805460ff191660018381811115611b6f57611b6f613d3c565b0217905550600101611a5b565b507fa4f03cc9c0e0aeb5b71b4ec800702753f65748c2cf3064695ba8e8b46be704448686868686866040516118ab96959493929190614470565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115611bec57611bec613d3c565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115611c2d57611c2d613d3c565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610a4d8133612f9e565b611c6e8282613002565b6000828152607360205260409020610bc89082613088565b611c90828261309d565b6000828152607360205260409020610bc89082613104565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b0316331480611cea57506005546001600160a01b031633145b610a4f576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b36929190614398565b611d1f613119565b6000805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b6000823561014084013582611d846080870160608801613a7f565b9050611da1611d9c3688900388016101008901614249565b612c6d565b6001611db3604088016020890161422c565b6001811115611dc457611dc4613d3c565b14611de25760405163182f3d8760e11b815260040160405180910390fd5b60808601354614611e245760405163092048d160e11b81526000356001600160e01b031916600482015260808701356024820152466044820152606401610b36565b6000611e396108756080890160608a01613a7f565b9050611e4d6101208801610100890161422c565b6001811115611e5e57611e5e613d3c565b81516001811115611e7157611e71613d3c565b148015611ea25750611e8960e0880160c08901613a7f565b6001600160a01b031681602001516001600160a01b0316145b611ebf5760405163f4b8742f60e01b815260040160405180910390fd5b60008481526079602052604090205415611eec57604051634f13df6160e01b815260040160405180910390fd5b6001611f0061012089016101008a0161422c565b6001811115611f1157611f11613d3c565b1480611f245750611f22828461265d565b155b611f415760405163c51297b760e01b815260040160405180910390fd5b6000611f55611098368a90038a018a6140cb565b90506000611f6560775483613162565b90506000611f85611f7e6101208c016101008d0161422c565b86886131a3565b60408051606081018252600080825260208201819052918101829052919a50919250819081906000805b8e518110156120aa578e8181518110611fca57611fca61401d565b6020908102919091018101518051818301516040808401518151600081529586018083528e905260ff9093169085015260608401526080830152935060019060a0016020604051602081039080840390855afa15801561202e573d6000803e3d6000fd5b505050602060405103519450846001600160a01b0316846001600160a01b03161061207a576000356001600160e01b031916604051635d3dcd3160e01b8152600401610b3691906143c6565b84935061208685613229565b61209090836144e8565b91508682106120a257600195506120aa565b600101611faf565b50846120c957604051639e8f5f6360e01b815260040160405180910390fd5b505050600089815260796020526040902085905550508715612144576000878152607a602052604090819020805460ff19166001179055517f89e52969465b1f1866fc5d46fd62de953962e9cb33552443cd999eba05bd20dc906121309085908d9061419f565b60405180910390a150505050505050610a76565b61214e85876132b5565b61218d61216160608c0160408d01613a7f565b86607460009054906101000a90046001600160a01b03168d610100018036038101906112979190614249565b7f21e88e956aa3e086f6388e899965cef814688f99ad8bb29b08d396571016372d838b6040516121be92919061419f565b60405180910390a15050505050505092915050565b610c478282611c64565b607480546001600160a01b0319166001600160a01b0383169081179091556040519081527f9d2334c23be647e994f27a72c5eee42a43d5bdcfe15bb88e939103c2b114cbaf9060200160405180910390a150565b60008082841115612263576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f891015b60405180910390a49250929050565b600080828411156122fa576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b5050603780546038805492859055839055600480546001810190915560408051838152602081018590529293928592879290917f31312c97b89cc751b832d98fd459b967a2c3eef3b49757d1cf5ebaa12bb6eee191016122b9565b600254603754612365919061428e565b603854600154612375919061428e565b1115610a4f576000356001600160e01b0319166040516387f6f09560e01b8152600401610b3691906143c6565b8281146123d0576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b83811015612441578282828181106123ed576123ed61401d565b905060200201356039600087878581811061240a5761240a61401d565b905060200201602081019061241f9190613a7f565b6001600160a01b031681526020810191909152604001600020556001016123d3565b507f80bc635c452ae67f12f9b6f12ad4daa6dbbc04eeb9ebb87d354ce10c0e210dc0848484846040516112d09493929190614424565b8281146124a5576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b8381101561255257620f42408383838181106124c6576124c661401d565b9050602002013511156124ec5760405163572d3bd360e11b815260040160405180910390fd5b8282828181106124fe576124fe61401d565b90506020020135603b600087878581811061251b5761251b61401d565b90506020020160208101906125309190613a7f565b6001600160a01b031681526020810191909152604001600020556001016124a8565b507fb05f5de88ae0294ebb6f67c5af2fcbbd593cc6bdfe543e2869794a4c8ce3ea50848484846040516112d09493929190614424565b8281146125b6576000356001600160e01b0319166040516306b5667560e21b8152600401610b3691906143c6565b60005b83811015612627578282828181106125d3576125d361401d565b90506020020135603c60008787858181106125f0576125f061401d565b90506020020160208101906126059190613a7f565b6001600160a01b031681526020810191909152604001600020556001016125b9565b507fb5d2963614d72181b4df1f993d45b83edf42fa19710f0204217ba1b3e183bb73848484846040516112d09493929190614424565b6001600160a01b0382166000908152603a6020526040812054821061268457506000610a76565b600061269362015180426144fb565b6001600160a01b0385166000908152603e60205260409020549091508111156126d95750506001600160a01b0382166000908152603c6020526040902054811015610a76565b6001600160a01b0384166000908152603d60205260409020546126fd9084906144e8565b6001600160a01b0385166000908152603c602052604090205411159150610a769050565b600061272d600b6114f3565b6001600160a01b03166306aba0e16040518163ffffffff1660e01b8152600401602060405180830381865afa15801561276a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611012919061451d565b60006002546001600254846001546127a6919061428e565b6127b091906144e8565b6127ba919061427b565b610a7691906144fb565b6127cc611614565b6000805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a258611d4c3390565b806001600160a01b03163b600003610a4d57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610b36565b6000610ff98383613345565b600080612853836040015161336f565b90506000612864846060015161336f565b905060006128b88560800151604080517f1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d815282516020808301919091528301518183015291015160608201526080902090565b604080517fb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea815287516020808301919091529097015190870152606086019390935250608084015260a08301525060c0902090565b6000620f424061291d838561428e565b610ff991906144fb565b6000816001600160a01b0316836001600160a01b0316036129d65760408086015190516001600160a01b0386169180156108fc02916000818181858888f193505050506129d157816001600160a01b031663d0e30db086604001516040518263ffffffff1660e01b81526004016000604051808303818588803b1580156129ad57600080fd5b505af11580156129c1573d6000803e3d6000fd5b50505050506129d18585856133b7565b612c5c565b6000855160018111156129eb576129eb613d3c565b03612b54576040516370a0823160e01b81523060048201526000906001600160a01b038516906370a0823190602401602060405180830381865afa158015612a37573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612a5b919061451d565b90508560400151811015612b4357836001600160a01b03166340c10f1930838960400151612a89919061427b565b6040516001600160a01b03909216602483015260448201526064016040516020818303038152906040529060e01b6020820180516001600160e01b038381831617835250505050604051612add919061455a565b6000604051808303816000865af19150503d8060008114612b1a576040519150601f19603f3d011682016040523d82523d6000602084013e612b1f565b606091505b50508092505081612b4357604051632f739fff60e11b815260040160405180910390fd5b612b4e8686866133b7565b50612c5c565b600185516001811115612b6957612b69613d3c565b03612c4357612b7d83858760200151613435565b6129d157602085810151604080516001600160a01b038881166024830152604480830194909452825180830390940184526064909101825292820180516001600160e01b03166340c10f1960e01b1790525191851691612bdd919061455a565b6000604051808303816000865af19150503d8060008114612c1a576040519150601f19603f3d011682016040523d82523d6000602084013e612c1f565b606091505b505080915050806129d15760405163c8e3a09f60e01b815260040160405180910390fd5b6040516361e411a760e11b815260040160405180910390fd5b5050505050565b6000610a76825490565b600081516001811115612c8257612c82613d3c565b148015612c93575060008160400151115b8015612ca157506020810151155b80612ccb5750600181516001811115612cbc57612cbc613d3c565b148015612ccb57506040810151155b610a4d5760405163034992a760e51b815260040160405180910390fd5b600060608186516001811115612d0057612d00613d3c565b03612ddd5760408681015181516001600160a01b038881166024830152878116604483015260648083019390935283518083039093018352608490910183526020820180516001600160e01b03166323b872dd60e01b179052915191851691612d69919061455a565b6000604051808303816000865af19150503d8060008114612da6576040519150601f19603f3d011682016040523d82523d6000602084013e612dab565b606091505b509092509050818015612dd6575080511580612dd6575080806020019051810190612dd69190614576565b9150612ea3565b600186516001811115612df257612df2613d3c565b03612c4357602086810151604080516001600160a01b0389811660248301528881166044830152606480830194909452825180830390940184526084909101825292820180516001600160e01b03166323b872dd60e01b1790525191851691612e5b919061455a565b6000604051808303816000865af19150503d8060008114612e98576040519150601f19603f3d011682016040523d82523d6000602084013e612e9d565b606091505b50909250505b81610af05785858585604051639d2e4c6760e01b8152600401610b369493929190614598565b612f396040805160a08101825260008082526020808301829052835160608082018652838252818301849052818601849052848601919091528451808201865283815280830184905280860184905281850152845190810185528281529081018290529283015290608082015290565b83815260006020820181905250604080820180516001600160a01b039788169052602080890151825190891690820152905146908301528751606084018051918916909152805195909716940193909352935182015292909201516080820152919050565b612fa882826112de565b610c4757612fc0816001600160a01b031660146134e0565b612fcb8360206134e0565b604051602001612fdc9291906145ce565b60408051601f198184030181529082905262461bcd60e51b8252610b3691600401614643565b61300c82826112de565b610c475760008281526072602090815260408083206001600160a01b03851684529091529020805460ff191660011790556130443390565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b6000610ff9836001600160a01b03841661367c565b6130a782826112de565b15610c475760008281526072602090815260408083206001600160a01b0385168085529252808320805460ff1916905551339285917ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b9190a45050565b6000610ff9836001600160a01b0384166136cb565b60005460ff16610a4f5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610b36565b6040805161190160f01b6020808301919091526022820185905260428083018590528351808403909101815260629092019092528051910120600090610ff9565b60008060006131b0612721565b90506131bb8161278e565b925060008660018111156131d1576131d1613d3c565b03613220576001600160a01b0385166000908152603960205260409020548410613201576131fe816137be565b92505b6001600160a01b0385166000908152603a602052604090205484101591505b50935093915050565b6000613235600b6114f3565b60405163901979d560e01b81526001600160a01b038481166004830152919091169063901979d590602401602060405180830381865afa15801561327d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906132a19190614676565b6bffffffffffffffffffffffff1692915050565b60006132c462015180426144fb565b6001600160a01b0384166000908152603e6020526040902054909150811115613313576001600160a01b03929092166000908152603e6020908152604080832094909455603d90529190912055565b6001600160a01b0383166000908152603d60205260408120805484929061333b9084906144e8565b9091555050505050565b600082600001828154811061335c5761335c61401d565b9060005260206000200154905092915050565b604080517f353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764815282516020808301919091528301518183015291015160608201526080902090565b600080845160018111156133cd576133cd613d3c565b036133e8576133e1828486604001516137d6565b9050613411565b6001845160018111156133fd576133fd613d3c565b03612c43576133e182848660200151613435565b80610ab2578383836040516341bd7d9160e11b8152600401610b36939291906146a4565b604080513060248201526001600160a01b038481166044830152606480830185905283518084039091018152608490920183526020820180516001600160e01b03166323b872dd60e01b17905291516000928616916134939161455a565b6000604051808303816000865af19150503d80600081146134d0576040519150601f19603f3d011682016040523d82523d6000602084013e6134d5565b606091505b509095945050505050565b606060006134ef83600261428e565b6134fa9060026144e8565b67ffffffffffffffff81111561351257613512613eb5565b6040519080825280601f01601f19166020018201604052801561353c576020820181803683370190505b509050600360fc1b816000815181106135575761355761401d565b60200101906001600160f81b031916908160001a905350600f60fb1b816001815181106135865761358661401d565b60200101906001600160f81b031916908160001a90535060006135aa84600261428e565b6135b59060016144e8565b90505b600181111561362d576f181899199a1a9b1b9c1cb0b131b232b360811b85600f16601081106135e9576135e961401d565b1a60f81b8282815181106135ff576135ff61401d565b60200101906001600160f81b031916908160001a90535060049490941c93613626816146d4565b90506135b8565b508315610ff95760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610b36565b60008181526001830160205260408120546136c357508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610a76565b506000610a76565b600081815260018301602052604081205480156137b45760006136ef60018361427b565b85549091506000906137039060019061427b565b90508181146137685760008660000182815481106137235761372361401d565b90600052602060002001549050808760000184815481106137465761374661401d565b6000918252602080832090910192909255918252600188019052604090208390555b8554869080613779576137796146eb565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610a76565b6000915050610a76565b60006038546001603854846037546127a6919061428e565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663a9059cbb60e01b179052915160009260609290871691613833919061455a565b6000604051808303816000865af19150503d8060008114613870576040519150601f19603f3d011682016040523d82523d6000602084013e613875565b606091505b5090925090508180156138a05750805115806138a05750808060200190518101906138a09190614576565b95945050505050565b60408051606081018252600080825260208201529081016138e56040805160608101909152806000815260200160008152602001600081525090565b905290565b6000602082840312156138fc57600080fd5b81356001600160e01b031981168114610ff957600080fd5b60008083601f84011261392657600080fd5b50813567ffffffffffffffff81111561393e57600080fd5b6020830191508360208260051b850101111561136157600080fd5b6000806000806040858703121561396f57600080fd5b843567ffffffffffffffff8082111561398757600080fd5b61399388838901613914565b909650945060208701359150808211156139ac57600080fd5b506139b987828801613914565b95989497509550505050565b600080600080600080606087890312156139de57600080fd5b863567ffffffffffffffff808211156139f657600080fd5b613a028a838b01613914565b90985096506020890135915080821115613a1b57600080fd5b613a278a838b01613914565b90965094506040890135915080821115613a4057600080fd5b50613a4d89828a01613914565b979a9699509497509295939492505050565b6001600160a01b0381168114610a4d57600080fd5b803561146881613a5f565b600060208284031215613a9157600080fd5b8135610ff981613a5f565b600060208284031215613aae57600080fd5b5035919050565b60008060408385031215613ac857600080fd5b823591506020830135613ada81613a5f565b809150509250929050565b600060a08284031215613af757600080fd5b50919050565b60006101608284031215613af757600080fd5b60008060006101808486031215613b2657600080fd5b613b308585613afd565b925061016084013567ffffffffffffffff80821115613b4e57600080fd5b818601915086601f830112613b6257600080fd5b813581811115613b7157600080fd5b876020606083028501011115613b8657600080fd5b6020830194508093505050509250925092565b8060608101831015610a7657600080fd5b8060808101831015610a7657600080fd5b6000806000806000806000806000806101208b8d031215613bdb57600080fd5b613be48b613a74565b9950613bf260208c01613a74565b985060408b0135975060608b0135965060808b0135955060a08b0135945060c08b013567ffffffffffffffff80821115613c2b57600080fd5b613c378e838f01613b99565b955060e08d0135915080821115613c4d57600080fd5b613c598e838f01613baa565b94506101008d0135915080821115613c7057600080fd5b50613c7d8d828e01613914565b915080935050809150509295989b9194979a5092959850565b60008060408385031215613ca957600080fd5b8235613cb481613a5f565b946020939093013593505050565b80356010811061146857600080fd5b60008060408385031215613ce457600080fd5b613ced83613cc2565b91506020830135613ada81613a5f565b60008060408385031215613d1057600080fd5b50508035926020909101359150565b60006101608284031215613d3257600080fd5b610ff98383613afd565b634e487b7160e01b600052602160045260246000fd5b60028110610a4d57610a4d613d3c565b81516040820190613d7281613d52565b82526020928301516001600160a01b0316929091019190915290565b600060208284031215613da057600080fd5b610ff982613cc2565b60008060008060008060006080888a031215613dc457600080fd5b873567ffffffffffffffff80821115613ddc57600080fd5b613de88b838c01613914565b909950975060208a0135915080821115613e0157600080fd5b613e0d8b838c01613914565b909750955060408a0135915080821115613e2657600080fd5b613e328b838c01613914565b909550935060608a0135915080821115613e4b57600080fd5b50613e588a828b01613baa565b91505092959891949750929550565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b6040516060810167ffffffffffffffff81118282101715613efc57634e487b7160e01b600052604160045260246000fd5b60405290565b60028110610a4d57600080fd5b600060608284031215613f2157600080fd5b613f29613ecb565b90508135613f3681613f02565b80825250602082013560208201526040820135604082015292915050565b600060a08284031215613f6657600080fd5b613f6e613ecb565b8235613f7981613a5f565b81526020830135613f8981613a5f565b6020820152613f9b8460408501613f0f565b60408201529392505050565b600060608284031215613fb957600080fd5b6040516060810181811067ffffffffffffffff82111715613fea57634e487b7160e01b600052604160045260246000fd5b604052823560ff81168114613ffe57600080fd5b8152602083810135908201526040928301359281019290925250919050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261404a57600080fd5b83018035915067ffffffffffffffff82111561406557600080fd5b6020019150600581901b360382131561136157600080fd5b60006060828403121561408f57600080fd5b614097613ecb565b905081356140a481613a5f565b815260208201356140b481613a5f565b806020830152506040820135604082015292915050565b600061016082840312156140de57600080fd5b60405160a0810181811067ffffffffffffffff8211171561410f57634e487b7160e01b600052604160045260246000fd5b60405282358152602083013561412481613f02565b6020820152614136846040850161407d565b60408201526141488460a0850161407d565b606082015261415b846101008501613f0f565b60808201529392505050565b803561417281613a5f565b6001600160a01b03908116835260208201359061418e82613a5f565b166020830152604090810135910152565b6000610180820190508382528235602083015260208301356141c081613f02565b6141c981613d52565b806040840152506141e06060830160408501614167565b6141f060c0830160a08501614167565b61012061010084013561420281613f02565b61420b81613d52565b81840152830135610140808401919091529092013561016090910152919050565b60006020828403121561423e57600080fd5b8135610ff981613f02565b60006060828403121561425b57600080fd5b610ff98383613f0f565b634e487b7160e01b600052601160045260246000fd5b81810381811115610a7657610a76614265565b8082028115828204841417610a7657610a76614265565b60208101601083106142b9576142b9613d3c565b91905290565b6000600182016142d1576142d1614265565b5060010190565b80516142e381613d52565b825260208181015190830152604090810151910152565b60006101808201905083825282516020830152602083015161431b81613d52565b6040838101919091528381015180516001600160a01b03908116606086015260208201511660808501529081015160a084015250606083015180516001600160a01b0390811660c085015260208201511660e084015260408101516101008401525060808301516143906101208401826142d8565b509392505050565b6001600160e01b03198316815260408101600b83106143b9576143b9613d3c565b8260208301529392505050565b6001600160e01b031991909116815260200190565b8183526000602080850194508260005b858110156144195781356143fe81613a5f565b6001600160a01b0316875295820195908201906001016143eb565b509495945050505050565b6040815260006144386040830186886143db565b82810360208401528381526001600160fb1b0384111561445757600080fd5b8360051b80866020840137016020019695505050505050565b60608152600061448460608301888a6143db565b60208382038185015261449882888a6143db565b8481036040860152858152869250810160005b868110156144d95783356144be81613f02565b6144c781613d52565b825292820192908201906001016144ab565b509a9950505050505050505050565b80820180821115610a7657610a76614265565b60008261451857634e487b7160e01b600052601260045260246000fd5b500490565b60006020828403121561452f57600080fd5b5051919050565b60005b83811015614551578181015183820152602001614539565b50506000910152565b6000825161456c818460208701614536565b9190910192915050565b60006020828403121561458857600080fd5b81518015158114610ff957600080fd5b60c081016145a682876142d8565b6001600160a01b0394851660608301529284166080820152921660a090920191909152919050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000815260008351614606816017850160208801614536565b7001034b99036b4b9b9b4b733903937b6329607d1b6017918401918201528351614637816028840160208801614536565b01602801949350505050565b6020815260008251806020840152614662816040850160208701614536565b601f01601f19169190910160400192915050565b60006020828403121561468857600080fd5b81516bffffffffffffffffffffffff81168114610ff957600080fd5b60a081016146b282866142d8565b6001600160a01b03938416606083015291909216608090920191909152919050565b6000816146e3576146e3614265565b506000190190565b634e487b7160e01b600052603160045260246000fdfea264697066735822122067a7e41e0d11cc4f13027848a796f28bc789f50aade1ce98bb6b3473be92478464736f6c63430008110033", + "devdoc": { + "errors": { + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrERC20MintingFailed()": [ + { + "details": "Error indicating that the minting of ERC20 tokens has failed." + } + ], + "ErrERC721MintingFailed()": [ + { + "details": "Error indicating that the minting of ERC721 tokens has failed." + } + ], + "ErrEmptyArray()": [ + { + "details": "Error indicating that an array is empty when it should contain elements." + } + ], + "ErrInvalidChainId(bytes4,uint256,uint256)": [ + { + "details": "Error indicating that the chain ID is invalid.", + "params": { + "actual": "Current chain ID that executing function.", + "expected": "Expected chain ID required for the tx to success.", + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid chain ID." + } + } + ], + "ErrInvalidInfo()": [ + { + "details": "Error indicating that the provided information is invalid." + } + ], + "ErrInvalidOrder(bytes4)": [ + { + "details": "Error indicating that an order is invalid.", + "params": { + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid order." + } + } + ], + "ErrInvalidPercentage()": [ + { + "details": "Error of invalid percentage." + } + ], + "ErrInvalidReceipt()": [ + { + "details": "Error indicating that a receipt is invalid." + } + ], + "ErrInvalidReceiptKind()": [ + { + "details": "Error indicating that a receipt kind is invalid." + } + ], + "ErrInvalidRequest()": [ + { + "details": "Error indicating that a request is invalid." + } + ], + "ErrInvalidThreshold(bytes4)": [ + { + "details": "Error indicating that the provided threshold is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that the invalid threshold applies to." + } + } + ], + "ErrInvalidTokenStandard()": [ + { + "details": "Error indicating that a token standard is invalid." + } + ], + "ErrLengthMismatch(bytes4)": [ + { + "details": "Error indicating a mismatch in the length of input parameters or arrays for a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that has a length mismatch." + } + } + ], + "ErrQueryForApprovedWithdrawal()": [ + { + "details": "Error indicating that a query was made for an approved withdrawal." + } + ], + "ErrQueryForInsufficientVoteWeight()": [ + { + "details": "Error indicating that a query was made for insufficient vote weight." + } + ], + "ErrQueryForProcessedWithdrawal()": [ + { + "details": "Error indicating that a query was made for a processed withdrawal." + } + ], + "ErrReachedDailyWithdrawalLimit()": [ + { + "details": "Error indicating that the daily withdrawal limit has been reached." + } + ], + "ErrTokenCouldNotTransfer((uint8,uint256,uint256),address,address)": [ + { + "details": "Error indicating that the `transfer` has failed.", + "params": { + "to": "Receiver of the token value.", + "token": "Address of the token.", + "tokenInfo": "Info of the token including ERC standard, id or quantity." + } + } + ], + "ErrTokenCouldNotTransferFrom((uint8,uint256,uint256),address,address,address)": [ + { + "details": "Error indicating that the `transferFrom` has failed.", + "params": { + "from": "Owner of the token value.", + "to": "Receiver of the token value.", + "token": "Address of the token.", + "tokenInfo": "Info of the token including ERC standard, id or quantity." + } + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnsupportedStandard()": [ + { + "details": "Error indicating that an unsupported standard is encountered." + } + ], + "ErrUnsupportedToken()": [ + { + "details": "Error indicating that a token is not supported." + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "DOMAIN_SEPARATOR()": { + "details": "Returns the domain seperator." + }, + "checkHighTierVoteWeightThreshold(uint256)": { + "details": "Checks whether the `_voteWeight` passes the high-tier vote weight threshold." + }, + "checkThreshold(uint256)": { + "details": "Checks whether the `_voteWeight` passes the threshold." + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getHighTierVoteWeightThreshold()": { + "details": "Returns the high-tier vote weight threshold." + }, + "getRoleAdmin(bytes32)": { + "details": "Returns the admin role that controls `role`. See {grantRole} and {revokeRole}. To change a role's admin, use {_setRoleAdmin}." + }, + "getRoleMember(bytes32,uint256)": { + "details": "Returns one of the accounts that have `role`. `index` must be a value between 0 and {getRoleMemberCount}, non-inclusive. Role bearers are not sorted in any particular way, and their ordering may change at any point. WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure you perform all queries on the same block. See the following https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post] for more information." + }, + "getRoleMemberCount(bytes32)": { + "details": "Returns the number of accounts that have `role`. Can be used together with {getRoleMember} to enumerate all bearers of a role." + }, + "getRoninToken(address)": { + "details": "Returns token address on Ronin network. Note: Reverts for unsupported token." + }, + "getThreshold()": { + "details": "Returns the threshold." + }, + "grantRole(bytes32,address)": { + "details": "Grants `role` to `account`. If `account` had not been already granted `role`, emits a {RoleGranted} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleGranted} event." + }, + "hasRole(bytes32,address)": { + "details": "Returns `true` if `account` has been granted `role`." + }, + "initialize(address,address,uint256,uint256,uint256,uint256,address[][3],uint256[][4],uint8[])": { + "details": "Initializes contract storage." + }, + "mapTokens(address[],address[],uint8[])": { + "details": "Maps mainchain tokens to Ronin network. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event." + }, + "mapTokensAndThresholds(address[],address[],uint8[],uint256[][4])": { + "details": "Maps mainchain tokens to Ronin network and sets thresholds. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event." + }, + "minimumVoteWeight()": { + "details": "Returns the minimum vote weight to pass the threshold." + }, + "pause()": { + "details": "Triggers paused state." + }, + "paused()": { + "details": "Returns true if the contract is paused, and false otherwise." + }, + "reachedWithdrawalLimit(address,uint256)": { + "details": "Checks whether the withdrawal reaches the limitation." + }, + "receiveEther()": { + "details": "Receives ether without doing anything. Use this function to topup native token." + }, + "renounceRole(bytes32,address)": { + "details": "Revokes `role` from the calling account. Roles are often managed via {grantRole} and {revokeRole}: this function's purpose is to provide a mechanism for accounts to lose their privileges if they are compromised (such as when a trusted device is misplaced). If the calling account had been revoked `role`, emits a {RoleRevoked} event. Requirements: - the caller must be `account`. May emit a {RoleRevoked} event." + }, + "requestDepositFor((address,address,(uint8,uint256,uint256)))": { + "details": "Locks the assets and request deposit." + }, + "revokeRole(bytes32,address)": { + "details": "Revokes `role` from `account`. If `account` had been granted `role`, emits a {RoleRevoked} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleRevoked} event." + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, + "setDailyWithdrawalLimits(address[],uint256[])": { + "details": "Sets daily limit amounts for the withdrawals. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `DailyWithdrawalLimitsUpdated` event." + }, + "setEmergencyPauser(address)": { + "details": "Grant emergency pauser role for `_addr`." + }, + "setHighTierThresholds(address[],uint256[])": { + "details": "Sets the thresholds for high-tier withdrawals that requires high-tier vote weights. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `HighTierThresholdsUpdated` event." + }, + "setHighTierVoteWeightThreshold(uint256,uint256)": { + "details": "Sets high-tier vote weight threshold and returns the old one. Requirements: - The method caller is admin. - The high-tier vote weight threshold must equal to or larger than the normal threshold. Emits the `HighTierVoteWeightThresholdUpdated` event." + }, + "setLockedThresholds(address[],uint256[])": { + "details": "Sets the amount thresholds to lock withdrawal. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `LockedThresholdsUpdated` event." + }, + "setThreshold(uint256,uint256)": { + "details": "Override `GatewayV3-setThreshold`. Requirements: - The high-tier vote weight threshold must equal to or larger than the normal threshold." + }, + "setUnlockFeePercentages(address[],uint256[])": { + "details": "Sets fee percentages to unlock withdrawal. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `UnlockFeePercentagesUpdated` event." + }, + "setWrappedNativeTokenContract(address)": { + "details": "Sets the wrapped native token contract. Requirements: - The method caller is admin. Emits the `WrappedNativeTokenContractUpdated` event." + }, + "submitWithdrawal((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)),(uint8,bytes32,bytes32)[])": { + "details": "Withdraws based on the receipt and the validator signatures. Returns whether the withdrawal is locked. Emits the `Withdrew` once the assets are released." + }, + "supportsInterface(bytes4)": { + "details": "See {IERC165-supportsInterface}." + }, + "unlockWithdrawal((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))": { + "details": "Approves a specific withdrawal. Requirements: - The method caller is a validator. Emits the `Withdrew` once the assets are released." + }, + "unpause()": { + "details": "Triggers unpaused state." + } + }, + "stateVariables": { + "WITHDRAWAL_UNLOCKER_ROLE": { + "details": "Withdrawal unlocker role hash" + }, + "______deprecatedBridgeOperatorAddedBlock": { + "custom:deprecated": "Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))" + }, + "______deprecatedBridgeOperators": { + "custom:deprecated": "Previously `_bridgeOperators` (uint256[])" + }, + "_domainSeparator": { + "details": "Domain seperator" + }, + "_roninToken": { + "details": "Mapping from mainchain token => token address on Ronin network" + }, + "depositCount": { + "details": "Total deposit" + }, + "roninChainId": { + "details": "Ronin network id" + }, + "withdrawalHash": { + "details": "Mapping from withdrawal id => withdrawal hash" + }, + "withdrawalLocked": { + "details": "Mapping from withdrawal id => locked" + }, + "wrappedNativeToken": { + "details": "Wrapped native token address" + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "unlockFeePercentages(address)": { + "notice": "Values 0-1,000,000 map to 0%-100%" + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 1535, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_paused", + "offset": 0, + "slot": "0", + "type": "t_bool" + }, + { + "astId": 4326, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_num", + "offset": 0, + "slot": "1", + "type": "t_uint256" + }, + { + "astId": 4328, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_denom", + "offset": 0, + "slot": "2", + "type": "t_uint256" + }, + { + "astId": 4330, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "______deprecated", + "offset": 0, + "slot": "3", + "type": "t_address" + }, + { + "astId": 4332, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "nonce", + "offset": 0, + "slot": "4", + "type": "t_uint256" + }, + { + "astId": 4334, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "emergencyPauser", + "offset": 0, + "slot": "5", + "type": "t_address" + }, + { + "astId": 4339, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "______gap", + "offset": 0, + "slot": "6", + "type": "t_array(t_uint256)49_storage" + }, + { + "astId": 5194, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_highTierVWNum", + "offset": 0, + "slot": "55", + "type": "t_uint256" + }, + { + "astId": 5196, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_highTierVWDenom", + "offset": 0, + "slot": "56", + "type": "t_uint256" + }, + { + "astId": 5201, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "highTierThreshold", + "offset": 0, + "slot": "57", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5206, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "lockedThreshold", + "offset": 0, + "slot": "58", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5211, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "unlockFeePercentages", + "offset": 0, + "slot": "59", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5216, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "dailyWithdrawalLimit", + "offset": 0, + "slot": "60", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5221, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "lastSyncedWithdrawal", + "offset": 0, + "slot": "61", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5226, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "lastDateSynced", + "offset": 0, + "slot": "62", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 5231, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "______gap", + "offset": 0, + "slot": "63", + "type": "t_array(t_uint256)50_storage" + }, + { + "astId": 1373, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_initialized", + "offset": 0, + "slot": "113", + "type": "t_uint8" + }, + { + "astId": 1376, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_initializing", + "offset": 1, + "slot": "113", + "type": "t_bool" + }, + { + "astId": 24, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_roles", + "offset": 0, + "slot": "114", + "type": "t_mapping(t_bytes32,t_struct(RoleData)19_storage)" + }, + { + "astId": 338, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_roleMembers", + "offset": 0, + "slot": "115", + "type": "t_mapping(t_bytes32,t_struct(AddressSet)4026_storage)" + }, + { + "astId": 17280, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "wrappedNativeToken", + "offset": 0, + "slot": "116", + "type": "t_contract(IWETH)12355" + }, + { + "astId": 17283, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "roninChainId", + "offset": 0, + "slot": "117", + "type": "t_uint256" + }, + { + "astId": 17286, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "depositCount", + "offset": 0, + "slot": "118", + "type": "t_uint256" + }, + { + "astId": 17289, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_domainSeparator", + "offset": 0, + "slot": "119", + "type": "t_bytes32" + }, + { + "astId": 17295, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_roninToken", + "offset": 0, + "slot": "120", + "type": "t_mapping(t_address,t_struct(MappedToken)13003_storage)" + }, + { + "astId": 17300, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "withdrawalHash", + "offset": 0, + "slot": "121", + "type": "t_mapping(t_uint256,t_bytes32)" + }, + { + "astId": 17305, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "withdrawalLocked", + "offset": 0, + "slot": "122", + "type": "t_mapping(t_uint256,t_bool)" + }, + { + "astId": 17308, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "______deprecatedBridgeOperatorAddedBlock", + "offset": 0, + "slot": "123", + "type": "t_uint256" + }, + { + "astId": 17311, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "______deprecatedBridgeOperators", + "offset": 0, + "slot": "124", + "type": "t_uint256" + } + ], + "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, + "t_array(t_bytes32)dyn_storage": { + "base": "t_bytes32", + "encoding": "dynamic_array", + "label": "bytes32[]", + "numberOfBytes": "32" + }, + "t_array(t_uint256)49_storage": { + "base": "t_uint256", + "encoding": "inplace", + "label": "uint256[49]", + "numberOfBytes": "1568" + }, + "t_array(t_uint256)50_storage": { + "base": "t_uint256", + "encoding": "inplace", + "label": "uint256[50]", + "numberOfBytes": "1600" + }, + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_bytes32": { + "encoding": "inplace", + "label": "bytes32", + "numberOfBytes": "32" + }, + "t_contract(IWETH)12355": { + "encoding": "inplace", + "label": "contract IWETH", + "numberOfBytes": "20" + }, + "t_enum(Standard)16303": { + "encoding": "inplace", + "label": "enum Token.Standard", + "numberOfBytes": "1" + }, + "t_mapping(t_address,t_bool)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => bool)", + "numberOfBytes": "32", + "value": "t_bool" + }, + "t_mapping(t_address,t_struct(MappedToken)13003_storage)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => struct MappedTokenConsumer.MappedToken)", + "numberOfBytes": "32", + "value": "t_struct(MappedToken)13003_storage" + }, + "t_mapping(t_address,t_uint256)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_mapping(t_bytes32,t_struct(AddressSet)4026_storage)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => struct EnumerableSet.AddressSet)", + "numberOfBytes": "32", + "value": "t_struct(AddressSet)4026_storage" + }, + "t_mapping(t_bytes32,t_struct(RoleData)19_storage)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => struct AccessControl.RoleData)", + "numberOfBytes": "32", + "value": "t_struct(RoleData)19_storage" + }, + "t_mapping(t_bytes32,t_uint256)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_mapping(t_uint256,t_bool)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => bool)", + "numberOfBytes": "32", + "value": "t_bool" + }, + "t_mapping(t_uint256,t_bytes32)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => bytes32)", + "numberOfBytes": "32", + "value": "t_bytes32" + }, + "t_struct(AddressSet)4026_storage": { + "encoding": "inplace", + "label": "struct EnumerableSet.AddressSet", + "members": [ + { + "astId": 4025, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_inner", + "offset": 0, + "slot": "0", + "type": "t_struct(Set)3725_storage" + } + ], + "numberOfBytes": "64" + }, + "t_struct(MappedToken)13003_storage": { + "encoding": "inplace", + "label": "struct MappedTokenConsumer.MappedToken", + "members": [ + { + "astId": 13000, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "erc", + "offset": 0, + "slot": "0", + "type": "t_enum(Standard)16303" + }, + { + "astId": 13002, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "tokenAddr", + "offset": 1, + "slot": "0", + "type": "t_address" + } + ], + "numberOfBytes": "32" + }, + "t_struct(RoleData)19_storage": { + "encoding": "inplace", + "label": "struct AccessControl.RoleData", + "members": [ + { + "astId": 16, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "members", + "offset": 0, + "slot": "0", + "type": "t_mapping(t_address,t_bool)" + }, + { + "astId": 18, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "adminRole", + "offset": 0, + "slot": "1", + "type": "t_bytes32" + } + ], + "numberOfBytes": "64" + }, + "t_struct(Set)3725_storage": { + "encoding": "inplace", + "label": "struct EnumerableSet.Set", + "members": [ + { + "astId": 3720, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_values", + "offset": 0, + "slot": "0", + "type": "t_array(t_bytes32)dyn_storage" + }, + { + "astId": 3724, + "contract": "contracts/mainchain/MainchainGatewayV3.sol:MainchainGatewayV3", + "label": "_indexes", + "offset": 0, + "slot": "1", + "type": "t_mapping(t_bytes32,t_uint256)" + } + ], + "numberOfBytes": "64" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ethereum/MainchainGatewayV3Proxy.json b/deployments/ethereum/MainchainGatewayV3Proxy.json new file mode 100644 index 000000000..8de7aa931 --- /dev/null +++ b/deployments/ethereum/MainchainGatewayV3Proxy.json @@ -0,0 +1,440 @@ +{ + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "receipt": { + "to": null, + "from": "0xAA1d342354d755EC515F40e7d5E83CB4184bB9ee", + "contractAddress": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "transactionIndex": 194, + "gasUsed": "1827074", + "logsBloom": "0x002000040002000000004000000040004000000090000000020000000000000000000004000020000000000002000000000180000000000000000000000c04008400000001000000000000000000020000000000000400000004000000000000800a000003000000000000000000080000000180000800000000000200000000000000000010000040000000000000002000000000000000000000000880000100040000000004100001000001000040050000000000000800100800000000004020002000002000000000000040000000080000042000010e000000000060008000100000080008100008400000000000000000000800008000204000004100", + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4", + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "logs": [ + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x0000000000000000000000002dba725f0a3485382a7f125a31cbf4361539af73" + ], + "data": "0x", + "logIndex": 577, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x0000000000000000000000002da02ac5f19ae362a4121718d990e655eb628d96", + "0x000000000000000000000000aa1d342354d755ec515f40e7d5e83cb4184bb9ee" + ], + "data": "0x", + "logIndex": 578, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x9d2334c23be647e994f27a72c5eee42a43d5bdcfe15bb88e939103c2b114cbaf" + ], + "data": "0x000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", + "logIndex": 579, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0xef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169" + ], + "data": "0x0000000000000000000000009ecbb8dbff5d32643fe308b399cef26d384875ba", + "logIndex": 580, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x0000000000000000000000000000000000000000000000000000000000000046", + "0x0000000000000000000000000000000000000000000000000000000000000064" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 581, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x31312c97b89cc751b832d98fd459b967a2c3eef3b49757d1cf5ebaa12bb6eee1", + "0x0000000000000000000000000000000000000000000000000000000000000001", + "0x000000000000000000000000000000000000000000000000000000000000005a", + "0x0000000000000000000000000000000000000000000000000000000000000064" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 582, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0xa4f03cc9c0e0aeb5b71b4ec800702753f65748c2cf3064695ba8e8b46be70444" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c99a6a985ed2cac1ef41640596c5a5f9f4e19ef5000000000000000000000000a8754b9fa15fc18bb59458815510e40a12cd201400000000000000000000000097a9107c1793bc407d6f527b77e7fff4d812bece0000000000000000000000000b7007c13325c48911f73a2dad5fa5dcbf808adc00000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 583, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x80bc635c452ae67f12f9b6f12ad4daa6dbbc04eeb9ebb87d354ce10c0e210dc0" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000031c3cf283a409800000000000000000000000000000000000000000000000000000000000010547d7a000000000000000000000000000000000000000000000f202c815cf040f40000000000000000000000000000000000000000000000000000000000e8d4a51000", + "logIndex": 584, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x64557254143204d91ba2d95acb9fda1e5fea55f77efd028685765bc1e94dd4b5" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb4800000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000001f1a617924685f0000000000000000000000000000000000000000000000000000000000000a34ce6c4000000000000000000000000000000000000000000009741bd0da16289880000000000000000000000000000000000000000000000000000000009184e72a000", + "logIndex": 585, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0xb05f5de88ae0294ebb6f67c5af2fcbbd593cc6bdfe543e2869794a4c8ce3ea50" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a", + "logIndex": 586, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0xb5d2963614d72181b4df1f993d45b83edf42fa19710f0204217ba1b3e183bb73" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb4800000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000009b83e75db609db0000000000000000000000000000000000000000000000000000000000003308081d400000000000000000000000000000000000000000002f448b14426ecafa8000000000000000000000000000000000000000000000000000000002d79883d2000", + "logIndex": 587, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4", + "0x00000000000000000000000058a8dcfdef9bb5e164382562317c13d6f2a706f4", + "0x000000000000000000000000aa1d342354d755ec515f40e7d5e83cb4184bb9ee" + ], + "data": "0x", + "logIndex": 588, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4", + "0x000000000000000000000000e5eb222996967be79468c28ba39d665fd96e8b30", + "0x000000000000000000000000aa1d342354d755ec515f40e7d5e83cb4184bb9ee" + ], + "data": "0x", + "logIndex": 589, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4", + "0x0000000000000000000000006bfc8f9096446d350713c4eb9d9b68866f87a9d0", + "0x000000000000000000000000aa1d342354d755ec515f40e7d5e83cb4184bb9ee" + ], + "data": "0x", + "logIndex": 590, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x5e5712e902fff5e704bc4d506ad976718319e019e9d2a872528a01a85db433e4", + "0x000000000000000000000000ad99fc4d593bae582c2ca83acd98ae6fcdb36192", + "0x000000000000000000000000aa1d342354d755ec515f40e7d5e83cb4184bb9ee" + ], + "data": "0x", + "logIndex": 591, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + }, + { + "transactionIndex": 194, + "blockNumber": 15006576, + "transactionHash": "0x8f2924a52e63564c9cb0b119d72dc8290daa39c59cbe02e7f1ab6b2160ac9aa4", + "address": "0x64192819Ac13Ef72bF6b5AE239AC672B43a9AF08", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000661e14a43173191d65951fbf7285749f416cbc8c", + "logIndex": 592, + "blockHash": "0xf2389283ec5272bd73e63d6e86fe856ad646e0eecd6370e1860f700185f100c4" + } + ], + "blockNumber": 15006576, + "cumulativeGasUsed": "22689977", + "status": 1, + "byzantium": true + }, + "args": [ + "0x2DBA725f0a3485382a7F125a31cBF4361539aF73", + "0x661E14A43173191d65951fbf7285749F416cbC8C", + "0x180ff1e90000000000000000000000002da02ac5f19ae362a4121718d990e655eb628d96000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc20000000000000000000000009ecbb8dbff5d32643fe308b399cef26d384875ba00000000000000000000000000000000000000000000000000000000000007e40000000000000000000000000000000000000000000000000000000000000046000000000000000000000000000000000000000000000000000000000000005a00000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000038000000000000000000000000000000000000000000000000000000000000006800000000000000000000000000000000000000000000000000000000000000060000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c99a6a985ed2cac1ef41640596c5a5f9f4e19ef5000000000000000000000000a8754b9fa15fc18bb59458815510e40a12cd201400000000000000000000000097a9107c1793bc407d6f527b77e7fff4d812bece0000000000000000000000000b7007c13325c48911f73a2dad5fa5dcbf808adc000000000000000000000000000000000000000000000000000000000000000400000000000000000000000058a8dcfdef9bb5e164382562317c13d6f2a706f4000000000000000000000000e5eb222996967be79468c28ba39d665fd96e8b300000000000000000000000006bfc8f9096446d350713c4eb9d9b68866f87a9d0000000000000000000000000ad99fc4d593bae582c2ca83acd98ae6fcdb361920000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001c000000000000000000000000000000000000000000000000000000000000002600000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000031c3cf283a409800000000000000000000000000000000000000000000000000000000000010547d7a000000000000000000000000000000000000000000000f202c815cf040f40000000000000000000000000000000000000000000000000000000000e8d4a5100000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000001f1a617924685f0000000000000000000000000000000000000000000000000000000000000a34ce6c4000000000000000000000000000000000000000000009741bd0da16289880000000000000000000000000000000000000000000000000000000009184e72a0000000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000a00000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000009b83e75db609db0000000000000000000000000000000000000000000000000000000000003308081d400000000000000000000000000000000000000000002f448b14426ecafa8000000000000000000000000000000000000000000000000000000002d79883d200000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" + ], + "numDeployments": 1, + "solcInputHash": "267ddc12ed25de7b99c302796e5ae6c1", + "metadata": "{\"compiler\":{\"version\":\"0.8.9+commit.e5eed63a\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"functionDelegateCall(bytes)\":{\"notice\":\"The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/v0.8/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":1000},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializating the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n assert(_IMPLEMENTATION_SLOT == bytes32(uint256(keccak256(\\\"eip1967.proxy.implementation\\\")) - 1));\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0x6309f9f39dc6f4f45a24f296543867aa358e32946cd6b2874627a996d606b3a0\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overriden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internall call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overriden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0x0edeb16b9821ae2b16e9d69c383b38d3ad2fbb3e0c06cf809a0786d96e602551\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n assert(_ADMIN_SLOT == bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0x140055a64cf579d622e04f5a198595832bf2cb193cd0005f4f2d4d61ca906253\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2ccf9d2313a313d41a791505f2b5abfdc62191b5d4334f7f7a82691c088a1c87\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xfe1b7a9aa2a530a9e705b220e26cd584e2fbdc9602a3a1066032b12816b46aca\",\"license\":\"MIT\"},\"contracts/v0.8/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * @notice The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xdf52e28697a1af7d7e176d35df4cfa2eee79a19eb74df6eac7704953d3583449\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x6080604052604051620011353803806200113583398101604081905262000026916200051f565b82828282816200005860017f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbd620005ff565b600080516020620010ee8339815191521462000078576200007862000625565b6200008682826000620000ed565b50620000b6905060017fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6104620005ff565b600080516020620010ce83398151915214620000d657620000d662000625565b620000e1826200012a565b5050505050506200068e565b620000f88362000185565b600082511180620001065750805b156200012557620001238383620001c760201b620002dd1760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f62000155620001f6565b604080516001600160a01b03928316815291841660208301520160405180910390a162000182816200022f565b50565b6200019081620002e4565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6060620001ef83836040518060600160405280602781526020016200110e6027913962000387565b9392505050565b600062000220600080516020620010ce83398151915260001b6200046d60201b620002851760201c565b546001600160a01b0316919050565b6001600160a01b0381166200029a5760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b80620002c3600080516020620010ce83398151915260001b6200046d60201b620002851760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b620002fa816200047060201b620003091760201c565b6200035e5760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b606482015260840162000291565b80620002c3600080516020620010ee83398151915260001b6200046d60201b620002851760201c565b60606001600160a01b0384163b620003f15760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b606482015260840162000291565b600080856001600160a01b0316856040516200040e91906200063b565b600060405180830381855af49150503d80600081146200044b576040519150601f19603f3d011682016040523d82523d6000602084013e62000450565b606091505b509092509050620004638282866200047f565b9695505050505050565b90565b6001600160a01b03163b151590565b6060831562000490575081620001ef565b825115620004a15782518084602001fd5b8160405162461bcd60e51b815260040162000291919062000659565b80516001600160a01b0381168114620004d557600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b838110156200050d578181015183820152602001620004f3565b83811115620001235750506000910152565b6000806000606084860312156200053557600080fd5b6200054084620004bd565b92506200055060208501620004bd565b60408501519092506001600160401b03808211156200056e57600080fd5b818601915086601f8301126200058357600080fd5b815181811115620005985762000598620004da565b604051601f8201601f19908116603f01168101908382118183101715620005c357620005c3620004da565b81604052828152896020848701011115620005dd57600080fd5b620005f0836020830160208801620004f0565b80955050505050509250925092565b6000828210156200062057634e487b7160e01b600052601160045260246000fd5b500390565b634e487b7160e01b600052600160045260246000fd5b600082516200064f818460208701620004f0565b9190910192915050565b60208152600082518060208401526200067a816040850160208701620004f0565b601f01601f19169190910160400192915050565b610a30806200069e6000396000f3fe6080604052600436106100695760003560e01c80635c60da1b116100435780635c60da1b146100c65780638f283970146100f7578063f851a4401461011757610078565b80633659cfe6146100805780634bb5274a146100a05780634f1ef286146100b357610078565b366100785761007661012c565b005b61007661012c565b34801561008c57600080fd5b5061007661009b3660046107da565b610146565b6100766100ae366004610824565b61018d565b6100766100c13660046108d5565b6101dc565b3480156100d257600080fd5b506100db61024d565b6040516001600160a01b03909116815260200160405180910390f35b34801561010357600080fd5b506100766101123660046107da565b610288565b34801561012357600080fd5b506100db6102b2565b610134610318565b61014461013f6103d2565b6103dc565b565b61014e6103fb565b6001600160a01b0316336001600160a01b03161415610185576101828160405180602001604052806000815250600061042e565b50565b61018261012c565b6101956103fb565b6001600160a01b0316336001600160a01b031614156101855760006101b86103d2565b9050600080835160208501845af43d6000803e8080156101d7573d6000f35b3d6000fd5b6101e46103fb565b6001600160a01b0316336001600160a01b03161415610245576102408383838080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152506001925061042e915050565b505050565b61024061012c565b60006102576103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103d2565b905090565b61028561012c565b90565b6102906103fb565b6001600160a01b0316336001600160a01b031614156101855761018281610459565b60006102bc6103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103fb565b606061030283836040518060600160405280602781526020016109d4602791396104ad565b9392505050565b6001600160a01b03163b151590565b6103206103fb565b6001600160a01b0316336001600160a01b031614156101445760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f7879207461726760648201527f6574000000000000000000000000000000000000000000000000000000000000608482015260a4015b60405180910390fd5b60006102786105a1565b3660008037600080366000845af43d6000803e8080156101d7573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b610437836105c9565b6000825111806104445750805b156102405761045383836102dd565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f6104826103fb565b604080516001600160a01b03928316815291841660208301520160405180910390a161018281610609565b60606001600160a01b0384163b61052c5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f60448201527f6e7472616374000000000000000000000000000000000000000000000000000060648201526084016103c9565b600080856001600160a01b0316856040516105479190610984565b600060405180830381855af49150503d8060008114610582576040519150601f19603f3d011682016040523d82523d6000602084013e610587565b606091505b50915091506105978282866106e1565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc61041f565b6105d28161071a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166106855760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016103c9565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b039290921691909117905550565b606083156106f0575081610302565b8251156107005782518084602001fd5b8160405162461bcd60e51b81526004016103c991906109a0565b6001600160a01b0381163b6107975760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201527f6f74206120636f6e74726163740000000000000000000000000000000000000060648201526084016103c9565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6106a8565b80356001600160a01b03811681146107d557600080fd5b919050565b6000602082840312156107ec57600080fd5b610302826107be565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b60006020828403121561083657600080fd5b813567ffffffffffffffff8082111561084e57600080fd5b818401915084601f83011261086257600080fd5b813581811115610874576108746107f5565b604051601f8201601f19908116603f0116810190838211818310171561089c5761089c6107f5565b816040528281528760208487010111156108b557600080fd5b826020860160208301376000928101602001929092525095945050505050565b6000806000604084860312156108ea57600080fd5b6108f3846107be565b9250602084013567ffffffffffffffff8082111561091057600080fd5b818601915086601f83011261092457600080fd5b81358181111561093357600080fd5b87602082850101111561094557600080fd5b6020830194508093505050509250925092565b60005b8381101561097357818101518382015260200161095b565b838111156104535750506000910152565b60008251610996818460208701610958565b9190910192915050565b60208152600082518060208401526109bf816040850160208701610958565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203b097b88c1cee26a495ec73a23404fc321233caf781f72087a86ad15c85d8f1d64736f6c63430008090033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100695760003560e01c80635c60da1b116100435780635c60da1b146100c65780638f283970146100f7578063f851a4401461011757610078565b80633659cfe6146100805780634bb5274a146100a05780634f1ef286146100b357610078565b366100785761007661012c565b005b61007661012c565b34801561008c57600080fd5b5061007661009b3660046107da565b610146565b6100766100ae366004610824565b61018d565b6100766100c13660046108d5565b6101dc565b3480156100d257600080fd5b506100db61024d565b6040516001600160a01b03909116815260200160405180910390f35b34801561010357600080fd5b506100766101123660046107da565b610288565b34801561012357600080fd5b506100db6102b2565b610134610318565b61014461013f6103d2565b6103dc565b565b61014e6103fb565b6001600160a01b0316336001600160a01b03161415610185576101828160405180602001604052806000815250600061042e565b50565b61018261012c565b6101956103fb565b6001600160a01b0316336001600160a01b031614156101855760006101b86103d2565b9050600080835160208501845af43d6000803e8080156101d7573d6000f35b3d6000fd5b6101e46103fb565b6001600160a01b0316336001600160a01b03161415610245576102408383838080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152506001925061042e915050565b505050565b61024061012c565b60006102576103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103d2565b905090565b61028561012c565b90565b6102906103fb565b6001600160a01b0316336001600160a01b031614156101855761018281610459565b60006102bc6103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103fb565b606061030283836040518060600160405280602781526020016109d4602791396104ad565b9392505050565b6001600160a01b03163b151590565b6103206103fb565b6001600160a01b0316336001600160a01b031614156101445760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f7879207461726760648201527f6574000000000000000000000000000000000000000000000000000000000000608482015260a4015b60405180910390fd5b60006102786105a1565b3660008037600080366000845af43d6000803e8080156101d7573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b610437836105c9565b6000825111806104445750805b156102405761045383836102dd565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f6104826103fb565b604080516001600160a01b03928316815291841660208301520160405180910390a161018281610609565b60606001600160a01b0384163b61052c5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f60448201527f6e7472616374000000000000000000000000000000000000000000000000000060648201526084016103c9565b600080856001600160a01b0316856040516105479190610984565b600060405180830381855af49150503d8060008114610582576040519150601f19603f3d011682016040523d82523d6000602084013e610587565b606091505b50915091506105978282866106e1565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc61041f565b6105d28161071a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166106855760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016103c9565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b039290921691909117905550565b606083156106f0575081610302565b8251156107005782518084602001fd5b8160405162461bcd60e51b81526004016103c991906109a0565b6001600160a01b0381163b6107975760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201527f6f74206120636f6e74726163740000000000000000000000000000000000000060648201526084016103c9565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6106a8565b80356001600160a01b03811681146107d557600080fd5b919050565b6000602082840312156107ec57600080fd5b610302826107be565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b60006020828403121561083657600080fd5b813567ffffffffffffffff8082111561084e57600080fd5b818401915084601f83011261086257600080fd5b813581811115610874576108746107f5565b604051601f8201601f19908116603f0116810190838211818310171561089c5761089c6107f5565b816040528281528760208487010111156108b557600080fd5b826020860160208301376000928101602001929092525095945050505050565b6000806000604084860312156108ea57600080fd5b6108f3846107be565b9250602084013567ffffffffffffffff8082111561091057600080fd5b818601915086601f83011261092457600080fd5b81358181111561093357600080fd5b87602082850101111561094557600080fd5b6020830194508093505050509250925092565b60005b8381101561097357818101518382015260200161095b565b838111156104535750506000910152565b60008251610996818460208701610958565b9190910192915050565b60208152600082518060208401526109bf816040850160208701610958565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203b097b88c1cee26a495ec73a23404fc321233caf781f72087a86ad15c85d8f1d64736f6c63430008090033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "functionDelegateCall(bytes)": { + "notice": "The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ethereum/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json b/deployments/ethereum/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json new file mode 100644 index 000000000..399649bc2 --- /dev/null +++ b/deployments/ethereum/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV2 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV2.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV2 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV2-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV2 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV2 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV2.sol\";\n\ncontract MainchainGatewayV2 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV2Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV2.sol\";\n\ncontract MockRoninGatewayV2Extended is RoninGatewayV2 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV2.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV2.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV2 is\n GatewayV2,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_MIGRATOR = keccak256(\"WITHDRAWAL_MIGRATOR\");\n\n /// @dev Flag indicating whether the withdrawal migrate progress is done\n bool public withdrawalMigrated;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata _withdrawalMigrators,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n\n for (uint256 _i; _i < _withdrawalMigrators.length; ) {\n _grantRole(WITHDRAWAL_MIGRATOR, _withdrawalMigrators[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @dev Migrates withdrawals.\n *\n * Requirements:\n * - The method caller is the migrator.\n * - The arrays have the same length and its length larger than 0.\n *\n */\n function migrateWithdrawals(\n Transfer.Request[] calldata _requests,\n address[] calldata _requesters\n ) external onlyRole(WITHDRAWAL_MIGRATOR) {\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n if (!(_requesters.length == _requests.length && _requests.length > 0)) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _requests.length; ) {\n MappedToken memory _token = getMainchainToken(_requests[_i].tokenAddr, 1);\n if (_requests[_i].info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _storeAsReceipt(_requests[_i], 1, _requesters[_i], _token.tokenAddr);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Mark the migration as done.\n */\n function markWithdrawalMigrated() external {\n if (!(hasRole(DEFAULT_ADMIN_ROLE, msg.sender) || hasRole(WITHDRAWAL_MIGRATOR, msg.sender))) {\n revert ErrUnauthorized(msg.sig, RoleAccess.WITHDRAWAL_MIGRATOR);\n }\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n\n withdrawalMigrated = true;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](_validators.length);\n for (uint256 _i = 0; _i < _validators.length; ) {\n _signatures[_i] = _withdrawalSig[_withdrawalId][_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata _withdrawals,\n bytes[] calldata _signatures\n ) external whenNotPaused onlyBridgeOperator {\n address _validator = msg.sender;\n\n if (!(_withdrawals.length > 0 && _withdrawals.length == _signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawals.length; ) {\n _id = _withdrawals[_i];\n _withdrawalSig[_id][_validator] = _signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, _id, _validator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[_id];\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, bytes32(_id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, _id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory _receipt, address _validator, uint256 _minVoteWeight) internal {\n uint256 _id = _receipt.id;\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (_receipt.ronin.chainId != block.chainid)\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(_receipt.ronin.tokenAddr, _receipt.mainchain.chainId);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[_receipt.mainchain.chainId][_id];\n bytes32 _receiptHash = _receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, _receiptHash);\n emit DepositVoted(_validator, _id, _receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _receipt.info.handleAssetTransfer(payable(_receipt.ronin.addr), _receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id\n );\n emit Deposited(_receiptHash, _receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ethereum/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json b/deployments/ethereum/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json new file mode 100644 index 000000000..ae441e766 --- /dev/null +++ b/deployments/ethereum/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV3.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV3 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV3-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV3 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV3.sol\";\n\ncontract MainchainGatewayV3 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV3Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV3.sol\";\n\ncontract MockRoninGatewayV3Extended is RoninGatewayV3 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV3.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV3.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV3 is\n GatewayV3,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value)\n bool private ___deprecated4;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata /* _withdrawalMigrators */,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getWithdrawalSignatures(\n uint256 withdrawalId,\n address[] calldata operators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](operators.length);\n for (uint256 _i = 0; _i < operators.length; ) {\n _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata withdrawals,\n bytes[] calldata signatures\n ) external whenNotPaused onlyBridgeOperator {\n address operator = msg.sender;\n\n if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < withdrawals.length; ) {\n id = withdrawals[_i];\n _withdrawalSig[id][operator] = signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id];\n VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal {\n uint256 id = receipt.id;\n receipt.info.validate();\n if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId);\n\n if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id];\n bytes32 _receiptHash = receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash);\n emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n receipt.id\n );\n emit Deposited(_receiptHash, receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/goerli/MainchainGatewayV2Proxy.json b/deployments/goerli/MainchainGatewayV3Proxy.json similarity index 100% rename from deployments/goerli/MainchainGatewayV2Proxy.json rename to deployments/goerli/MainchainGatewayV3Proxy.json diff --git a/deployments/ronin-mainnet/BridgeRewardLogic.json b/deployments/ronin-mainnet/BridgeRewardLogic.json new file mode 100644 index 000000000..46207fdcf --- /dev/null +++ b/deployments/ronin-mainnet/BridgeRewardLogic.json @@ -0,0 +1,732 @@ +{ + "address": "0x6d457615C1B08ab8d5ec2a0410440E23A17F7c38", + "abi": [ + { + "inputs": [], + "stateMutability": "payable", + "type": "constructor" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "currentBalance", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "sendAmount", + "type": "uint256" + } + ], + "name": "ErrInsufficientBalance", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidArguments", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrRecipientRevert", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "latestRewardedPeriod", + "type": "uint256" + } + ], + "name": "ErrSyncTooFarPeriod", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrUnauthorizedCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "address", + "name": "operator", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount", + "type": "uint256" + } + ], + "name": "BridgeRewardScatterFailed", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "address", + "name": "operator", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount", + "type": "uint256" + } + ], + "name": "BridgeRewardScattered", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "address", + "name": "operator", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount", + "type": "uint256" + } + ], + "name": "BridgeRewardSlashed", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint256", + "name": "requestingPeriod", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "latestPeriod", + "type": "uint256" + } + ], + "name": "BridgeRewardSyncTooFarPeriod", + "type": "event" + }, + { + "anonymous": false, + "inputs": [], + "name": "BridgeTrackingIncorrectlyResponded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "from", + "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "balanceBefore", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount", + "type": "uint256" + } + ], + "name": "SafeReceived", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint256", + "name": "newRewardPerPeriod", + "type": "uint256" + } + ], + "name": "UpdatedRewardPerPeriod", + "type": "event" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "operators", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "ballots", + "type": "uint256[]" + }, + { + "internalType": "uint256", + "name": "totalBallot", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "totalVote", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "period", + "type": "uint256" + } + ], + "name": "execSyncReward", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getLatestRewardedPeriod", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getRewardPerPeriod", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getTotalRewardScattered", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getTotalRewardToppedUp", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeManagerContract", + "type": "address" + }, + { + "internalType": "address", + "name": "bridgeTrackingContract", + "type": "address" + }, + { + "internalType": "address", + "name": "bridgeSlashContract", + "type": "address" + }, + { + "internalType": "address", + "name": "validatorSetContract", + "type": "address" + }, + { + "internalType": "address", + "name": "dposGA", + "type": "address" + }, + { + "internalType": "uint256", + "name": "rewardPerPeriod", + "type": "uint256" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "initializeREP2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "receiveRON", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "rewardPerPeriod", + "type": "uint256" + } + ], + "name": "setRewardPerPeriod", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "periodLength", + "type": "uint256" + } + ], + "name": "syncReward", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "transactionHash": "0xcfa93c49d0d70792ce34ecf08c63df3f2775d5e5bfb1701498a72726f2150581", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x6d457615C1B08ab8d5ec2a0410440E23A17F7c38", + "transactionIndex": 2, + "gasUsed": "1381648", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000082000000000000000000000000001000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0xf0a9d990126082ae1764baee9d65186bea031655894f5f8161e91dfa2673e75b", + "transactionHash": "0xcfa93c49d0d70792ce34ecf08c63df3f2775d5e5bfb1701498a72726f2150581", + "logs": [ + { + "transactionIndex": 2, + "blockNumber": 28368660, + "transactionHash": "0xcfa93c49d0d70792ce34ecf08c63df3f2775d5e5bfb1701498a72726f2150581", + "address": "0x6d457615C1B08ab8d5ec2a0410440E23A17F7c38", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", + "logIndex": 7, + "blockHash": "0xf0a9d990126082ae1764baee9d65186bea031655894f5f8161e91dfa2673e75b" + } + ], + "blockNumber": 28368660, + "cumulativeGasUsed": "1590778", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 1, + "solcInputHash": "d5751a51f1eb067d18a7dec1633f85eb", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"currentBalance\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"sendAmount\",\"type\":\"uint256\"}],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidArguments\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"latestRewardedPeriod\",\"type\":\"uint256\"}],\"name\":\"ErrSyncTooFarPeriod\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrUnauthorizedCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"operator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"BridgeRewardScatterFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"operator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"BridgeRewardScattered\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"operator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"BridgeRewardSlashed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"requestingPeriod\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"latestPeriod\",\"type\":\"uint256\"}],\"name\":\"BridgeRewardSyncTooFarPeriod\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[],\"name\":\"BridgeTrackingIncorrectlyResponded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"balanceBefore\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"SafeReceived\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"newRewardPerPeriod\",\"type\":\"uint256\"}],\"name\":\"UpdatedRewardPerPeriod\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"operators\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"ballots\",\"type\":\"uint256[]\"},{\"internalType\":\"uint256\",\"name\":\"totalBallot\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"totalVote\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"execSyncReward\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getLatestRewardedPeriod\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getRewardPerPeriod\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getTotalRewardScattered\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getTotalRewardToppedUp\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeManagerContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeTrackingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeSlashContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"validatorSetContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"dposGA\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"rewardPerPeriod\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeREP2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"receiveRON\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"rewardPerPeriod\",\"type\":\"uint256\"}],\"name\":\"setRewardPerPeriod\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"periodLength\",\"type\":\"uint256\"}],\"name\":\"syncReward\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrInsufficientBalance(bytes4,uint256,uint256)\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInvalidArguments(bytes4)\":[{\"details\":\"Error indicating that arguments are invalid.\"}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrRecipientRevert(bytes4)\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnauthorizedCall(bytes4)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"execSyncReward(address[],uint256[],uint256,uint256,uint256)\":{\"details\":\"The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getLatestRewardedPeriod()\":{\"details\":\"External function to retrieve the latest rewarded period in the contract.\",\"returns\":{\"_0\":\"latestRewardedPeriod The latest rewarded period value.\"}},\"getRewardPerPeriod()\":{\"details\":\"Getter for all bridge operators per period.\"},\"getTotalRewardScattered()\":{\"details\":\"Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\",\"returns\":{\"_0\":\"totalRewardScattered The total rewards scattered value.\"}},\"getTotalRewardToppedUp()\":{\"details\":\"Retrieve the total amount of rewards that have been topped up in the contract.\",\"returns\":{\"_0\":\"totalRewardToppedUp The total rewards topped up value.\"}},\"initializeREP2()\":{\"details\":\"Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\"},\"receiveRON()\":{\"details\":\"Receives RON from any address.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setRewardPerPeriod(uint256)\":{\"details\":\"Setter for all bridge operators per period.\"},\"syncReward(uint256)\":{\"details\":\"This function allows bridge operators to manually synchronize the reward for a given period length.\",\"params\":{\"periodLength\":\"The length of the reward period for which synchronization is requested.\"}}},\"stateVariables\":{\"LATEST_REWARDED_PERIOD_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\\\") - 1\"},\"REWARD_INFO_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\\\") - 1\"},\"REWARD_PER_PERIOD_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\\\") - 1\"},\"TOTAL_REWARDS_SCATTERED_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\\\") - 1\"},\"TOTAL_REWARDS_TOPPED_UP_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\\\") - 1\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/BridgeReward.sol\":\"BridgeReward\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert(bytes4 msgSig);\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable recipient, uint256 amount) internal {\\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\\n }\\n\\n /**\\n * @dev Send `amount` RON to the address `recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\\n return _unsafeSendRON(recipient, amount);\\n }\\n\\n /**\\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRONLimitGas(\\n address payable recipient,\\n uint256 amount,\\n uint256 gas\\n ) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount, gas: gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xdece837caa8da00fe031b8139ada009330b8bef149af12b535913c021ab94d0e\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract BridgeTrackingHelper {\\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /**\\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\\n * @param totalBallot The total number of ballots available for the tracking response.\\n * @param totalVote The total number of votes recorded in the tracking response.\\n * @param ballots An array containing the individual ballot counts in the tracking response.\\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\\n */\\n function _isValidBridgeTrackingResponse(\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256[] memory ballots\\n ) internal pure returns (bool valid) {\\n valid = true;\\n uint256 sumBallot;\\n uint256 length = ballots.length;\\n\\n unchecked {\\n for (uint256 i; i < length; ++i) {\\n if (ballots[i] > totalVote) {\\n valid = false;\\n break;\\n }\\n\\n sumBallot += ballots[i];\\n }\\n }\\n\\n valid = valid && (sumBallot <= totalBallot);\\n }\\n}\\n\",\"keccak256\":\"0x2da3d7c4b8d48228761b48c79beb04a55065d24a3469a16043b00c45873844e5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeReward.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { IBridgeRewardEvents } from \\\"./events/IBridgeRewardEvents.sol\\\";\\n\\ninterface IBridgeReward is IBridgeRewardEvents {\\n /**\\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\\n * @param periodLength The length of the reward period for which synchronization is requested.\\n */\\n function syncReward(uint256 periodLength) external;\\n\\n /**\\n * @dev Receives RON from any address.\\n */\\n function receiveRON() external payable;\\n\\n /**\\n * @dev Invoke calculate and transfer reward to operators based on their performance.\\n *\\n * Requirements:\\n * - This method is only called once each period.\\n * - The caller must be the bridge tracking contract or a bridge operator.\\n */\\n function execSyncReward(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external;\\n\\n /**\\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\\n * @return totalRewardToppedUp The total rewards topped up value.\\n */\\n function getTotalRewardToppedUp() external view returns (uint256);\\n\\n /**\\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\\n * @return totalRewardScattered The total rewards scattered value.\\n */\\n function getTotalRewardScattered() external view returns (uint256);\\n\\n /**\\n * @dev Getter for all bridge operators per period.\\n */\\n function getRewardPerPeriod() external view returns (uint256);\\n\\n /**\\n * @dev External function to retrieve the latest rewarded period in the contract.\\n * @return latestRewardedPeriod The latest rewarded period value.\\n */\\n function getLatestRewardedPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Setter for all bridge operators per period.\\n */\\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\\n}\\n\",\"keccak256\":\"0x781f5b4e9257231f008457d41b277058fe6a2b7366ecd3d64bce2591d0eaa216\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeSlashEvents } from \\\"./events/IBridgeSlashEvents.sol\\\";\\n\\n/**\\n * @title IBridgeSlash\\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\\n */\\ninterface IBridgeSlash is IBridgeSlashEvents {\\n /**\\n * @dev Slashes the unavailability of bridge operators during a specific period.\\n * @param period The period to slash the bridge operators for.\\n */\\n function execSlashBridgeOperators(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external;\\n\\n /**\\n * @dev Returns the penalize durations for the specified bridge operators.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @return untilPeriods The penalized periods for the bridge operators.\\n */\\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\\n\\n /**\\n * @dev Retrieves the added periods of the specified bridge operators.\\n * @param bridgeOperators An array of bridge operator addresses.\\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\\n */\\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\\n\\n /**\\n * @dev Gets the slash tier based on the given ballot and total ballots.\\n * @param ballot The ballot count for a bridge operator.\\n * @param totalVote The total vote count for the period.\\n * @return tier The slash tier.\\n */\\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\\n\\n /**\\n * @dev Retrieve the penalty durations for different slash tiers.\\n * @return penaltyDurations The array of penalty durations for each slash tier.\\n */\\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 1 slashing.\\n * @return The duration in period number for Tier 1 slashing.\\n */\\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 2 slashing.\\n * @return The duration in period number for Tier 2 slashing.\\n */\\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the threshold duration for removing bridge operators.\\n * @return The duration in period number that exceeds which a bridge operator will be removed.\\n */\\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\\n\\n /**\\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\\n * @return minimumVoteThreshold The minimum vote threshold value.\\n */\\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0xc28c29288397fa0a3a4f3b2c33e31158c6e09611dbbcb6db9ca99195256b1c34\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\\n\\n /**\\n * @dev Returns the block that allow incomming mutable call.\\n */\\n function startedAtBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVote(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallot(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(\\n uint256 _period,\\n address[] calldata _bridgeOperators\\n ) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\\n}\\n\",\"keccak256\":\"0x092841025351341cf7ff9cbf0eb6ef78752ffd2b1af329cb6048996d20c789a9\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeRewardEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeRewardEvents {\\n /**\\n * @dev Reward-related information for a bridge operator.\\n * @param claimed The amount of rewards claimed by the bridge operator.\\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\\n */\\n struct BridgeRewardInfo {\\n uint256 claimed;\\n uint256 slashed;\\n }\\n\\n /**\\n * @dev Emitted when RON are safely received as rewards in the contract.\\n * @param from The address of the sender who transferred RON tokens as rewards.\\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\\n * @param amount The amount of RON received.\\n */\\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\\n /// @dev Event emitted when the reward per period config is updated.\\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the requesting period to sync is too far.\\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\\n}\\n\",\"keccak256\":\"0xf0efa7130ba933552a16b7fb4040f23e276a41d8d698f27b11c3f82930916e51\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeSlashEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeSlashEvents {\\n /**\\n * @dev Enumeration representing the slashing tiers for bridge operators.\\n */\\n enum Tier {\\n Tier0,\\n Tier1,\\n Tier2\\n }\\n\\n /**\\n * @dev Struct representing the status of a bridge operator.\\n */\\n struct BridgeSlashInfo {\\n uint128 slashUntilPeriod;\\n uint128 newlyAddedAtPeriod;\\n }\\n\\n /**\\n * @dev Event emitted when a bridge operator is slashed.\\n * @param tier The slash tier of the operator.\\n * @param bridgeOperator The address of the slashed bridge operator.\\n * @param period The period in which the operator is slashed.\\n * @param slashUntilPeriod The period until which the operator is penalized.\\n */\\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\\n\\n /**\\n * @dev Emitted when a removal request is made for a bridge operator.\\n * @param period The period for which the removal request is made.\\n * @param bridgeOperator The address of the bridge operator being requested for removal.\\n */\\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\\n}\\n\",\"keccak256\":\"0x9611e0d8b85b50bdd8ba9e8148564af526e78ccce5d202e7c84043d2d2ccb75f\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\"},\"contracts/ronin/gateway/BridgeReward.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { Initializable } from \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport { BridgeTrackingHelper } from \\\"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\\\";\\nimport { ContractType, HasContracts } from \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { RONTransferHelper } from \\\"../../extensions/RONTransferHelper.sol\\\";\\nimport { IRoninValidatorSet } from \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport { IBridgeManager } from \\\"../../interfaces/bridge/IBridgeManager.sol\\\";\\nimport { IBridgeTracking } from \\\"../../interfaces/bridge/IBridgeTracking.sol\\\";\\nimport { IBridgeReward } from \\\"../../interfaces/bridge/IBridgeReward.sol\\\";\\nimport { IBridgeSlash } from \\\"../../interfaces/bridge/IBridgeSlash.sol\\\";\\nimport { Math } from \\\"../../libraries/Math.sol\\\";\\nimport { TUint256Slot } from \\\"../../types/Types.sol\\\";\\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\\\") - 1\\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\\\") - 1\\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\\\") - 1\\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\\\") - 1\\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\\\") - 1\\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\\n\\n address private immutable _self;\\n\\n constructor() payable {\\n _self = address(this);\\n _disableInitializers();\\n }\\n\\n function initialize(\\n address bridgeManagerContract,\\n address bridgeTrackingContract,\\n address bridgeSlashContract,\\n address validatorSetContract,\\n address dposGA,\\n uint256 rewardPerPeriod\\n ) external payable initializer {\\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\\n _setContract(ContractType.VALIDATOR, validatorSetContract);\\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\\n _setRewardPerPeriod(rewardPerPeriod);\\n _receiveRON();\\n }\\n\\n /**\\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\\n */\\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\\n require(getLatestRewardedPeriod() == type(uint256).max, \\\"already init rep 2\\\");\\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function receiveRON() external payable {\\n _receiveRON();\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function syncReward(uint256 periodLength) external {\\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\\n\\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n\\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\\n\\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\\n\\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\\n\\n for (uint256 i = 1; i <= periodLength; ) {\\n unchecked {\\n _syncReward({\\n operators: operators,\\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\\n period: latestRewardedPeriod += i\\n });\\n\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n *\\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\\n */\\n function execSyncReward(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\\n if (operators.length == 0) return;\\n\\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\\n unchecked {\\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\\n }\\n LATEST_REWARDED_PERIOD_SLOT.store(period);\\n\\n _syncReward({\\n operators: operators,\\n ballots: ballots,\\n totalBallot: totalBallot,\\n totalVote: totalVote,\\n period: period\\n });\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function getTotalRewardToppedUp() external view returns (uint256) {\\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function getTotalRewardScattered() external view returns (uint256) {\\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\\n }\\n\\n /**\\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\\n */\\n function _receiveRON() internal {\\n // prevent transfer RON directly to logic contract\\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\\n\\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\\n }\\n\\n /**\\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\\n * @param operators An array containing the addresses of bridge operators to receive rewards.\\n * @param ballots An array containing the individual ballot counts for each bridge operator.\\n * @param totalBallot The total number of available ballots for the period.\\n * @param totalVote The total number of votes recorded for the period.\\n * @param period The period for which the rewards are being synchronized.\\n */\\n function _syncReward(\\n address[] memory operators,\\n uint256[] memory ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) internal {\\n uint256 numBridgeOperators = operators.length;\\n uint256 rewardPerPeriod = getRewardPerPeriod();\\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\\n // Validate should share the reward equally\\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\\n\\n uint256 reward;\\n bool shouldSlash;\\n uint256 sumRewards;\\n\\n for (uint256 i; i < numBridgeOperators; ) {\\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\\n shouldShareEqually: shouldShareEqually,\\n numBridgeOperators: numBridgeOperators,\\n rewardPerPeriod: rewardPerPeriod,\\n ballot: ballots[i],\\n totalBallot: totalBallot,\\n period: period,\\n slashUntilPeriod: slashedDurationList[i]\\n });\\n\\n sumRewards += shouldSlash ? 0 : reward;\\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\\n }\\n\\n /**\\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\\n * informed data or there is no ballot in a day.\\n *\\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\\n */\\n function _shouldShareEqually(\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256[] memory ballots\\n ) internal returns (bool shareEqually) {\\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\\n if (!valid) {\\n emit BridgeTrackingIncorrectlyResponded();\\n }\\n\\n return !valid || totalBallot == 0;\\n }\\n\\n /**\\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\\n * @param rewardPerPeriod The total reward available for the period.\\n * @param ballot The individual ballot count of the bridge operator for the period.\\n * @param totalBallot The total number of available ballots for the period.\\n * @param period The period for which the reward is being calculated.\\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\\n * @return reward The calculated reward for the bridge operator.\\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\\n */\\n function _calcRewardAndCheckSlashedStatus(\\n bool shouldShareEqually,\\n uint256 numBridgeOperators,\\n uint256 rewardPerPeriod,\\n uint256 ballot,\\n uint256 totalBallot,\\n uint256 period,\\n uint256 slashUntilPeriod\\n ) internal pure returns (uint256 reward, bool shouldSlash) {\\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\\n }\\n\\n /**\\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\\n * @param period The period to check if it should be slashed.\\n * @param slashDuration The duration until which periods should be considered as slashed.\\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\\n */\\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\\n return period <= slashDuration;\\n }\\n\\n /**\\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\\n * @param rewardPerPeriod The total reward available for the period.\\n * @param ballot The individual ballot count of the bridge operator for the period.\\n * @param totalBallot The total number of available ballots for the period.\\n * @return reward The calculated reward for the bridge operator.\\n */\\n function _calcReward(\\n bool shouldShareEqually,\\n uint256 numBridgeOperators,\\n uint256 rewardPerPeriod,\\n uint256 ballot,\\n uint256 totalBallot\\n ) internal pure returns (uint256 reward) {\\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\\n // Else shares the bridge operators reward proportionally\\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\\n }\\n\\n /**\\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\\n */\\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\\n\\n if (shouldSlash) {\\n _iRewardInfo.slashed += reward;\\n emit BridgeRewardSlashed(period, operator, reward);\\n } else {\\n _iRewardInfo.claimed += reward;\\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\\n emit BridgeRewardScattered(period, operator, reward);\\n } else {\\n emit BridgeRewardScatterFailed(period, operator, reward);\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function getRewardPerPeriod() public view returns (uint256) {\\n return REWARD_PER_PERIOD_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function getLatestRewardedPeriod() public view returns (uint256) {\\n return LATEST_REWARDED_PERIOD_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IBridgeReward\\n */\\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\\n _setRewardPerPeriod(rewardPerPeriod);\\n }\\n\\n /**\\n * @dev Internal function for setting the total reward per period.\\n * Emit an {UpdatedRewardPerPeriod} event after set.\\n */\\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\\n }\\n\\n /**\\n * @dev Internal helper for querying slash info of a list of operators.\\n */\\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\\n }\\n\\n /**\\n * @dev Internal helper for querying whether an address is an operator.\\n */\\n function _isBridgeOperator(address operator) internal view returns (bool) {\\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\\n */\\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\\n assembly (\\\"memory-safe\\\") {\\n rewardInfo.slot := REWARD_INFO_SLOT\\n }\\n }\\n}\\n\",\"keccak256\":\"0x7a0f81147e76a0418d3535dd880c1e6e6d8c471adee164b4050d5ad5d4cd822b\",\"license\":\"MIT\"},\"contracts/types/Types.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { LibTUint256Slot } from \\\"./operations/LibTUint256Slot.sol\\\";\\n\\ntype TUint256Slot is bytes32;\\n\\nusing {\\n LibTUint256Slot.add,\\n LibTUint256Slot.sub,\\n LibTUint256Slot.mul,\\n LibTUint256Slot.div,\\n LibTUint256Slot.load,\\n LibTUint256Slot.store,\\n LibTUint256Slot.addAssign,\\n LibTUint256Slot.subAssign,\\n LibTUint256Slot.preDecrement,\\n LibTUint256Slot.postDecrement,\\n LibTUint256Slot.preIncrement,\\n LibTUint256Slot.postIncrement\\n} for TUint256Slot global;\\n\",\"keccak256\":\"0x20ab58f1c9ae4936f9dd9891d064301d78ef508c1dd2ce0c19a7b5b81d530e36\",\"license\":\"MIT\"},\"contracts/types/operations/LibTUint256Slot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { TUint256Slot } from \\\"../Types.sol\\\";\\n\\n/**\\n * @title LibTUint256Slot\\n * @dev Library for handling unsigned 256-bit integers.\\n */\\nlibrary LibTUint256Slot {\\n /// @dev value is equal to bytes4(keccak256(\\\"Panic(uint256)\\\"))\\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\\n /// @dev error code for {Arithmetic over/underflow} error\\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\\n /// @dev error code for {Division or modulo by 0} error\\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\\n\\n /**\\n * @dev Loads the value of the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @return val The loaded value.\\n */\\n function load(TUint256Slot self) internal view returns (uint256 val) {\\n assembly {\\n val := sload(self)\\n }\\n }\\n\\n /**\\n * @dev Stores a value into the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to be stored.\\n */\\n function store(TUint256Slot self, uint256 other) internal {\\n assembly {\\n sstore(self, other)\\n }\\n }\\n\\n /**\\n * @dev Multiplies the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to multiply by.\\n * @return res The resulting value after multiplication.\\n */\\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n if iszero(iszero(storedVal)) {\\n res := mul(storedVal, other)\\n\\n // Overflow check\\n if iszero(eq(other, div(res, storedVal))) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n }\\n\\n /**\\n * @dev Divides the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to divide by.\\n * @return res The resulting value after division.\\n */\\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n // revert if divide by zero\\n if iszero(other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, DIVISION_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n res := div(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction.\\n */\\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n\\n // Underflow check\\n if lt(storedVal, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n\\n res := sub(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition.\\n */\\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n res := add(storedVal, other)\\n\\n // Overflow check\\n if lt(res, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after incrementing.\\n */\\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = addAssign(self, 1);\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\\n * @param self The TUint256Slot variable.\\n * @return res The original value before incrementing.\\n */\\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res + 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after decrementing.\\n */\\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = subAssign(self, 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value before decrementing.\\n */\\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res - 1);\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition and storage.\\n */\\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = add(self, other));\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction and storage.\\n */\\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = sub(self, other));\\n }\\n}\\n\",\"keccak256\":\"0xe10c089459baf373494d76b00e582d49f6e43c500ab0f1657d53afc2fa472cbb\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x60a060405230608052610010610015565b6100d5565b600054610100900460ff16156100815760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff90811610156100d3576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b60805161178f6100f06000396000610ca0015261178f6000f3fe6080604052600436106100a75760003560e01c80638f7c34a2116100645780638f7c34a21461015357806395b6ef0c14610168578063a6bd67881461017b578063ad43663e1461019b578063de981f1b146101b0578063f5dbc4ee146101e857600080fd5b806324a2f579146100ac57806334087952146100ce5780633b154455146100f657806359f778df1461010b5780636bcb6fd614610113578063865e6fd314610133575b600080fd5b3480156100b857600080fd5b506100cc6100c73660046111d7565b6101fd565b005b3480156100da57600080fd5b506100e3610522565b6040519081526020015b60405180910390f35b34801561010257600080fd5b506100cc610551565b6100cc610644565b34801561011f57600080fd5b506100cc61012e36600461123c565b61064e565b34801561013f57600080fd5b506100cc61014e3660046112e7565b61078d565b34801561015f57600080fd5b506100e36107ac565b6100cc61017636600461131e565b6107c4565b34801561018757600080fd5b506100cc6101963660046111d7565b61092e565b3480156101a757600080fd5b506100e3610942565b3480156101bc57600080fd5b506101d06101cb366004611397565b61096c565b6040516001600160a01b0390911681526020016100ed565b3480156101f457600080fd5b506100e36109e7565b61020633610a11565b61023a576000356001600160e01b031916604051638f47e7e360e01b815260040161023191906113b9565b60405180910390fd5b60006102446107ac565b90506000610252600861096c565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561028f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102b391906113ce565b90508181116102e3576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b806102ee84846113fd565b111561031b576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b61033360008051602061173a83398151915284610a8f565b506000610340600b61096c565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa15801561037d573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526103a5919081019061147b565b905060006103b3600361096c565b905060015b85811161051a5761051283836001600160a01b031663f67e815288876040518363ffffffff1660e01b81526004016103f192919061155e565b600060405180830381865afa15801561040e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610436919081019061157f565b60405163692f6a6360e11b8152600481018990526001600160a01b0386169063d25ed4c690602401602060405180830381865afa15801561047b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061049f91906113ce565b604051637153af9b60e11b8152600481018a90526001600160a01b0387169063e2a75f3690602401602060405180830381865afa1580156104e4573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061050891906113ce565b9885019889610aa6565b6001016103b8565b505050505050565b600061054c7f3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f45490565b905090565b600461055c81610ba6565b6000196105676107ac565b146105a95760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b6044820152606401610231565b61063560016105b8600861096c565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105f5573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061061991906113ce565b6106239190611605565b60008051602061173a83398151915255565b61064160046000610bf2565b50565b61064c610c96565b565b600361065981610ba6565b868514610687576000356001600160e01b0319166040516306b5667560e21b815260040161023191906113b9565b86156107835760006106976107ac565b9050806001018310156106cb576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b806001018311156106f957604051634e4e051560e01b81526004810184905260248101829052604401610231565b5061071160008051602061173a833981519152839055565b61078388888080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808c0282810182019093528b82529093508b92508a918291850190849080828437600092019190915250899250889150879050610aa6565b5050505050505050565b610795610d77565b61079e81610dd1565b6107a88282610bf2565b5050565b600061054c60008051602061173a8339815191525490565b600054610100900460ff16158080156107e45750600054600160ff909116105b806107fe5750303b1580156107fe575060005460ff166001145b6108615760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610231565b6000805460ff191660011790558015610884576000805461ff0019166101001790555b61088f600b88610bf2565b61089a600387610bf2565b6108a5600c86610bf2565b6108b0600885610bf2565b6108bb600484610bf2565b60001960008051602061173a833981519152556108d782610e07565b6108df610c96565b8015610925576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050565b600b61093981610ba6565b6107a882610e07565b600061054c7f90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec739105490565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156109a3576109a3611618565b60ff1681526020810191909152604001600020546001600160a01b03169050806109e2578160405163409140df60e11b81526004016102319190611642565b919050565b600061054c7f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c645490565b6000610a1d600b61096c565b604051635a02d57960e11b81526001600160a01b038481166004830152919091169063b405aaf290602401602060405180830381865afa158015610a65573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a899190611650565b92915050565b6000610a8983610a9f8585610e66565b9250829055565b84516000610ab2610942565b90506000610abf88610e85565b90506000610ace87878a610f03565b90506000806000805b87811015610b6c57610b208589898f8581518110610af757610af7611672565b60200260200101518f8e8c8881518110610b1357610b13611672565b6020026020010151610f56565b909450925082610b305783610b33565b60005b610b3d90836113fd565b9150610b64898e8381518110610b5557610b55611672565b60200260200101518686610f77565b600101610ad7565b50610b977f3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f482610a8f565b50505050505050505050505050565b610baf8161096c565b6001600160a01b0316336001600160a01b031614610641576000356001600160e01b03191681336040516320e0f98d60e21b815260040161023193929190611688565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c2857610c28611618565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610c6957610c69611618565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000163003610ced576000356001600160e01b031916604051638f47e7e360e01b815260040161023191906113b9565b337f7ae161a1f0ef2537f5ff1957021a50412e72abdc6a941a77d99361e91e7f3c3d610d377f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c645490565b604080519182523460208301520160405180910390a26106417f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c6434610a8f565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b0316331461064c576000356001600160e01b0319166001604051620f948f60ea1b81526004016102319291906116bf565b806001600160a01b03163b60000361064157604051630bfc64a360e21b81526001600160a01b0382166004820152602401610231565b610e307f90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910829055565b6040518181527f9b40b647582311cc8f5f7d27e7ce206d126605d1625b8299b7edaeefd869ef259060200160405180910390a150565b8154810181811015610a8957634e487b7160005260116020526024601cfd5b6060610e91600c61096c565b6001600160a01b0316635311153b836040518263ffffffff1660e01b8152600401610ebc91906116ed565b6000604051808303816000875af1158015610edb573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610a89919081019061157f565b600080610f118585856110cf565b905080610f42576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a15b801580610f4d575084155b95945050505050565b600082821015610f69898989898961114c565b915097509795505050505050565b6001600160a01b03831660009081527f518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a6020526040902081156110175782816001016000828254610fc891906113fd565b9091555050604080516001600160a01b03861681526020810185905286917fb3d061c3ef3991b0d4b09f4c8b551d137c3d1e014cf5326462d3d1f6a8dfb9c291015b60405180910390a26110c8565b8281600001600082825461102b91906113fd565b9091555061103d905084846000611177565b1561108357604080516001600160a01b03861681526020810185905286917fbab0baccb39371d4d5206b519fe58d21cae9cdd63a1d1b5146ecdf405fd93152910161100a565b604080516001600160a01b03861681526020810185905286917f74b217634c5a7790ce69770c5e35019970453d4da3973769e7d6cdb7ce6816a1910160405180910390a25b5050505050565b8051600190600090815b8181101561113457858582815181106110f4576110f4611672565b6020026020010151111561110b5760009350611134565b84818151811061111d5761111d611672565b6020026020010151830192508060010190506110d9565b508280156111425750858211155b9695505050505050565b60008561116d578161115e8486611700565b6111689190611717565b611142565b6111428585611717565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146111c7576040519150601f19603f3d011682016040523d82523d6000602084013e6111cc565b606091505b509095945050505050565b6000602082840312156111e957600080fd5b5035919050565b60008083601f84011261120257600080fd5b50813567ffffffffffffffff81111561121a57600080fd5b6020830191508360208260051b850101111561123557600080fd5b9250929050565b600080600080600080600060a0888a03121561125757600080fd5b873567ffffffffffffffff8082111561126f57600080fd5b61127b8b838c016111f0565b909950975060208a013591508082111561129457600080fd5b506112a18a828b016111f0565b989b979a50986040810135976060820135975060809091013595509350505050565b8035601081106109e257600080fd5b6001600160a01b038116811461064157600080fd5b600080604083850312156112fa57600080fd5b611303836112c3565b91506020830135611313816112d2565b809150509250929050565b60008060008060008060c0878903121561133757600080fd5b8635611342816112d2565b95506020870135611352816112d2565b94506040870135611362816112d2565b93506060870135611372816112d2565b92506080870135611382816112d2565b8092505060a087013590509295509295509295565b6000602082840312156113a957600080fd5b6113b2826112c3565b9392505050565b6001600160e01b031991909116815260200190565b6000602082840312156113e057600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b80820180821115610a8957610a896113e7565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561144f5761144f611410565b604052919050565b600067ffffffffffffffff82111561147157611471611410565b5060051b60200190565b6000602080838503121561148e57600080fd5b825167ffffffffffffffff8111156114a557600080fd5b8301601f810185136114b657600080fd5b80516114c96114c482611457565b611426565b81815260059190911b820183019083810190878311156114e857600080fd5b928401925b8284101561150f578351611500816112d2565b825292840192908401906114ed565b979650505050505050565b600081518084526020808501945080840160005b838110156115535781516001600160a01b03168752958201959082019060010161152e565b509495945050505050565b828152604060208201526000611577604083018461151a565b949350505050565b6000602080838503121561159257600080fd5b825167ffffffffffffffff8111156115a957600080fd5b8301601f810185136115ba57600080fd5b80516115c86114c482611457565b81815260059190911b820183019083810190878311156115e757600080fd5b928401925b8284101561150f578351825292840192908401906115ec565b81810381811115610a8957610a896113e7565b634e487b7160e01b600052602160045260246000fd5b6010811061163e5761163e611618565b9052565b60208101610a89828461162e565b60006020828403121561166257600080fd5b815180151581146113b257600080fd5b634e487b7160e01b600052603260045260246000fd5b6001600160e01b031984168152606081016116a6602083018561162e565b6001600160a01b03929092166040919091015292915050565b6001600160e01b03198316815260408101600b83106116e0576116e0611618565b8260208301529392505050565b6020815260006113b2602083018461151a565b8082028115828204841417610a8957610a896113e7565b60008261173457634e487b7160e01b600052601260045260246000fd5b50049056fe2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619a2646970667358221220c1c598adda978082b59773d95adf13181c8fb2d5a7934f4d7411162caabd26ae64736f6c63430008110033", + "deployedBytecode": "0x6080604052600436106100a75760003560e01c80638f7c34a2116100645780638f7c34a21461015357806395b6ef0c14610168578063a6bd67881461017b578063ad43663e1461019b578063de981f1b146101b0578063f5dbc4ee146101e857600080fd5b806324a2f579146100ac57806334087952146100ce5780633b154455146100f657806359f778df1461010b5780636bcb6fd614610113578063865e6fd314610133575b600080fd5b3480156100b857600080fd5b506100cc6100c73660046111d7565b6101fd565b005b3480156100da57600080fd5b506100e3610522565b6040519081526020015b60405180910390f35b34801561010257600080fd5b506100cc610551565b6100cc610644565b34801561011f57600080fd5b506100cc61012e36600461123c565b61064e565b34801561013f57600080fd5b506100cc61014e3660046112e7565b61078d565b34801561015f57600080fd5b506100e36107ac565b6100cc61017636600461131e565b6107c4565b34801561018757600080fd5b506100cc6101963660046111d7565b61092e565b3480156101a757600080fd5b506100e3610942565b3480156101bc57600080fd5b506101d06101cb366004611397565b61096c565b6040516001600160a01b0390911681526020016100ed565b3480156101f457600080fd5b506100e36109e7565b61020633610a11565b61023a576000356001600160e01b031916604051638f47e7e360e01b815260040161023191906113b9565b60405180910390fd5b60006102446107ac565b90506000610252600861096c565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561028f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102b391906113ce565b90508181116102e3576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b806102ee84846113fd565b111561031b576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b61033360008051602061173a83398151915284610a8f565b506000610340600b61096c565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa15801561037d573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526103a5919081019061147b565b905060006103b3600361096c565b905060015b85811161051a5761051283836001600160a01b031663f67e815288876040518363ffffffff1660e01b81526004016103f192919061155e565b600060405180830381865afa15801561040e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610436919081019061157f565b60405163692f6a6360e11b8152600481018990526001600160a01b0386169063d25ed4c690602401602060405180830381865afa15801561047b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061049f91906113ce565b604051637153af9b60e11b8152600481018a90526001600160a01b0387169063e2a75f3690602401602060405180830381865afa1580156104e4573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061050891906113ce565b9885019889610aa6565b6001016103b8565b505050505050565b600061054c7f3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f45490565b905090565b600461055c81610ba6565b6000196105676107ac565b146105a95760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b6044820152606401610231565b61063560016105b8600861096c565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105f5573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061061991906113ce565b6106239190611605565b60008051602061173a83398151915255565b61064160046000610bf2565b50565b61064c610c96565b565b600361065981610ba6565b868514610687576000356001600160e01b0319166040516306b5667560e21b815260040161023191906113b9565b86156107835760006106976107ac565b9050806001018310156106cb576000356001600160e01b03191660405163053265f160e01b815260040161023191906113b9565b806001018311156106f957604051634e4e051560e01b81526004810184905260248101829052604401610231565b5061071160008051602061173a833981519152839055565b61078388888080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808c0282810182019093528b82529093508b92508a918291850190849080828437600092019190915250899250889150879050610aa6565b5050505050505050565b610795610d77565b61079e81610dd1565b6107a88282610bf2565b5050565b600061054c60008051602061173a8339815191525490565b600054610100900460ff16158080156107e45750600054600160ff909116105b806107fe5750303b1580156107fe575060005460ff166001145b6108615760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610231565b6000805460ff191660011790558015610884576000805461ff0019166101001790555b61088f600b88610bf2565b61089a600387610bf2565b6108a5600c86610bf2565b6108b0600885610bf2565b6108bb600484610bf2565b60001960008051602061173a833981519152556108d782610e07565b6108df610c96565b8015610925576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050565b600b61093981610ba6565b6107a882610e07565b600061054c7f90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec739105490565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156109a3576109a3611618565b60ff1681526020810191909152604001600020546001600160a01b03169050806109e2578160405163409140df60e11b81526004016102319190611642565b919050565b600061054c7f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c645490565b6000610a1d600b61096c565b604051635a02d57960e11b81526001600160a01b038481166004830152919091169063b405aaf290602401602060405180830381865afa158015610a65573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a899190611650565b92915050565b6000610a8983610a9f8585610e66565b9250829055565b84516000610ab2610942565b90506000610abf88610e85565b90506000610ace87878a610f03565b90506000806000805b87811015610b6c57610b208589898f8581518110610af757610af7611672565b60200260200101518f8e8c8881518110610b1357610b13611672565b6020026020010151610f56565b909450925082610b305783610b33565b60005b610b3d90836113fd565b9150610b64898e8381518110610b5557610b55611672565b60200260200101518686610f77565b600101610ad7565b50610b977f3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f482610a8f565b50505050505050505050505050565b610baf8161096c565b6001600160a01b0316336001600160a01b031614610641576000356001600160e01b03191681336040516320e0f98d60e21b815260040161023193929190611688565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c2857610c28611618565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610c6957610c69611618565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6001600160a01b037f0000000000000000000000000000000000000000000000000000000000000000163003610ced576000356001600160e01b031916604051638f47e7e360e01b815260040161023191906113b9565b337f7ae161a1f0ef2537f5ff1957021a50412e72abdc6a941a77d99361e91e7f3c3d610d377f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c645490565b604080519182523460208301520160405180910390a26106417f9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c6434610a8f565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b0316331461064c576000356001600160e01b0319166001604051620f948f60ea1b81526004016102319291906116bf565b806001600160a01b03163b60000361064157604051630bfc64a360e21b81526001600160a01b0382166004820152602401610231565b610e307f90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910829055565b6040518181527f9b40b647582311cc8f5f7d27e7ce206d126605d1625b8299b7edaeefd869ef259060200160405180910390a150565b8154810181811015610a8957634e487b7160005260116020526024601cfd5b6060610e91600c61096c565b6001600160a01b0316635311153b836040518263ffffffff1660e01b8152600401610ebc91906116ed565b6000604051808303816000875af1158015610edb573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610a89919081019061157f565b600080610f118585856110cf565b905080610f42576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a15b801580610f4d575084155b95945050505050565b600082821015610f69898989898961114c565b915097509795505050505050565b6001600160a01b03831660009081527f518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a6020526040902081156110175782816001016000828254610fc891906113fd565b9091555050604080516001600160a01b03861681526020810185905286917fb3d061c3ef3991b0d4b09f4c8b551d137c3d1e014cf5326462d3d1f6a8dfb9c291015b60405180910390a26110c8565b8281600001600082825461102b91906113fd565b9091555061103d905084846000611177565b1561108357604080516001600160a01b03861681526020810185905286917fbab0baccb39371d4d5206b519fe58d21cae9cdd63a1d1b5146ecdf405fd93152910161100a565b604080516001600160a01b03861681526020810185905286917f74b217634c5a7790ce69770c5e35019970453d4da3973769e7d6cdb7ce6816a1910160405180910390a25b5050505050565b8051600190600090815b8181101561113457858582815181106110f4576110f4611672565b6020026020010151111561110b5760009350611134565b84818151811061111d5761111d611672565b6020026020010151830192508060010190506110d9565b508280156111425750858211155b9695505050505050565b60008561116d578161115e8486611700565b6111689190611717565b611142565b6111428585611717565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146111c7576040519150601f19603f3d011682016040523d82523d6000602084013e6111cc565b606091505b509095945050505050565b6000602082840312156111e957600080fd5b5035919050565b60008083601f84011261120257600080fd5b50813567ffffffffffffffff81111561121a57600080fd5b6020830191508360208260051b850101111561123557600080fd5b9250929050565b600080600080600080600060a0888a03121561125757600080fd5b873567ffffffffffffffff8082111561126f57600080fd5b61127b8b838c016111f0565b909950975060208a013591508082111561129457600080fd5b506112a18a828b016111f0565b989b979a50986040810135976060820135975060809091013595509350505050565b8035601081106109e257600080fd5b6001600160a01b038116811461064157600080fd5b600080604083850312156112fa57600080fd5b611303836112c3565b91506020830135611313816112d2565b809150509250929050565b60008060008060008060c0878903121561133757600080fd5b8635611342816112d2565b95506020870135611352816112d2565b94506040870135611362816112d2565b93506060870135611372816112d2565b92506080870135611382816112d2565b8092505060a087013590509295509295509295565b6000602082840312156113a957600080fd5b6113b2826112c3565b9392505050565b6001600160e01b031991909116815260200190565b6000602082840312156113e057600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b80820180821115610a8957610a896113e7565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561144f5761144f611410565b604052919050565b600067ffffffffffffffff82111561147157611471611410565b5060051b60200190565b6000602080838503121561148e57600080fd5b825167ffffffffffffffff8111156114a557600080fd5b8301601f810185136114b657600080fd5b80516114c96114c482611457565b611426565b81815260059190911b820183019083810190878311156114e857600080fd5b928401925b8284101561150f578351611500816112d2565b825292840192908401906114ed565b979650505050505050565b600081518084526020808501945080840160005b838110156115535781516001600160a01b03168752958201959082019060010161152e565b509495945050505050565b828152604060208201526000611577604083018461151a565b949350505050565b6000602080838503121561159257600080fd5b825167ffffffffffffffff8111156115a957600080fd5b8301601f810185136115ba57600080fd5b80516115c86114c482611457565b81815260059190911b820183019083810190878311156115e757600080fd5b928401925b8284101561150f578351825292840192908401906115ec565b81810381811115610a8957610a896113e7565b634e487b7160e01b600052602160045260246000fd5b6010811061163e5761163e611618565b9052565b60208101610a89828461162e565b60006020828403121561166257600080fd5b815180151581146113b257600080fd5b634e487b7160e01b600052603260045260246000fd5b6001600160e01b031984168152606081016116a6602083018561162e565b6001600160a01b03929092166040919091015292915050565b6001600160e01b03198316815260408101600b83106116e0576116e0611618565b8260208301529392505050565b6020815260006113b2602083018461151a565b8082028115828204841417610a8957610a896113e7565b60008261173457634e487b7160e01b600052601260045260246000fd5b50049056fe2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619a2646970667358221220c1c598adda978082b59773d95adf13181c8fb2d5a7934f4d7411162caabd26ae64736f6c63430008110033", + "devdoc": { + "errors": { + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrInsufficientBalance(bytes4,uint256,uint256)": [ + { + "details": "Error of sender has insufficient balance." + } + ], + "ErrInvalidArguments(bytes4)": [ + { + "details": "Error indicating that arguments are invalid." + } + ], + "ErrLengthMismatch(bytes4)": [ + { + "details": "Error indicating a mismatch in the length of input parameters or arrays for a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that has a length mismatch." + } + } + ], + "ErrRecipientRevert(bytes4)": [ + { + "details": "Error of recipient not accepting RON when transfer RON." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnauthorizedCall(bytes4)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "execSyncReward(address[],uint256[],uint256,uint256,uint256)": { + "details": "The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1." + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getLatestRewardedPeriod()": { + "details": "External function to retrieve the latest rewarded period in the contract.", + "returns": { + "_0": "latestRewardedPeriod The latest rewarded period value." + } + }, + "getRewardPerPeriod()": { + "details": "Getter for all bridge operators per period." + }, + "getTotalRewardScattered()": { + "details": "Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.", + "returns": { + "_0": "totalRewardScattered The total rewards scattered value." + } + }, + "getTotalRewardToppedUp()": { + "details": "Retrieve the total amount of rewards that have been topped up in the contract.", + "returns": { + "_0": "totalRewardToppedUp The total rewards topped up value." + } + }, + "initializeREP2()": { + "details": "Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`" + }, + "receiveRON()": { + "details": "Receives RON from any address." + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, + "setRewardPerPeriod(uint256)": { + "details": "Setter for all bridge operators per period." + }, + "syncReward(uint256)": { + "details": "This function allows bridge operators to manually synchronize the reward for a given period length.", + "params": { + "periodLength": "The length of the reward period for which synchronization is requested." + } + } + }, + "stateVariables": { + "LATEST_REWARDED_PERIOD_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1" + }, + "REWARD_INFO_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1" + }, + "REWARD_PER_PERIOD_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1" + }, + "TOTAL_REWARDS_SCATTERED_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1" + }, + "TOTAL_REWARDS_TOPPED_UP_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1" + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 1373, + "contract": "contracts/ronin/gateway/BridgeReward.sol:BridgeReward", + "label": "_initialized", + "offset": 0, + "slot": "0", + "type": "t_uint8" + }, + { + "astId": 1376, + "contract": "contracts/ronin/gateway/BridgeReward.sol:BridgeReward", + "label": "_initializing", + "offset": 1, + "slot": "0", + "type": "t_bool" + } + ], + "types": { + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/BridgeRewardProxy.json b/deployments/ronin-mainnet/BridgeRewardProxy.json new file mode 100644 index 000000000..dcfa7a987 --- /dev/null +++ b/deployments/ronin-mainnet/BridgeRewardProxy.json @@ -0,0 +1,354 @@ +{ + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "transactionIndex": 0, + "gasUsed": "828410", + "logsBloom": "0x00000000082000000000004000000000400002000000000000000008000000000000000000000200000200000000000000000080020084010000000002000000400000000000800000000000200002000000000000000000000000000000000008000000000000800000000000000410000000800000000000000004008002000080000180000000000000000000000000000000000480000000000000800000000000000000000000000000000400000000080000800000002000000000408040000120001000000000000000040000002000088400001010000000000000200000001000000000100000000000800900000000000000040000000000000000", + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa", + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "logs": [ + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x0000000000000000000000006d457615c1b08ab8d5ec2a0410440e23a17f7c38" + ], + "data": "0x", + "logIndex": 0, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x000000000000000000000000000000000000000000000000000000000000000b", + "0x0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a" + ], + "data": "0x", + "logIndex": 1, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000003", + "0x0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2" + ], + "data": "0x", + "logIndex": 2, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x000000000000000000000000000000000000000000000000000000000000000c", + "0x000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24" + ], + "data": "0x", + "logIndex": 3, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000008", + "0x000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "data": "0x", + "logIndex": 4, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000004", + "0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3" + ], + "data": "0x", + "logIndex": 5, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x9b40b647582311cc8f5f7d27e7ce206d126605d1625b8299b7edaeefd869ef25" + ], + "data": "0x0000000000000000000000000000000000000000000000948556223a29d26934", + "logIndex": 6, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x7ae161a1f0ef2537f5ff1957021a50412e72abdc6a941a77d99361e91e7f3c3d", + "0x0000000000000000000000004d58ea7231c394d5804e8b06b1365915f906e27f" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 7, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000001", + "logIndex": 8, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + }, + { + "transactionIndex": 0, + "blockNumber": 28595547, + "transactionHash": "0x98538f03d217f6393deb84f85cfdfb7b82c9a7ece88d64c21fca60c733cd43fd", + "address": "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a", + "logIndex": 9, + "blockHash": "0x3a55bbe7d762d3186ae6f40d501b91fb60d3c3237f217246573182934e92d1aa" + } + ], + "blockNumber": 28595547, + "cumulativeGasUsed": "828410", + "status": 1, + "byzantium": true + }, + "args": [ + "0x6d457615C1B08ab8d5ec2a0410440E23A17F7c38", + "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "0x95b6ef0c0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c30000000000000000000000000000000000000000000000948556223a29d26934" + ], + "numDeployments": 2, + "solcInputHash": "f9f5036294d35a88da21dae55fc8b26c", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405260405162000f5f38038062000f5f83398101604081905262000026916200048d565b8282828281620000398282600062000053565b506200004790508262000090565b505050505050620005c0565b6200005e83620000eb565b6000825111806200006c5750805b156200008b576200008983836200012d60201b620002911760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f620000bb6200015c565b604080516001600160a01b03928316815291841660208301520160405180910390a1620000e88162000195565b50565b620000f6816200024a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b606062000155838360405180606001604052806027815260200162000f3860279139620002fe565b9392505050565b60006200018660008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b546001600160a01b0316919050565b6001600160a01b038116620002005760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b806200022960008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b6200026081620003e760201b620002bd1760201c565b620002c45760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401620001f7565b80620002297f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc60001b620003e460201b6200024d1760201c565b60606001600160a01b0384163b620003685760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401620001f7565b600080856001600160a01b0316856040516200038591906200056d565b600060405180830381855af49150503d8060008114620003c2576040519150601f19603f3d011682016040523d82523d6000602084013e620003c7565b606091505b509092509050620003da828286620003f6565b9695505050505050565b90565b6001600160a01b03163b151590565b606083156200040757508162000155565b825115620004185782518084602001fd5b8160405162461bcd60e51b8152600401620001f791906200058b565b80516001600160a01b03811681146200044c57600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b83811015620004845781810151838201526020016200046a565b50506000910152565b600080600060608486031215620004a357600080fd5b620004ae8462000434565b9250620004be6020850162000434565b60408501519092506001600160401b0380821115620004dc57600080fd5b818601915086601f830112620004f157600080fd5b81518181111562000506576200050662000451565b604051601f8201601f19908116603f0116810190838211818310171562000531576200053162000451565b816040528281528960208487010111156200054b57600080fd5b6200055e83602083016020880162000467565b80955050505050509250925092565b600082516200058181846020870162000467565b9190910192915050565b6020815260008251806020840152620005ac81604085016020870162000467565b601f01601f19169190910160400192915050565b61094880620005d06000396000f3fe6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/BridgeSlashLogic.json b/deployments/ronin-mainnet/BridgeSlashLogic.json new file mode 100644 index 000000000..358a48988 --- /dev/null +++ b/deployments/ronin-mainnet/BridgeSlashLogic.json @@ -0,0 +1,763 @@ +{ + "address": "0x763e39d39a59BE7458147C7129fB044B34Ab4Ca4", + "abi": [ + { + "inputs": [], + "stateMutability": "payable", + "type": "constructor" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [], + "name": "BridgeTrackingIncorrectlyResponded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "RemovalRequested", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum IBridgeSlashEvents.Tier", + "name": "tier", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "period", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "slashUntilPeriod", + "type": "uint256" + } + ], + "name": "Slashed", + "type": "event" + }, + { + "inputs": [], + "name": "MINIMUM_VOTE_THRESHOLD", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "REMOVE_DURATION_THRESHOLD", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "TIER_1_PENALTY_DURATION", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "TIER_2_PENALTY_DURATION", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "operators", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "ballots", + "type": "uint256[]" + }, + { + "internalType": "uint256", + "name": "totalBallot", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "totalVote", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "period", + "type": "uint256" + } + ], + "name": "execSlashBridgeOperators", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "getAddedPeriodOf", + "outputs": [ + { + "internalType": "uint256[]", + "name": "addedPeriods", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getPenaltyDurations", + "outputs": [ + { + "internalType": "uint256[]", + "name": "penaltyDurations", + "type": "uint256[]" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "ballot", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "totalVote", + "type": "uint256" + } + ], + "name": "getSlashTier", + "outputs": [ + { + "internalType": "enum IBridgeSlashEvents.Tier", + "name": "tier", + "type": "uint8" + } + ], + "stateMutability": "pure", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "getSlashUntilPeriodOf", + "outputs": [ + { + "internalType": "uint256[]", + "name": "untilPeriods", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "validatorContract", + "type": "address" + }, + { + "internalType": "address", + "name": "bridgeManagerContract", + "type": "address" + }, + { + "internalType": "address", + "name": "bridgeTrackingContract", + "type": "address" + }, + { + "internalType": "address", + "name": "dposGA", + "type": "address" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "initializeREP2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "currentBridgeOperator", + "type": "address" + }, + { + "internalType": "address", + "name": "newBridgeOperator", + "type": "address" + } + ], + "name": "onBridgeOperatorUpdated", + "outputs": [ + { + "internalType": "bytes4", + "name": "", + "type": "bytes4" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + }, + { + "internalType": "bool[]", + "name": "addeds", + "type": "bool[]" + } + ], + "name": "onBridgeOperatorsAdded", + "outputs": [ + { + "internalType": "bytes4", + "name": "", + "type": "bytes4" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "", + "type": "address[]" + }, + { + "internalType": "bool[]", + "name": "", + "type": "bool[]" + } + ], + "name": "onBridgeOperatorsRemoved", + "outputs": [ + { + "internalType": "bytes4", + "name": "", + "type": "bytes4" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "interfaceId", + "type": "bytes4" + } + ], + "name": "supportsInterface", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "pure", + "type": "function" + } + ], + "transactionHash": "0x93ba52c3f2606d8cd048d434072f3a2b7e65e82dfba11671b312da021ecdc503", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x763e39d39a59BE7458147C7129fB044B34Ab4Ca4", + "transactionIndex": 0, + "gasUsed": "1296626", + "logsBloom": "0x00000000000100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010000", + "blockHash": "0x2503dee36d14c08cf319e1768f2e61a12007a7f5cf34ae835f949690b88f1173", + "transactionHash": "0x93ba52c3f2606d8cd048d434072f3a2b7e65e82dfba11671b312da021ecdc503", + "logs": [ + { + "transactionIndex": 0, + "blockNumber": 28368655, + "transactionHash": "0x93ba52c3f2606d8cd048d434072f3a2b7e65e82dfba11671b312da021ecdc503", + "address": "0x763e39d39a59BE7458147C7129fB044B34Ab4Ca4", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", + "logIndex": 0, + "blockHash": "0x2503dee36d14c08cf319e1768f2e61a12007a7f5cf34ae835f949690b88f1173" + } + ], + "blockNumber": 28368655, + "cumulativeGasUsed": "1296626", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 1, + "solcInputHash": "d5751a51f1eb067d18a7dec1633f85eb", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[],\"name\":\"BridgeTrackingIncorrectlyResponded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"RemovalRequested\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum IBridgeSlashEvents.Tier\",\"name\":\"tier\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashUntilPeriod\",\"type\":\"uint256\"}],\"name\":\"Slashed\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"MINIMUM_VOTE_THRESHOLD\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"REMOVE_DURATION_THRESHOLD\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"TIER_1_PENALTY_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"TIER_2_PENALTY_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"operators\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"ballots\",\"type\":\"uint256[]\"},{\"internalType\":\"uint256\",\"name\":\"totalBallot\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"totalVote\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"execSlashBridgeOperators\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"getAddedPeriodOf\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"addedPeriods\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getPenaltyDurations\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"penaltyDurations\",\"type\":\"uint256[]\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"ballot\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"totalVote\",\"type\":\"uint256\"}],\"name\":\"getSlashTier\",\"outputs\":[{\"internalType\":\"enum IBridgeSlashEvents.Tier\",\"name\":\"tier\",\"type\":\"uint8\"}],\"stateMutability\":\"pure\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"getSlashUntilPeriodOf\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"untilPeriods\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validatorContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeManagerContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeTrackingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"dposGA\",\"type\":\"address\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeREP2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"currentBridgeOperator\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"newBridgeOperator\",\"type\":\"address\"}],\"name\":\"onBridgeOperatorUpdated\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"bool[]\",\"name\":\"addeds\",\"type\":\"bool[]\"}],\"name\":\"onBridgeOperatorsAdded\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"},{\"internalType\":\"bool[]\",\"name\":\"\",\"type\":\"bool[]\"}],\"name\":\"onBridgeOperatorsRemoved\",\"outputs\":[{\"internalType\":\"bytes4\",\"name\":\"\",\"type\":\"bytes4\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"}],\"name\":\"supportsInterface\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"pure\",\"type\":\"function\"}],\"devdoc\":{\"details\":\"A contract that implements slashing functionality for bridge operators based on their availability.\",\"errors\":{\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"execSlashBridgeOperators(address[],uint256[],uint256,uint256,uint256)\":{\"details\":\"Slashes the unavailability of bridge operators during a specific period.\",\"params\":{\"period\":\"The period to slash the bridge operators for.\"}},\"getAddedPeriodOf(address[])\":{\"details\":\"Retrieves the added periods of the specified bridge operators.\",\"params\":{\"bridgeOperators\":\"An array of bridge operator addresses.\"},\"returns\":{\"addedPeriods\":\"An array of uint256 values representing the added periods for each bridge operator.\"}},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getPenaltyDurations()\":{\"details\":\"Retrieve the penalty durations for different slash tiers.\",\"returns\":{\"penaltyDurations\":\"The array of penalty durations for each slash tier.\"}},\"getSlashTier(uint256,uint256)\":{\"details\":\"Gets the slash tier based on the given ballot and total ballots.\",\"params\":{\"ballot\":\"The ballot count for a bridge operator.\",\"totalVote\":\"The total vote count for the period.\"},\"returns\":{\"tier\":\"The slash tier.\"}},\"getSlashUntilPeriodOf(address[])\":{\"details\":\"Returns the penalize durations for the specified bridge operators.\",\"params\":{\"bridgeOperators\":\"The addresses of the bridge operators.\"},\"returns\":{\"untilPeriods\":\"The penalized periods for the bridge operators.\"}},\"initializeREP2()\":{\"details\":\"Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\"},\"onBridgeOperatorUpdated(address,address)\":{\"details\":\"Handles the event when a bridge operator is updated.\",\"params\":{\"currentBridgeOperator\":\"The address of the current bridge operator.\",\"newbridgeOperator\":\"The new address of the bridge operator.\"},\"returns\":{\"_0\":\"The selector of the function being called.\"}},\"onBridgeOperatorsAdded(address[],bool[])\":{\"details\":\"Handles the event when bridge operators are added.\",\"params\":{\"addeds\":\"The corresponding boolean values indicating whether the operators were added or not.\",\"bridgeOperators\":\"The addresses of the bridge operators.\"},\"returns\":{\"_0\":\"The selector of the function being called.\"}},\"onBridgeOperatorsRemoved(address[],bool[])\":{\"details\":\"Handles the event when bridge operators are removed.\",\"params\":{\"bridgeOperators\":\"The addresses of the bridge operators.\",\"removeds\":\"The corresponding boolean values indicating whether the operators were removed or not.\"},\"returns\":{\"_0\":\"The selector of the function being called.\"}},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"supportsInterface(bytes4)\":{\"details\":\"Returns true if this contract implements the interface defined by `interfaceId`. See the corresponding https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] to learn more about how these ids are created. This function call must use less than 30 000 gas.\"}},\"stateVariables\":{\"BRIDGE_SLASH_INFOS_SLOT\":{\"details\":\"value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\\\") - 1\"},\"MINIMUM_VOTE_THRESHOLD\":{\"details\":\"External function to retrieve the value of the minimum vote threshold to execute slashing rule.\",\"return\":\"minimumVoteThreshold The minimum vote threshold value.\",\"returns\":{\"_0\":\"minimumVoteThreshold The minimum vote threshold value.\"}},\"PERCENTAGE_FRACTION\":{\"details\":\"Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\"},\"REMOVE_DURATION_THRESHOLD\":{\"details\":\"Returns the threshold duration for removing bridge operators.\",\"return\":\"The duration in period number that exceeds which a bridge operator will be removed.\",\"returns\":{\"_0\":\"The duration in period number that exceeds which a bridge operator will be removed.\"}},\"SLASH_PERMANENT_DURATION\":{\"details\":\"This value is set to the maximum value of uint128 to indicate a permanent slash duration.\"},\"TIER_1_PENALTY_DURATION\":{\"details\":\"Returns the penalty duration for Tier 1 slashing.\",\"return\":\"The duration in period number for Tier 1 slashing.\",\"returns\":{\"_0\":\"The duration in period number for Tier 1 slashing.\"}},\"TIER_1_THRESHOLD\":{\"details\":\"Tier 1 slashing threshold ratio is 10%\"},\"TIER_2_PENALTY_DURATION\":{\"details\":\"Returns the penalty duration for Tier 2 slashing.\",\"return\":\"The duration in period number for Tier 2 slashing.\",\"returns\":{\"_0\":\"The duration in period number for Tier 2 slashing.\"}},\"TIER_2_THRESHOLD\":{\"details\":\"Tier 2 slashing threshold ratio is 30%\"},\"_startedAtPeriod\":{\"details\":\"The period that the contract allows slashing.\"}},\"title\":\"BridgeSlash\",\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/BridgeSlash.sol\":\"BridgeSlash\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract BridgeTrackingHelper {\\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /**\\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\\n * @param totalBallot The total number of ballots available for the tracking response.\\n * @param totalVote The total number of votes recorded in the tracking response.\\n * @param ballots An array containing the individual ballot counts in the tracking response.\\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\\n */\\n function _isValidBridgeTrackingResponse(\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256[] memory ballots\\n ) internal pure returns (bool valid) {\\n valid = true;\\n uint256 sumBallot;\\n uint256 length = ballots.length;\\n\\n unchecked {\\n for (uint256 i; i < length; ++i) {\\n if (ballots[i] > totalVote) {\\n valid = false;\\n break;\\n }\\n\\n sumBallot += ballots[i];\\n }\\n }\\n\\n valid = valid && (sumBallot <= totalBallot);\\n }\\n}\\n\",\"keccak256\":\"0x2da3d7c4b8d48228761b48c79beb04a55065d24a3469a16043b00c45873844e5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallback.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @title IBridgeManagerCallback\\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\\n */\\ninterface IBridgeManagerCallback is IERC165 {\\n /**\\n * @dev Handles the event when bridge operators are added.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsAdded(\\n address[] memory bridgeOperators,\\n bool[] memory addeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when bridge operators are removed.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsRemoved(\\n address[] memory bridgeOperators,\\n bool[] memory removeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when a bridge operator is updated.\\n * @param currentBridgeOperator The address of the current bridge operator.\\n * @param newbridgeOperator The new address of the bridge operator.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorUpdated(\\n address currentBridgeOperator,\\n address newbridgeOperator\\n ) external returns (bytes4 selector);\\n}\\n\",\"keccak256\":\"0xfd6868a1041577a463b6c96713edcb18063dc817154d09710abfd5783e4629ee\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeSlashEvents } from \\\"./events/IBridgeSlashEvents.sol\\\";\\n\\n/**\\n * @title IBridgeSlash\\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\\n */\\ninterface IBridgeSlash is IBridgeSlashEvents {\\n /**\\n * @dev Slashes the unavailability of bridge operators during a specific period.\\n * @param period The period to slash the bridge operators for.\\n */\\n function execSlashBridgeOperators(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external;\\n\\n /**\\n * @dev Returns the penalize durations for the specified bridge operators.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @return untilPeriods The penalized periods for the bridge operators.\\n */\\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\\n\\n /**\\n * @dev Retrieves the added periods of the specified bridge operators.\\n * @param bridgeOperators An array of bridge operator addresses.\\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\\n */\\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\\n\\n /**\\n * @dev Gets the slash tier based on the given ballot and total ballots.\\n * @param ballot The ballot count for a bridge operator.\\n * @param totalVote The total vote count for the period.\\n * @return tier The slash tier.\\n */\\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\\n\\n /**\\n * @dev Retrieve the penalty durations for different slash tiers.\\n * @return penaltyDurations The array of penalty durations for each slash tier.\\n */\\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 1 slashing.\\n * @return The duration in period number for Tier 1 slashing.\\n */\\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 2 slashing.\\n * @return The duration in period number for Tier 2 slashing.\\n */\\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the threshold duration for removing bridge operators.\\n * @return The duration in period number that exceeds which a bridge operator will be removed.\\n */\\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\\n\\n /**\\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\\n * @return minimumVoteThreshold The minimum vote threshold value.\\n */\\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0xc28c29288397fa0a3a4f3b2c33e31158c6e09611dbbcb6db9ca99195256b1c34\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\\n\\n /**\\n * @dev Returns the block that allow incomming mutable call.\\n */\\n function startedAtBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVote(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallot(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(\\n uint256 _period,\\n address[] calldata _bridgeOperators\\n ) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\\n}\\n\",\"keccak256\":\"0x092841025351341cf7ff9cbf0eb6ef78752ffd2b1af329cb6048996d20c789a9\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeSlashEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeSlashEvents {\\n /**\\n * @dev Enumeration representing the slashing tiers for bridge operators.\\n */\\n enum Tier {\\n Tier0,\\n Tier1,\\n Tier2\\n }\\n\\n /**\\n * @dev Struct representing the status of a bridge operator.\\n */\\n struct BridgeSlashInfo {\\n uint128 slashUntilPeriod;\\n uint128 newlyAddedAtPeriod;\\n }\\n\\n /**\\n * @dev Event emitted when a bridge operator is slashed.\\n * @param tier The slash tier of the operator.\\n * @param bridgeOperator The address of the slashed bridge operator.\\n * @param period The period in which the operator is slashed.\\n * @param slashUntilPeriod The period until which the operator is penalized.\\n */\\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\\n\\n /**\\n * @dev Emitted when a removal request is made for a bridge operator.\\n * @param period The period for which the removal request is made.\\n * @param bridgeOperator The address of the bridge operator being requested for removal.\\n */\\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\\n}\\n\",\"keccak256\":\"0x9611e0d8b85b50bdd8ba9e8148564af526e78ccce5d202e7c84043d2d2ccb75f\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\"},\"contracts/ronin/gateway/BridgeSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { Initializable } from \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport { BridgeTrackingHelper } from \\\"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\\\";\\nimport { IHasContracts, HasContracts } from \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { IBridgeSlash } from \\\"../../interfaces/bridge/IBridgeSlash.sol\\\";\\nimport { IERC165, IBridgeManagerCallback } from \\\"../../interfaces/bridge/IBridgeManagerCallback.sol\\\";\\nimport { IBridgeTracking } from \\\"../../interfaces/bridge/IBridgeTracking.sol\\\";\\nimport { IRoninValidatorSet } from \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport { Math } from \\\"../../libraries/Math.sol\\\";\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrLengthMismatch } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title BridgeSlash\\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\\n */\\ncontract BridgeSlash is\\n IBridgeSlash,\\n IBridgeManagerCallback,\\n BridgeTrackingHelper,\\n IdentityGuard,\\n Initializable,\\n HasContracts\\n{\\n /// @inheritdoc IBridgeSlash\\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\\n /// @inheritdoc IBridgeSlash\\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\\n /// @inheritdoc IBridgeSlash\\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\\n /// @inheritdoc IBridgeSlash\\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\\n\\n /// @dev Tier 1 slashing threshold ratio is 10%\\n uint256 private constant TIER_1_THRESHOLD = 10_00;\\n /// @dev Tier 2 slashing threshold ratio is 30%\\n uint256 private constant TIER_2_THRESHOLD = 30_00;\\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\\\") - 1\\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\\n\\n /// @dev The period that the contract allows slashing.\\n uint256 internal _startedAtPeriod;\\n\\n /**\\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\\n * @param totalVote The total number of ballots for the period.\\n */\\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\\n _;\\n }\\n\\n modifier skipOnNotStarted(uint256 period) {\\n if (period < _startedAtPeriod) return;\\n _;\\n }\\n\\n constructor() payable {\\n _disableInitializers();\\n }\\n\\n function initialize(\\n address validatorContract,\\n address bridgeManagerContract,\\n address bridgeTrackingContract,\\n address dposGA\\n ) external initializer {\\n _setContract(ContractType.VALIDATOR, validatorContract);\\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\\n _startedAtPeriod = type(uint256).max;\\n }\\n\\n /**\\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\\n */\\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\\n require(_startedAtPeriod == type(uint256).max, \\\"already init rep 2\\\");\\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallback\\n */\\n function onBridgeOperatorsAdded(\\n address[] calldata bridgeOperators,\\n bool[] memory addeds\\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\\n uint256 length = bridgeOperators.length;\\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\\n if (length == 0) {\\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\\n }\\n\\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n\\n for (uint256 i; i < length; ) {\\n unchecked {\\n if (addeds[i]) {\\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\\n }\\n\\n ++i;\\n }\\n }\\n\\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallback\\n */\\n function onBridgeOperatorUpdated(\\n address currentBridgeOperator,\\n address newBridgeOperator\\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\\n\\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\\n delete _bridgeSlashInfos[currentBridgeOperator];\\n\\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\\n }\\n\\n /**\\n * @inheritdoc IBridgeSlash\\n */\\n function execSlashBridgeOperators(\\n address[] memory operators,\\n uint256[] memory ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\\n if (operators.length == 0) return;\\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\\n emit BridgeTrackingIncorrectlyResponded();\\n return;\\n }\\n\\n // Get penalty durations for each slash tier.\\n uint256[] memory penaltyDurations = _getPenaltyDurations();\\n // Get the storage mapping for bridge slash information.\\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\\n\\n // Declare variables for iteration.\\n BridgeSlashInfo memory status;\\n uint256 slashUntilPeriod;\\n address bridgeOperator;\\n Tier tier;\\n\\n for (uint256 i; i < operators.length; ) {\\n bridgeOperator = operators[i];\\n status = _bridgeSlashInfos[bridgeOperator];\\n\\n // Check if the bridge operator was added before the current period.\\n // Bridge operators added in current period will not be slashed.\\n if (status.newlyAddedAtPeriod < period) {\\n // Determine the slash tier for the bridge operator based on their ballots.\\n tier = _getSlashTier(ballots[i], totalVote);\\n\\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\\n\\n // Check if the slash duration exceeds the threshold for removal.\\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\\n emit RemovalRequested(period, bridgeOperator);\\n }\\n\\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\\n if (tier != Tier.Tier0) {\\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\\n }\\n\\n // Store updated slash until period\\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\\n }\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallback\\n */\\n function onBridgeOperatorsRemoved(\\n address[] calldata,\\n bool[] calldata\\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\\n }\\n\\n /**\\n * @inheritdoc IERC165\\n */\\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\\n }\\n\\n /**\\n * @inheritdoc IBridgeSlash\\n */\\n function getSlashUntilPeriodOf(\\n address[] calldata bridgeOperators\\n ) external view returns (uint256[] memory untilPeriods) {\\n uint256 length = bridgeOperators.length;\\n untilPeriods = new uint256[](length);\\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\\n\\n for (uint256 i; i < length; ) {\\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeSlash\\n */\\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\\n uint256 length = bridgeOperators.length;\\n addedPeriods = new uint256[](length);\\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\\n\\n for (uint256 i; i < length; ) {\\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeSlash\\n */\\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\\n penaltyDurations = _getPenaltyDurations();\\n }\\n\\n /**\\n * @inheritdoc IBridgeSlash\\n */\\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\\n tier = _getSlashTier(ballot, totalVote);\\n }\\n\\n /**\\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\\n * @param slashUntilPeriod The slash until period number.\\n * @param period The current period.\\n * @return met A boolean indicates that the threshold for removal is met.\\n */\\n function _isSlashDurationMetRemovalThreshold(\\n uint256 slashUntilPeriod,\\n uint256 period\\n ) internal pure returns (bool met) {\\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\\n }\\n\\n /**\\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\\n * @param tier The slash tier representing the severity of the slash.\\n * @param period The current period in which the calculation is performed.\\n * @param slashUntilPeriod The existing slash until period.\\n * @param penaltyDurations An array of penalty durations for each slash tier.\\n * @return newSlashUntilPeriod The newly calculated slash until period.\\n */\\n function _calcSlashUntilPeriod(\\n Tier tier,\\n uint256 period,\\n uint256 slashUntilPeriod,\\n uint256[] memory penaltyDurations\\n ) internal pure returns (uint256 newSlashUntilPeriod) {\\n // Calculate the slash until period number.\\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\\n }\\n\\n /**\\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\\n * @param ballot The individual ballot count of a bridge operator.\\n * @param totalVote The total number of votes recorded for the bridge operator.\\n * @return tier The calculated slashing tier for the bridge operator.\\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\\n */\\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\\n */\\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\\n assembly (\\\"memory-safe\\\") {\\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\\n */\\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\\n // reserve index 0\\n penaltyDurations = new uint256[](3);\\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\\n }\\n}\\n\",\"keccak256\":\"0xa02783f8aa34582eb19cd9a3fc05d6d0496c5550c38edb143fb1c9fd51c9a4ec\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405261000c610011565b6100d1565b600054610100900460ff161561007d5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff90811610156100cf576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611603806100e06000396000f3fe608060405234801561001057600080fd5b506004361061010b5760003560e01c80639c2f4459116100a2578063ddc3f7f611610071578063ddc3f7f614610213578063de981f1b1461021b578063f8c8765e14610246578063f9f6087314610259578063fbb2f1941461026157600080fd5b80639c2f4459146101dd578063c48549de146101e5578063c9631a12146101f8578063d1e1f2f81461020b57600080fd5b80635311153b116100de5780635311153b146101755780635ebae8a0146101885780636dda4408146101b4578063865e6fd3146101ca57600080fd5b806301ffc9a7146101105780631288810a146101385780633b154455146101585780634dca592514610162575b600080fd5b61012361011e366004610f49565b610281565b60405190151581526020015b60405180910390f35b61014b610146366004610fbf565b6102b8565b60405161012f9190611001565b6101606103a0565b005b610160610170366004611132565b610480565b61014b610183366004610fbf565b61070e565b61019b61019636600461120d565b6107e7565b6040516001600160e01b0319909116815260200161012f565b6101bc600181565b60405190815260200161012f565b6101606101d83660046112eb565b610964565b6101bc603281565b61019b6101f336600461131e565b610983565b61019b61020636600461138a565b6109a2565b6101bc600581565b6101bc601e81565b61022e6102293660046113a6565b610a21565b6040516001600160a01b03909116815260200161012f565b6101606102543660046113c1565b610a9c565b61014b610bdb565b61027461026f366004611415565b610bea565b60405161012f919061144d565b60006001600160e01b031982166314d72edb60e21b14806102b257506001600160e01b031982166301ffc9a760e01b145b92915050565b6060818067ffffffffffffffff8111156102d4576102d4611045565b6040519080825280602002602001820160405280156102fd578160200160208202803683370190505b5091506000805160206115ae83398151915260005b828110156103975781600087878481811061032f5761032f611467565b9050602002016020810190610344919061147d565b6001600160a01b031681526020810191909152604001600020548451600160801b9091046001600160801b03169085908390811061038457610384611467565b6020908102919091010152600101610312565b50505092915050565b60046103ab81610bfd565b600019600154146103f85760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b60448201526064015b60405180910390fd5b6104026008610a21565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561043f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104639190611498565b61046e9060016114c7565b60015561047d60046000610c49565b50565b600361048b81610bfd565b816001548110610705578360328111156107035786518851146104cf576040516306b5667560e21b81526001600160e01b03196000351660048201526024016103ef565b875115610703576104e1868689610ced565b610513576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a1610703565b600061051d610d6a565b604080518082019091526000808252602082018190529192506000805160206115ae833981519152918080805b8e518110156106fb578e818151811061056557610565611467565b6020908102919091018101516001600160a01b03811660009081528883526040908190208151808301909252546001600160801b038082168352600160801b90910416928101839052965093508b11156106f3576105dc8e82815181106105ce576105ce611467565b60200260200101518d610dd5565b91506105f7828c87600001516001600160801b03168a610e27565b9350610603848c610e7e565b15610649576040516001600160801b0394506001600160a01b038416908c907fb32a150b9737190a456d8b2b81dd7d592a799ab2933ea494e44351acd41f835d90600090a35b600082600281111561065d5761065d611437565b146106f3576001600160801b0384146106c1578a836001600160a01b031683600281111561068d5761068d611437565b6040518781527f14441e950b7f9ed959e16b2405dd1a9d163efd5d85027b222dcf78b902a00d759060200160405180910390a45b6001600160a01b038316600090815260208790526040902080546001600160801b0319166001600160801b0386161790555b60010161054a565b505050505050505b505b50505050505050565b6060818067ffffffffffffffff81111561072a5761072a611045565b604051908082528060200260200182016040528015610753578160200160208202803683370190505b5091506000805160206115ae83398151915260005b828110156103975781600087878481811061078557610785611467565b905060200201602081019061079a919061147d565b6001600160a01b0316815260208101919091526040016000205484516001600160801b03909116908590839081106107d4576107d4611467565b6020908102919091010152600101610768565b6000600b6107f481610bfd565b825184908114610825576040516306b5667560e21b81526001600160e01b03196000351660048201526024016103ef565b8060000361083d57506302f5d74560e51b915061095c565b6000805160206115ae83398151915260006108586008610a21565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610895573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108b99190611498565b905060005b8381101561094d578681815181106108d8576108d8611467565b60200260200101511561094557818360008b8b858181106108fb576108fb611467565b9050602002016020810190610910919061147d565b6001600160a01b03168152602081019190915260400160002080546001600160801b03928316600160801b0292169190911790555b6001016108be565b506302f5d74560e51b94505050505b509392505050565b61096c610ea0565b61097581610efc565b61097f8282610c49565b5050565b6000600b61099081610bfd565b506302f5d74560e51b95945050505050565b6000600b6109af81610bfd565b50506001600160a01b0391821660008181526000805160206115ae8339815191526020526040808220939094168152928320825481546001600160801b0319166001600160801b0391821690811783558454600160801b908190049092169091021790558252556364b18d0960e11b90565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610a5857610a58611437565b60ff1681526020810191909152604001600020546001600160a01b0316905080610a97578160405163409140df60e11b81526004016103ef91906114ee565b919050565b600054610100900460ff1615808015610abc5750600054600160ff909116105b80610ad65750303b158015610ad6575060005460ff166001145b610b395760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016103ef565b6000805460ff191660011790558015610b5c576000805461ff0019166101001790555b610b67600886610c49565b610b72600b85610c49565b610b7d600384610c49565b610b88600483610c49565b6000196001558015610bd4576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b6060610be5610d6a565b905090565b6000610bf68383610dd5565b9392505050565b610c0681610a21565b6001600160a01b0316336001600160a01b03161461047d576000356001600160e01b03191681336040516320e0f98d60e21b81526004016103ef939291906114fc565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c7f57610c7f611437565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610cc057610cc0611437565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b8051600190600090815b81811015610d525785858281518110610d1257610d12611467565b60200260200101511115610d295760009350610d52565b848181518110610d3b57610d3b611467565b602002602001015183019250806001019050610cf7565b50828015610d605750858211155b9695505050505050565b604080516003808252608082019092526060916020820183803683370190505090506001818160ff1681518110610da357610da3611467565b6020908102919091010152600581600260ff1681518110610dc657610dc6611467565b60200260200101818152505090565b60008082612710610de68683611533565b610df09190611546565b610dfa919061155d565b9050610bb88111610e1c576103e88111610e15576000610e1f565b6001610e1f565b60025b949350505050565b6000610e3d610e37600186611533565b84610f32565b82866002811115610e5057610e50611437565b60ff1681518110610e6357610e63611467565b6020026020010151610e7591906114c7565b95945050505050565b6000601e610e8d600184611533565b610e979085611533565b10159392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610efa576000356001600160e01b0319166001604051620f948f60ea1b81526004016103ef92919061157f565b565b806001600160a01b03163b60000361047d57604051630bfc64a360e21b81526001600160a01b03821660048201526024016103ef565b600081831015610f425781610bf6565b5090919050565b600060208284031215610f5b57600080fd5b81356001600160e01b031981168114610bf657600080fd5b60008083601f840112610f8557600080fd5b50813567ffffffffffffffff811115610f9d57600080fd5b6020830191508360208260051b8501011115610fb857600080fd5b9250929050565b60008060208385031215610fd257600080fd5b823567ffffffffffffffff811115610fe957600080fd5b610ff585828601610f73565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b818110156110395783518352928401929184019160010161101d565b50909695505050505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561108457611084611045565b604052919050565b600067ffffffffffffffff8211156110a6576110a6611045565b5060051b60200190565b80356001600160a01b0381168114610a9757600080fd5b600082601f8301126110d857600080fd5b813560206110ed6110e88361108c565b61105b565b82815260059290921b8401810191818101908684111561110c57600080fd5b8286015b848110156111275780358352918301918301611110565b509695505050505050565b600080600080600060a0868803121561114a57600080fd5b853567ffffffffffffffff8082111561116257600080fd5b818801915088601f83011261117657600080fd5b813560206111866110e88361108c565b82815260059290921b8401810191818101908c8411156111a557600080fd5b948201945b838610156111ca576111bb866110b0565b825294820194908201906111aa565b995050890135925050808211156111e057600080fd5b506111ed888289016110c7565b959895975050505060408401359360608101359360809091013592509050565b60008060006040848603121561122257600080fd5b833567ffffffffffffffff8082111561123a57600080fd5b61124687838801610f73565b909550935060209150858201358181111561126057600080fd5b86019050601f8101871361127357600080fd5b80356112816110e88261108c565b81815260059190911b820183019083810190898311156112a057600080fd5b928401925b828410156112cd57833580151581146112be5760008081fd5b825292840192908401906112a5565b80955050505050509250925092565b803560108110610a9757600080fd5b600080604083850312156112fe57600080fd5b611307836112dc565b9150611315602084016110b0565b90509250929050565b6000806000806040858703121561133457600080fd5b843567ffffffffffffffff8082111561134c57600080fd5b61135888838901610f73565b9096509450602087013591508082111561137157600080fd5b5061137e87828801610f73565b95989497509550505050565b6000806040838503121561139d57600080fd5b611307836110b0565b6000602082840312156113b857600080fd5b610bf6826112dc565b600080600080608085870312156113d757600080fd5b6113e0856110b0565b93506113ee602086016110b0565b92506113fc604086016110b0565b915061140a606086016110b0565b905092959194509250565b6000806040838503121561142857600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b602081016003831061146157611461611437565b91905290565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561148f57600080fd5b610bf6826110b0565b6000602082840312156114aa57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b808201808211156102b2576102b26114b1565b601081106114ea576114ea611437565b9052565b602081016102b282846114da565b6001600160e01b0319841681526060810161151a60208301856114da565b6001600160a01b03929092166040919091015292915050565b818103818111156102b2576102b26114b1565b80820281158282048414176102b2576102b26114b1565b60008261157a57634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b03198316815260408101600b83106115a0576115a0611437565b826020830152939250505056fed08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfea264697066735822122032aba1d1aea99774b6809a087369abaf26b64768fb2b926577d59dddc8d46ab864736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b506004361061010b5760003560e01c80639c2f4459116100a2578063ddc3f7f611610071578063ddc3f7f614610213578063de981f1b1461021b578063f8c8765e14610246578063f9f6087314610259578063fbb2f1941461026157600080fd5b80639c2f4459146101dd578063c48549de146101e5578063c9631a12146101f8578063d1e1f2f81461020b57600080fd5b80635311153b116100de5780635311153b146101755780635ebae8a0146101885780636dda4408146101b4578063865e6fd3146101ca57600080fd5b806301ffc9a7146101105780631288810a146101385780633b154455146101585780634dca592514610162575b600080fd5b61012361011e366004610f49565b610281565b60405190151581526020015b60405180910390f35b61014b610146366004610fbf565b6102b8565b60405161012f9190611001565b6101606103a0565b005b610160610170366004611132565b610480565b61014b610183366004610fbf565b61070e565b61019b61019636600461120d565b6107e7565b6040516001600160e01b0319909116815260200161012f565b6101bc600181565b60405190815260200161012f565b6101606101d83660046112eb565b610964565b6101bc603281565b61019b6101f336600461131e565b610983565b61019b61020636600461138a565b6109a2565b6101bc600581565b6101bc601e81565b61022e6102293660046113a6565b610a21565b6040516001600160a01b03909116815260200161012f565b6101606102543660046113c1565b610a9c565b61014b610bdb565b61027461026f366004611415565b610bea565b60405161012f919061144d565b60006001600160e01b031982166314d72edb60e21b14806102b257506001600160e01b031982166301ffc9a760e01b145b92915050565b6060818067ffffffffffffffff8111156102d4576102d4611045565b6040519080825280602002602001820160405280156102fd578160200160208202803683370190505b5091506000805160206115ae83398151915260005b828110156103975781600087878481811061032f5761032f611467565b9050602002016020810190610344919061147d565b6001600160a01b031681526020810191909152604001600020548451600160801b9091046001600160801b03169085908390811061038457610384611467565b6020908102919091010152600101610312565b50505092915050565b60046103ab81610bfd565b600019600154146103f85760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b60448201526064015b60405180910390fd5b6104026008610a21565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561043f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104639190611498565b61046e9060016114c7565b60015561047d60046000610c49565b50565b600361048b81610bfd565b816001548110610705578360328111156107035786518851146104cf576040516306b5667560e21b81526001600160e01b03196000351660048201526024016103ef565b875115610703576104e1868689610ced565b610513576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a1610703565b600061051d610d6a565b604080518082019091526000808252602082018190529192506000805160206115ae833981519152918080805b8e518110156106fb578e818151811061056557610565611467565b6020908102919091018101516001600160a01b03811660009081528883526040908190208151808301909252546001600160801b038082168352600160801b90910416928101839052965093508b11156106f3576105dc8e82815181106105ce576105ce611467565b60200260200101518d610dd5565b91506105f7828c87600001516001600160801b03168a610e27565b9350610603848c610e7e565b15610649576040516001600160801b0394506001600160a01b038416908c907fb32a150b9737190a456d8b2b81dd7d592a799ab2933ea494e44351acd41f835d90600090a35b600082600281111561065d5761065d611437565b146106f3576001600160801b0384146106c1578a836001600160a01b031683600281111561068d5761068d611437565b6040518781527f14441e950b7f9ed959e16b2405dd1a9d163efd5d85027b222dcf78b902a00d759060200160405180910390a45b6001600160a01b038316600090815260208790526040902080546001600160801b0319166001600160801b0386161790555b60010161054a565b505050505050505b505b50505050505050565b6060818067ffffffffffffffff81111561072a5761072a611045565b604051908082528060200260200182016040528015610753578160200160208202803683370190505b5091506000805160206115ae83398151915260005b828110156103975781600087878481811061078557610785611467565b905060200201602081019061079a919061147d565b6001600160a01b0316815260208101919091526040016000205484516001600160801b03909116908590839081106107d4576107d4611467565b6020908102919091010152600101610768565b6000600b6107f481610bfd565b825184908114610825576040516306b5667560e21b81526001600160e01b03196000351660048201526024016103ef565b8060000361083d57506302f5d74560e51b915061095c565b6000805160206115ae83398151915260006108586008610a21565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610895573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108b99190611498565b905060005b8381101561094d578681815181106108d8576108d8611467565b60200260200101511561094557818360008b8b858181106108fb576108fb611467565b9050602002016020810190610910919061147d565b6001600160a01b03168152602081019190915260400160002080546001600160801b03928316600160801b0292169190911790555b6001016108be565b506302f5d74560e51b94505050505b509392505050565b61096c610ea0565b61097581610efc565b61097f8282610c49565b5050565b6000600b61099081610bfd565b506302f5d74560e51b95945050505050565b6000600b6109af81610bfd565b50506001600160a01b0391821660008181526000805160206115ae8339815191526020526040808220939094168152928320825481546001600160801b0319166001600160801b0391821690811783558454600160801b908190049092169091021790558252556364b18d0960e11b90565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610a5857610a58611437565b60ff1681526020810191909152604001600020546001600160a01b0316905080610a97578160405163409140df60e11b81526004016103ef91906114ee565b919050565b600054610100900460ff1615808015610abc5750600054600160ff909116105b80610ad65750303b158015610ad6575060005460ff166001145b610b395760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016103ef565b6000805460ff191660011790558015610b5c576000805461ff0019166101001790555b610b67600886610c49565b610b72600b85610c49565b610b7d600384610c49565b610b88600483610c49565b6000196001558015610bd4576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b6060610be5610d6a565b905090565b6000610bf68383610dd5565b9392505050565b610c0681610a21565b6001600160a01b0316336001600160a01b03161461047d576000356001600160e01b03191681336040516320e0f98d60e21b81526004016103ef939291906114fc565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c7f57610c7f611437565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610cc057610cc0611437565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b8051600190600090815b81811015610d525785858281518110610d1257610d12611467565b60200260200101511115610d295760009350610d52565b848181518110610d3b57610d3b611467565b602002602001015183019250806001019050610cf7565b50828015610d605750858211155b9695505050505050565b604080516003808252608082019092526060916020820183803683370190505090506001818160ff1681518110610da357610da3611467565b6020908102919091010152600581600260ff1681518110610dc657610dc6611467565b60200260200101818152505090565b60008082612710610de68683611533565b610df09190611546565b610dfa919061155d565b9050610bb88111610e1c576103e88111610e15576000610e1f565b6001610e1f565b60025b949350505050565b6000610e3d610e37600186611533565b84610f32565b82866002811115610e5057610e50611437565b60ff1681518110610e6357610e63611467565b6020026020010151610e7591906114c7565b95945050505050565b6000601e610e8d600184611533565b610e979085611533565b10159392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610efa576000356001600160e01b0319166001604051620f948f60ea1b81526004016103ef92919061157f565b565b806001600160a01b03163b60000361047d57604051630bfc64a360e21b81526001600160a01b03821660048201526024016103ef565b600081831015610f425781610bf6565b5090919050565b600060208284031215610f5b57600080fd5b81356001600160e01b031981168114610bf657600080fd5b60008083601f840112610f8557600080fd5b50813567ffffffffffffffff811115610f9d57600080fd5b6020830191508360208260051b8501011115610fb857600080fd5b9250929050565b60008060208385031215610fd257600080fd5b823567ffffffffffffffff811115610fe957600080fd5b610ff585828601610f73565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b818110156110395783518352928401929184019160010161101d565b50909695505050505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff8111828210171561108457611084611045565b604052919050565b600067ffffffffffffffff8211156110a6576110a6611045565b5060051b60200190565b80356001600160a01b0381168114610a9757600080fd5b600082601f8301126110d857600080fd5b813560206110ed6110e88361108c565b61105b565b82815260059290921b8401810191818101908684111561110c57600080fd5b8286015b848110156111275780358352918301918301611110565b509695505050505050565b600080600080600060a0868803121561114a57600080fd5b853567ffffffffffffffff8082111561116257600080fd5b818801915088601f83011261117657600080fd5b813560206111866110e88361108c565b82815260059290921b8401810191818101908c8411156111a557600080fd5b948201945b838610156111ca576111bb866110b0565b825294820194908201906111aa565b995050890135925050808211156111e057600080fd5b506111ed888289016110c7565b959895975050505060408401359360608101359360809091013592509050565b60008060006040848603121561122257600080fd5b833567ffffffffffffffff8082111561123a57600080fd5b61124687838801610f73565b909550935060209150858201358181111561126057600080fd5b86019050601f8101871361127357600080fd5b80356112816110e88261108c565b81815260059190911b820183019083810190898311156112a057600080fd5b928401925b828410156112cd57833580151581146112be5760008081fd5b825292840192908401906112a5565b80955050505050509250925092565b803560108110610a9757600080fd5b600080604083850312156112fe57600080fd5b611307836112dc565b9150611315602084016110b0565b90509250929050565b6000806000806040858703121561133457600080fd5b843567ffffffffffffffff8082111561134c57600080fd5b61135888838901610f73565b9096509450602087013591508082111561137157600080fd5b5061137e87828801610f73565b95989497509550505050565b6000806040838503121561139d57600080fd5b611307836110b0565b6000602082840312156113b857600080fd5b610bf6826112dc565b600080600080608085870312156113d757600080fd5b6113e0856110b0565b93506113ee602086016110b0565b92506113fc604086016110b0565b915061140a606086016110b0565b905092959194509250565b6000806040838503121561142857600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b602081016003831061146157611461611437565b91905290565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561148f57600080fd5b610bf6826110b0565b6000602082840312156114aa57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b808201808211156102b2576102b26114b1565b601081106114ea576114ea611437565b9052565b602081016102b282846114da565b6001600160e01b0319841681526060810161151a60208301856114da565b6001600160a01b03929092166040919091015292915050565b818103818111156102b2576102b26114b1565b80820281158282048414176102b2576102b26114b1565b60008261157a57634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b03198316815260408101600b83106115a0576115a0611437565b826020830152939250505056fed08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfea264697066735822122032aba1d1aea99774b6809a087369abaf26b64768fb2b926577d59dddc8d46ab864736f6c63430008110033", + "devdoc": { + "details": "A contract that implements slashing functionality for bridge operators based on their availability.", + "errors": { + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrLengthMismatch(bytes4)": [ + { + "details": "Error indicating a mismatch in the length of input parameters or arrays for a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that has a length mismatch." + } + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "execSlashBridgeOperators(address[],uint256[],uint256,uint256,uint256)": { + "details": "Slashes the unavailability of bridge operators during a specific period.", + "params": { + "period": "The period to slash the bridge operators for." + } + }, + "getAddedPeriodOf(address[])": { + "details": "Retrieves the added periods of the specified bridge operators.", + "params": { + "bridgeOperators": "An array of bridge operator addresses." + }, + "returns": { + "addedPeriods": "An array of uint256 values representing the added periods for each bridge operator." + } + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getPenaltyDurations()": { + "details": "Retrieve the penalty durations for different slash tiers.", + "returns": { + "penaltyDurations": "The array of penalty durations for each slash tier." + } + }, + "getSlashTier(uint256,uint256)": { + "details": "Gets the slash tier based on the given ballot and total ballots.", + "params": { + "ballot": "The ballot count for a bridge operator.", + "totalVote": "The total vote count for the period." + }, + "returns": { + "tier": "The slash tier." + } + }, + "getSlashUntilPeriodOf(address[])": { + "details": "Returns the penalize durations for the specified bridge operators.", + "params": { + "bridgeOperators": "The addresses of the bridge operators." + }, + "returns": { + "untilPeriods": "The penalized periods for the bridge operators." + } + }, + "initializeREP2()": { + "details": "Helper for running upgrade script, required to only revoked once by the DPoS's governance admin." + }, + "onBridgeOperatorUpdated(address,address)": { + "details": "Handles the event when a bridge operator is updated.", + "params": { + "currentBridgeOperator": "The address of the current bridge operator.", + "newbridgeOperator": "The new address of the bridge operator." + }, + "returns": { + "_0": "The selector of the function being called." + } + }, + "onBridgeOperatorsAdded(address[],bool[])": { + "details": "Handles the event when bridge operators are added.", + "params": { + "addeds": "The corresponding boolean values indicating whether the operators were added or not.", + "bridgeOperators": "The addresses of the bridge operators." + }, + "returns": { + "_0": "The selector of the function being called." + } + }, + "onBridgeOperatorsRemoved(address[],bool[])": { + "details": "Handles the event when bridge operators are removed.", + "params": { + "bridgeOperators": "The addresses of the bridge operators.", + "removeds": "The corresponding boolean values indicating whether the operators were removed or not." + }, + "returns": { + "_0": "The selector of the function being called." + } + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, + "supportsInterface(bytes4)": { + "details": "Returns true if this contract implements the interface defined by `interfaceId`. See the corresponding https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] to learn more about how these ids are created. This function call must use less than 30 000 gas." + } + }, + "stateVariables": { + "BRIDGE_SLASH_INFOS_SLOT": { + "details": "value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1" + }, + "MINIMUM_VOTE_THRESHOLD": { + "details": "External function to retrieve the value of the minimum vote threshold to execute slashing rule.", + "return": "minimumVoteThreshold The minimum vote threshold value.", + "returns": { + "_0": "minimumVoteThreshold The minimum vote threshold value." + } + }, + "PERCENTAGE_FRACTION": { + "details": "Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]" + }, + "REMOVE_DURATION_THRESHOLD": { + "details": "Returns the threshold duration for removing bridge operators.", + "return": "The duration in period number that exceeds which a bridge operator will be removed.", + "returns": { + "_0": "The duration in period number that exceeds which a bridge operator will be removed." + } + }, + "SLASH_PERMANENT_DURATION": { + "details": "This value is set to the maximum value of uint128 to indicate a permanent slash duration." + }, + "TIER_1_PENALTY_DURATION": { + "details": "Returns the penalty duration for Tier 1 slashing.", + "return": "The duration in period number for Tier 1 slashing.", + "returns": { + "_0": "The duration in period number for Tier 1 slashing." + } + }, + "TIER_1_THRESHOLD": { + "details": "Tier 1 slashing threshold ratio is 10%" + }, + "TIER_2_PENALTY_DURATION": { + "details": "Returns the penalty duration for Tier 2 slashing.", + "return": "The duration in period number for Tier 2 slashing.", + "returns": { + "_0": "The duration in period number for Tier 2 slashing." + } + }, + "TIER_2_THRESHOLD": { + "details": "Tier 2 slashing threshold ratio is 30%" + }, + "_startedAtPeriod": { + "details": "The period that the contract allows slashing." + } + }, + "title": "BridgeSlash", + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 1373, + "contract": "contracts/ronin/gateway/BridgeSlash.sol:BridgeSlash", + "label": "_initialized", + "offset": 0, + "slot": "0", + "type": "t_uint8" + }, + { + "astId": 1376, + "contract": "contracts/ronin/gateway/BridgeSlash.sol:BridgeSlash", + "label": "_initializing", + "offset": 1, + "slot": "0", + "type": "t_bool" + }, + { + "astId": 27209, + "contract": "contracts/ronin/gateway/BridgeSlash.sol:BridgeSlash", + "label": "_startedAtPeriod", + "offset": 0, + "slot": "1", + "type": "t_uint256" + } + ], + "types": { + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/BridgeSlashProxy.json b/deployments/ronin-mainnet/BridgeSlashProxy.json new file mode 100644 index 000000000..00891600d --- /dev/null +++ b/deployments/ronin-mainnet/BridgeSlashProxy.json @@ -0,0 +1,315 @@ +{ + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "transactionIndex": 1, + "gasUsed": "779480", + "logsBloom": "0x00000000082000000000004000000000400000000000000000000008000000000000000000000000000000000000000000000000020084010000000000004000000000000000800000000000000002000000000000000000000000000000000008000000000000000000000000000000000000800000000000000004000002000080000080000000000000000000000000000000000480000000000000800000000000000000000000001000000400000000000000800000002000000000400040000120000000000000000000040000002000008400001010000200000000000000000000000000000000000000000100000000040000060000000000000000", + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8", + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "logs": [ + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x000000000000000000000000763e39d39a59be7458147c7129fb044b34ab4ca4" + ], + "data": "0x", + "logIndex": 1, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000008", + "0x000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "data": "0x", + "logIndex": 2, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x000000000000000000000000000000000000000000000000000000000000000b", + "0x0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a" + ], + "data": "0x", + "logIndex": 3, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000003", + "0x0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2" + ], + "data": "0x", + "logIndex": 4, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000004", + "0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3" + ], + "data": "0x", + "logIndex": 5, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000001", + "logIndex": 6, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + }, + { + "transactionIndex": 1, + "blockNumber": 28595542, + "transactionHash": "0x1061b1a0d1dd68f6463d431745f2efdf622a5dbb0ff686cb33e7075a73a7d5c1", + "address": "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a", + "logIndex": 7, + "blockHash": "0xa03bdb057d05d00a4da898126da9d92a34680627dd75f1f362aec91aa7e9efd8" + } + ], + "blockNumber": 28595542, + "cumulativeGasUsed": "839004", + "status": 1, + "byzantium": true + }, + "args": [ + "0x763e39d39a59BE7458147C7129fB044B34Ab4Ca4", + "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "0xf8c8765e000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3" + ], + "numDeployments": 2, + "solcInputHash": "f9f5036294d35a88da21dae55fc8b26c", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405260405162000f5f38038062000f5f83398101604081905262000026916200048d565b8282828281620000398282600062000053565b506200004790508262000090565b505050505050620005c0565b6200005e83620000eb565b6000825111806200006c5750805b156200008b576200008983836200012d60201b620002911760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f620000bb6200015c565b604080516001600160a01b03928316815291841660208301520160405180910390a1620000e88162000195565b50565b620000f6816200024a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b606062000155838360405180606001604052806027815260200162000f3860279139620002fe565b9392505050565b60006200018660008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b546001600160a01b0316919050565b6001600160a01b038116620002005760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b806200022960008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b6200026081620003e760201b620002bd1760201c565b620002c45760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401620001f7565b80620002297f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc60001b620003e460201b6200024d1760201c565b60606001600160a01b0384163b620003685760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401620001f7565b600080856001600160a01b0316856040516200038591906200056d565b600060405180830381855af49150503d8060008114620003c2576040519150601f19603f3d011682016040523d82523d6000602084013e620003c7565b606091505b509092509050620003da828286620003f6565b9695505050505050565b90565b6001600160a01b03163b151590565b606083156200040757508162000155565b825115620004185782518084602001fd5b8160405162461bcd60e51b8152600401620001f791906200058b565b80516001600160a01b03811681146200044c57600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b83811015620004845781810151838201526020016200046a565b50506000910152565b600080600060608486031215620004a357600080fd5b620004ae8462000434565b9250620004be6020850162000434565b60408501519092506001600160401b0380821115620004dc57600080fd5b818601915086601f830112620004f157600080fd5b81518181111562000506576200050662000451565b604051601f8201601f19908116603f0116810190838211818310171562000531576200053162000451565b816040528281528960208487010111156200054b57600080fd5b6200055e83602083016020880162000467565b80955050505050509250925092565b600082516200058181846020870162000467565b9190910192915050565b6020815260008251806020840152620005ac81604085016020870162000467565b601f01601f19169190910160400192915050565b61094880620005d06000396000f3fe6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/BridgeTrackingLogic.json b/deployments/ronin-mainnet/BridgeTrackingLogic.json index d6afe4264..5ccd93b0f 100644 --- a/deployments/ronin-mainnet/BridgeTrackingLogic.json +++ b/deployments/ronin-mainnet/BridgeTrackingLogic.json @@ -1,5 +1,5 @@ { - "address": "0xFCA143FE2751A992e8Cff2eB5D64Eda809049295", + "address": "0xe4CcF400e99Cb07Eb76D3a169532916069B7DC32", "abi": [ { "inputs": [], @@ -7,17 +7,61 @@ "type": "constructor" }, { - "inputs": [], - "name": "ErrCallerMustBeBridgeContract", + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", "type": "error" }, { - "inputs": [], - "name": "ErrCallerMustBeValidatorContract", + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, @@ -25,26 +69,44 @@ "anonymous": false, "inputs": [ { - "indexed": false, + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, "internalType": "address", - "name": "", + "name": "addr", "type": "address" } ], - "name": "BridgeContractUpdated", + "name": "ContractUpdated", "type": "event" }, { "anonymous": false, "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "indexed": true, + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, { "indexed": false, - "internalType": "uint8", - "name": "version", - "type": "uint8" + "internalType": "bytes", + "name": "reason", + "type": "bytes" } ], - "name": "Initialized", + "name": "ExternalCallFailed", "type": "event" }, { @@ -52,21 +114,27 @@ "inputs": [ { "indexed": false, - "internalType": "address", - "name": "", - "type": "address" + "internalType": "uint8", + "name": "version", + "type": "uint8" } ], - "name": "ValidatorContractUpdated", + "name": "Initialized", "type": "event" }, { - "inputs": [], - "name": "bridgeContract", + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", "outputs": [ { "internalType": "address", - "name": "", + "name": "contract_", "type": "address" } ], @@ -77,12 +145,12 @@ "inputs": [ { "internalType": "uint256", - "name": "_period", + "name": "period", "type": "uint256" }, { "internalType": "address[]", - "name": "_bridgeOperators", + "name": "operators", "type": "address[]" } ], @@ -101,12 +169,12 @@ "inputs": [ { "internalType": "enum IBridgeTracking.VoteKind", - "name": "_kind", + "name": "kind", "type": "uint8" }, { "internalType": "uint256", - "name": "_requestId", + "name": "requestId", "type": "uint256" } ], @@ -119,17 +187,17 @@ "inputs": [ { "internalType": "address", - "name": "_bridgeContract", + "name": "bridgeContract", "type": "address" }, { "internalType": "address", - "name": "_validatorContract", + "name": "validatorContract", "type": "address" }, { "internalType": "uint256", - "name": "_startedAtBlock", + "name": "startedAtBlock_", "type": "uint256" } ], @@ -138,51 +206,85 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [], + "name": "initializeREP2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [ { - "internalType": "enum IBridgeTracking.VoteKind", - "name": "_kind", - "type": "uint8" + "internalType": "address", + "name": "bridgeManager", + "type": "address" }, { - "internalType": "uint256", - "name": "_requestId", - "type": "uint256" + "internalType": "address", + "name": "bridgeSlash", + "type": "address" + }, + { + "internalType": "address", + "name": "bridgeReward", + "type": "address" }, { "internalType": "address", - "name": "_operator", + "name": "dposGA", "type": "address" } ], - "name": "recordVote", + "name": "initializeV3", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ + { + "internalType": "enum IBridgeTracking.VoteKind", + "name": "kind", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "requestId", + "type": "uint256" + }, { "internalType": "address", - "name": "_addr", + "name": "operator", "type": "address" } ], - "name": "setBridgeContract", + "name": "recordVote", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, { "internalType": "address", - "name": "_addr", + "name": "addr", "type": "address" } ], - "name": "setValidatorContract", + "name": "setContract", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -204,15 +306,15 @@ "inputs": [ { "internalType": "uint256", - "name": "_period", + "name": "period", "type": "uint256" } ], - "name": "totalBallots", + "name": "totalBallot", "outputs": [ { "internalType": "uint256", - "name": "_totalBallots", + "name": "totalBallot_", "type": "uint256" } ], @@ -223,16 +325,16 @@ "inputs": [ { "internalType": "uint256", - "name": "_period", + "name": "period", "type": "uint256" }, { "internalType": "address", - "name": "_bridgeOperator", + "name": "bridgeOperator", "type": "address" } ], - "name": "totalBallotsOf", + "name": "totalBallotOf", "outputs": [ { "internalType": "uint256", @@ -247,83 +349,84 @@ "inputs": [ { "internalType": "uint256", - "name": "_period", + "name": "period", "type": "uint256" } ], - "name": "totalVotes", + "name": "totalVote", "outputs": [ { "internalType": "uint256", - "name": "_totalVotes", + "name": "totalVote_", "type": "uint256" } ], "stateMutability": "view", "type": "function" - }, - { - "inputs": [], - "name": "validatorContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" } ], - "transactionHash": "0x68957a05f139a5f180c70b408a204e16580cf8c908c7372536cfbcc44c821f12", + "transactionHash": "0x85dc857849ebb9500276b8cb4f2006ce0f07bf6e860db9da1d55124fe9b3f0e9", "receipt": { "to": null, - "from": "0x0F68eDBE14C8f68481771016d7E2871d6a35DE11", - "contractAddress": "0xFCA143FE2751A992e8Cff2eB5D64Eda809049295", - "transactionIndex": 1, - "gasUsed": "1106178", - "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000001000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000004000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0xd7da5f050a07249e37ac8f4355b1c9ac9a17feb2ed6e4c8f56cf2413db927b23", - "transactionHash": "0x68957a05f139a5f180c70b408a204e16580cf8c908c7372536cfbcc44c821f12", + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0xe4CcF400e99Cb07Eb76D3a169532916069B7DC32", + "transactionIndex": 2, + "gasUsed": "1564169", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000002000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000040000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x7ca09f5ddb2e320a5466a0dcb4a82cde80614db185760f68ad73b3ca6f9a7d09", + "transactionHash": "0x85dc857849ebb9500276b8cb4f2006ce0f07bf6e860db9da1d55124fe9b3f0e9", "logs": [ { - "transactionIndex": 1, - "blockNumber": 22608280, - "transactionHash": "0x68957a05f139a5f180c70b408a204e16580cf8c908c7372536cfbcc44c821f12", - "address": "0xFCA143FE2751A992e8Cff2eB5D64Eda809049295", + "transactionIndex": 2, + "blockNumber": 28368665, + "transactionHash": "0x85dc857849ebb9500276b8cb4f2006ce0f07bf6e860db9da1d55124fe9b3f0e9", + "address": "0xe4CcF400e99Cb07Eb76D3a169532916069B7DC32", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 1, - "blockHash": "0xd7da5f050a07249e37ac8f4355b1c9ac9a17feb2ed6e4c8f56cf2413db927b23" + "logIndex": 7, + "blockHash": "0x7ca09f5ddb2e320a5466a0dcb4a82cde80614db185760f68ad73b3ca6f9a7d09" } ], - "blockNumber": 22608280, - "cumulativeGasUsed": "1127986", + "blockNumber": 28368665, + "cumulativeGasUsed": "1826630", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 1, - "solcInputHash": "a50a3f056fa24c0b5a230a9cb29a1cb4", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeBridgeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeValidatorContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"BridgeContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"ValidatorContractUpdated\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"bridgeContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"_bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"getManyTotalBallots\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum IBridgeTracking.VoteKind\",\"name\":\"_kind\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"_requestId\",\"type\":\"uint256\"}],\"name\":\"handleVoteApproved\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_bridgeContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_startedAtBlock\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum IBridgeTracking.VoteKind\",\"name\":\"_kind\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"_requestId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_operator\",\"type\":\"address\"}],\"name\":\"recordVote\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setBridgeContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setValidatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"startedAtBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"totalBallots\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_totalBallots\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_bridgeOperator\",\"type\":\"address\"}],\"name\":\"totalBallotsOf\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"totalVotes\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_totalVotes\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallerMustBeBridgeContract()\":[{\"details\":\"Error of method caller must be bridge contract.\"}],\"ErrCallerMustBeValidatorContract()\":[{\"details\":\"Error of method caller must be validator contract.\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"bridgeContract()\":{\"details\":\"Returns the bridge contract.\"},\"getManyTotalBallots(uint256,address[])\":{\"details\":\"Returns the total number of ballots of bridge operators at the specific period `_period`.\"},\"handleVoteApproved(uint8,uint256)\":{\"details\":\"Handles the request once it is approved. Requirements: - The method caller is the bridge contract.\"},\"initialize(address,address,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"recordVote(uint8,uint256,address)\":{\"details\":\"Records vote for a receipt and a operator. Requirements: - The method caller is the bridge contract.\"},\"setBridgeContract(address)\":{\"details\":\"Sets the bridge contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `BridgeContractUpdated`.\"},\"setValidatorContract(address)\":{\"details\":\"Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`.\"},\"totalBallots(uint256)\":{\"details\":\"Returns the total number of ballots at the specific period `_period`.\"},\"totalBallotsOf(uint256,address)\":{\"details\":\"Returns the total number of ballots of a bridge operator at the specific period `_period`.\"},\"totalVotes(uint256)\":{\"details\":\"Returns the total number of votes at the specific period `_period`.\"},\"validatorContract()\":{\"details\":\"Returns the validator contract.\"}},\"stateVariables\":{\"_bufferMetric\":{\"details\":\"The temporary info of votes and ballots\"},\"_periodMetric\":{\"details\":\"Mapping from period number => vote stats based on period\"},\"_receiptTrackingInfo\":{\"details\":\"Mapping from vote kind => receipt id => receipt stats\"},\"startedAtBlock\":{\"details\":\"The block that the contract allows incoming mutable calls.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/BridgeTracking.sol\":\"BridgeTracking\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasBridgeContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasBridgeContract.sol\\\";\\nimport \\\"../../interfaces/IBridge.sol\\\";\\n\\ncontract HasBridgeContract is IHasBridgeContract, HasProxyAdmin {\\n IBridge internal _bridgeContract;\\n\\n modifier onlyBridgeContract() {\\n if (bridgeContract() != msg.sender) revert ErrCallerMustBeBridgeContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasBridgeContract\\n */\\n function bridgeContract() public view override returns (address) {\\n return address(_bridgeContract);\\n }\\n\\n /**\\n * @inheritdoc IHasBridgeContract\\n */\\n function setBridgeContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length <= 0) revert ErrZeroCodeContract();\\n _setBridgeContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the bridge contract.\\n *\\n * Emits the event `BridgeContractUpdated`.\\n *\\n */\\n function _setBridgeContract(address _addr) internal {\\n _bridgeContract = IBridge(_addr);\\n emit BridgeContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x6fabd1a69eb4391793a28f0d5449f4662b7e7eaf3d9ca87554ccbc77e2b099f9\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\n\\ncontract HasValidatorContract is IHasValidatorContract, HasProxyAdmin {\\n IRoninValidatorSet internal _validatorContract;\\n\\n modifier onlyValidatorContract() {\\n if (validatorContract() != msg.sender) revert ErrCallerMustBeValidatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function validatorContract() public view override returns (address) {\\n return address(_validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function setValidatorContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setValidatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function _setValidatorContract(address _addr) internal {\\n _validatorContract = IRoninValidatorSet(_addr);\\n emit ValidatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xf0a7c4c2165ede118c6ba219ee1a20d293d94049b18aa6fc86a2c48661eb654d\",\"license\":\"MIT\"},\"contracts/interfaces/IBridge.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridge {\\n /**\\n * @dev Replaces the old bridge operator list by the new one.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emitted the event `BridgeOperatorsReplaced`.\\n *\\n */\\n function replaceBridgeOperators(address[] calldata) external;\\n\\n /**\\n * @dev Returns the bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n}\\n\",\"keccak256\":\"0x614db701e54383b7d0a749bc9b0d2da95d42652cd673499bf71e25096548b96e\",\"license\":\"MIT\"},\"contracts/interfaces/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVotes(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallots(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(uint256 _period, address[] calldata _bridgeOperators)\\n external\\n view\\n returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotsOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(\\n VoteKind _kind,\\n uint256 _requestId,\\n address _operator\\n ) external;\\n}\\n\",\"keccak256\":\"0x6066ff36c2ad0494a676dfeb4289c3cbe48d0d70266e8ec0930014a41f2a39a3\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasBridgeContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasBridgeContract is IHasContract {\\n /// @dev Emitted when the bridge contract is updated.\\n event BridgeContractUpdated(address);\\n\\n /// @dev Error of method caller must be bridge contract.\\n error ErrCallerMustBeBridgeContract();\\n\\n /**\\n * @dev Returns the bridge contract.\\n */\\n function bridgeContract() external view returns (address);\\n\\n /**\\n * @dev Sets the bridge contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `BridgeContractUpdated`.\\n *\\n */\\n function setBridgeContract(address) external;\\n}\\n\",\"keccak256\":\"0xf3ab1830ba7797cb3b8011512af3a5e38a316549f62140b0c10e0b4dcb67f773\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasValidatorContract is IHasContract {\\n /// @dev Emitted when the validator contract is updated.\\n event ValidatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be validator contract.\\n error ErrCallerMustBeValidatorContract();\\n\\n /**\\n * @dev Returns the validator contract.\\n */\\n function validatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function setValidatorContract(address) external;\\n}\\n\",\"keccak256\":\"0x35a715f123b0c5dc296d13583f946bef4e485201e122b5170988a7535f114559\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/ronin/gateway/BridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../extensions/collections/HasBridgeContract.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/IBridgeTracking.sol\\\";\\n\\ncontract BridgeTracking is HasBridgeContract, HasValidatorContract, Initializable, IBridgeTracking {\\n struct PeriodVotingMetric {\\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\\n uint256 totalRequests;\\n uint256 totalBallots;\\n mapping(address => uint256) totalBallotsOf;\\n address[] voters;\\n }\\n\\n struct PeriodVotingMetricTimeWrapper {\\n uint256 lastEpoch;\\n Request[] requests;\\n PeriodVotingMetric data;\\n }\\n\\n struct ReceiptTrackingInfo {\\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\\n uint256 approvedPeriod;\\n /// @dev The address list of voters\\n address[] voters;\\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\\n mapping(address => bool) voted;\\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\\n uint256 trackedPeriod;\\n }\\n\\n /// @dev The block that the contract allows incoming mutable calls.\\n uint256 public startedAtBlock;\\n\\n /// @dev The temporary info of votes and ballots\\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\\n /// @dev Mapping from period number => vote stats based on period\\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\\n /// @dev Mapping from vote kind => receipt id => receipt stats\\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\\n\\n modifier skipOnUnstarted() {\\n if (block.number < startedAtBlock) {\\n return;\\n }\\n _;\\n }\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address _bridgeContract,\\n address _validatorContract,\\n uint256 _startedAtBlock\\n ) external initializer {\\n _setBridgeContract(_bridgeContract);\\n _setValidatorContract(_validatorContract);\\n startedAtBlock = _startedAtBlock;\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalVotes(uint256 _period) external view override returns (uint256 _totalVotes) {\\n _totalVotes = _periodMetric[_period].totalRequests;\\n if (_isBufferCountedForPeriod(_period)) {\\n _totalVotes += _bufferMetric.requests.length;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalBallots(uint256 _period) external view override returns (uint256 _totalBallots) {\\n _totalBallots = _periodMetric[_period].totalBallots;\\n if (_isBufferCountedForPeriod(_period)) {\\n _totalBallots += _bufferMetric.data.totalBallots;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function getManyTotalBallots(uint256 _period, address[] calldata _bridgeOperators)\\n external\\n view\\n override\\n returns (uint256[] memory _res)\\n {\\n _res = new uint256[](_bridgeOperators.length);\\n bool _isBufferCounted = _isBufferCountedForPeriod(_period);\\n for (uint _i = 0; _i < _bridgeOperators.length; _i++) {\\n _res[_i] = _totalBallotsOf(_period, _bridgeOperators[_i], _isBufferCounted);\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalBallotsOf(uint256 _period, address _bridgeOperator) public view override returns (uint256) {\\n return _totalBallotsOf(_period, _bridgeOperator, _isBufferCountedForPeriod(_period));\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external override onlyBridgeContract skipOnUnstarted {\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_kind][_requestId];\\n\\n // Only records for the receipt which not approved\\n if (_receiptInfo.approvedPeriod == 0) {\\n _trySyncBuffer();\\n uint256 _currentPeriod = _validatorContract.currentPeriod();\\n _receiptInfo.approvedPeriod = _currentPeriod;\\n\\n Request storage _bufferRequest = _bufferMetric.requests.push();\\n _bufferRequest.kind = _kind;\\n _bufferRequest.id = _requestId;\\n\\n address[] storage _voters = _receiptInfo.voters;\\n for (uint _i = 0; _i < _voters.length; _i++) {\\n _increaseBallot(_kind, _requestId, _voters[_i], _currentPeriod);\\n }\\n\\n delete _receiptInfo.voters;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function recordVote(\\n VoteKind _kind,\\n uint256 _requestId,\\n address _operator\\n ) external override onlyBridgeContract skipOnUnstarted {\\n uint256 _period = _validatorContract.currentPeriod();\\n _trySyncBuffer();\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_kind][_requestId];\\n\\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\\n // The ballot metric will be increased later in the {handleVoteApproved} method.\\n if (_receiptInfo.approvedPeriod == 0) {\\n _receiptInfo.voters.push(_operator);\\n return;\\n }\\n\\n _increaseBallot(_kind, _requestId, _operator, _period);\\n }\\n\\n /**\\n * @dev Increases the ballot for the operator at a period.\\n */\\n function _increaseBallot(\\n VoteKind _kind,\\n uint256 _requestId,\\n address _operator,\\n uint256 _currentPeriod\\n ) internal {\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_kind][_requestId];\\n if (_receiptInfo.voted[_operator]) {\\n return;\\n }\\n\\n _receiptInfo.voted[_operator] = true;\\n\\n uint256 _trackedPeriod = _receiptInfo.trackedPeriod;\\n\\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\\n // If the receipt is not tracked in a period, increase metric in buffer.\\n if (_trackedPeriod == 0) {\\n if (_bufferMetric.data.totalBallotsOf[_operator] == 0) {\\n _bufferMetric.data.voters.push(_operator);\\n }\\n _bufferMetric.data.totalBallots++;\\n _bufferMetric.data.totalBallotsOf[_operator]++;\\n }\\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\\n else if (_trackedPeriod == _currentPeriod) {\\n PeriodVotingMetric storage _metric = _periodMetric[_trackedPeriod];\\n _metric.totalBallots++;\\n _metric.totalBallotsOf[_operator]++;\\n }\\n }\\n\\n /**\\n * @dev See `totalBallotsOf`.\\n */\\n function _totalBallotsOf(\\n uint256 _period,\\n address _bridgeOperator,\\n bool _mustCountLastStats\\n ) internal view returns (uint256 _totalBallots) {\\n _totalBallots = _periodMetric[_period].totalBallotsOf[_bridgeOperator];\\n if (_mustCountLastStats) {\\n _totalBallots += _bufferMetric.data.totalBallotsOf[_bridgeOperator];\\n }\\n }\\n\\n /**\\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\\n *\\n * Requirements:\\n * - The epoch after the buffer epoch is wrapped up.\\n */\\n function _trySyncBuffer() internal {\\n uint256 _currentEpoch = _validatorContract.epochOf(block.number);\\n if (_bufferMetric.lastEpoch < _currentEpoch) {\\n (, uint256 _trackedPeriod) = _validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\\n _bufferMetric.lastEpoch = _currentEpoch;\\n\\n // Copy numbers of totals\\n PeriodVotingMetric storage _metric = _periodMetric[_trackedPeriod];\\n _metric.totalRequests += _bufferMetric.requests.length;\\n _metric.totalBallots += _bufferMetric.data.totalBallots;\\n\\n // Copy voters info and voters' ballot\\n for (uint _i = 0; _i < _bufferMetric.data.voters.length; _i++) {\\n address _voter = _bufferMetric.data.voters[_i];\\n _metric.totalBallotsOf[_voter] += _bufferMetric.data.totalBallotsOf[_voter];\\n delete _bufferMetric.data.totalBallotsOf[_voter]; // need to manually delete each element, due to mapping\\n }\\n\\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\\n for (uint _i = 0; _i < _bufferMetric.requests.length; _i++) {\\n Request storage _bufferRequest = _bufferMetric.requests[_i];\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\\n _receiptInfo.trackedPeriod = _trackedPeriod;\\n }\\n\\n delete _bufferMetric.requests;\\n delete _bufferMetric.data;\\n }\\n }\\n\\n /**\\n * @dev Returns whether the buffer stats must be counted or not.\\n */\\n function _isBufferCountedForPeriod(uint256 _queriedPeriod) internal view returns (bool) {\\n uint256 _currentEpoch = _validatorContract.epochOf(block.number);\\n (bool _filled, uint256 _periodOfNextTemporaryEpoch) = _validatorContract.tryGetPeriodOfEpoch(\\n _bufferMetric.lastEpoch + 1\\n );\\n return _filled && _queriedPeriod == _periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < _currentEpoch;\\n }\\n}\\n\",\"keccak256\":\"0xc739580bbdc7a2adc1bb9e3c952c0b858fd25a7d92be1d774f57c76183de5581\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600154600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60015460ff600160a01b909104811610156100e9576001805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611290806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100a45760003560e01c806304375dcf146100a95780630b26cf66146100cf5780631794bb3c146100e457806319e6e158146100f7578063229f88ea1461010a578063889998ef1461011d5780639943908914610130578063c7c4fea91461014a578063cd5965831461015d578063cdf64a7614610165578063f67e815214610178578063f84bd12114610198575b600080fd5b6100bc6100b7366004610f61565b6101a1565b6040519081526020015b60405180910390f35b6100e26100dd366004610f8d565b6101bf565b005b6100e26100f2366004610fa8565b610237565b6100bc610105366004610fe4565b610371565b6100e261011836600461100c565b6103a3565b6100bc61012b366004610fe4565b61057c565b6001546001600160a01b03165b6040516100c69190611036565b6100e261015836600461104a565b6105a9565b61013d6106f7565b6100e2610173366004610f8d565b610706565b61018b610186366004611086565b610772565b6040516100c69190611104565b6100bc60025481565b60006101b683836101b186610839565b610958565b90505b92915050565b6101c76109b1565b6001600160a01b0316336001600160a01b0316146102005760405162461bcd60e51b81526004016101f790611148565b60405180910390fd5b6000816001600160a01b03163b1161022b57604051637bcd509160e01b815260040160405180910390fd5b610234816109df565b50565b600154600160a81b900460ff161580801561025d575060018054600160a01b900460ff16105b8061027d5750303b15801561027d575060018054600160a01b900460ff16145b6102e05760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016101f7565b6001805460ff60a01b1916600160a01b179055801561030d576001805460ff60a81b1916600160a81b1790555b610316846109df565b61031f83610a35565b6002829055801561036b576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b60008181526009602052604090205461038982610839565b1561039e5760045461039b90826111a0565b90505b919050565b336103ac6106f7565b6001600160a01b0316146103d357604051631812f26f60e11b815260040160405180910390fd5b6002544310610578576000600a60008460028111156103f4576103f46111b3565b6002811115610405576104056111b3565b81526020019081526020016000206000838152602001908152602001600020905080600001546000036105765761043a610a80565b6001546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa158015610483573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104a791906111c9565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928792849260ff19909216918490811115610504576105046111b3565b02179055506001808201859055830160005b8154811015610563576105518787848481548110610536576105366111e2565b6000918252602090912001546001600160a01b031687610d27565b8061055b816111f8565b915050610516565b50610572600185016000610ed2565b5050505b505b5050565b60008181526009602052604090206001015461059782610839565b1561039e5760065461039b90826111a0565b336105b26106f7565b6001600160a01b0316146105d957604051631812f26f60e11b815260040160405180910390fd5b6002544310610576576001546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa15801561062b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061064f91906111c9565b9050610659610a80565b6000600a6000866002811115610671576106716111b3565b6002811115610682576106826111b3565b81526020019081526020016000206000858152602001908152602001600020905080600001546000036106e4576001908101805491820181556000908152602090200180546001600160a01b0319166001600160a01b03841617905550610576565b6106f085858585610d27565b5050505050565b6000546001600160a01b031690565b61070e6109b1565b6001600160a01b0316336001600160a01b03161461073e5760405162461bcd60e51b81526004016101f790611148565b806001600160a01b03163b60000361076957604051637bcd509160e01b815260040160405180910390fd5b61023481610a35565b6060816001600160401b0381111561078c5761078c611211565b6040519080825280602002602001820160405280156107b5578160200160208202803683370190505b50905060006107c385610839565b905060005b8381101561083057610801868686848181106107e6576107e66111e2565b90506020020160208101906107fb9190610f8d565b84610958565b838281518110610813576108136111e2565b602090810291909101015280610828816111f8565b9150506107c8565b50509392505050565b60015460405163a3d545f560e01b815243600482015260009182916001600160a01b039091169063a3d545f590602401602060405180830381865afa158015610886573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108aa91906111c9565b6001805460035492935060009283926001600160a01b039092169163468c96ae916108d4916111a0565b6040518263ffffffff1660e01b81526004016108f291815260200190565b6040805180830381865afa15801561090e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109329190611227565b9150915081801561094257508085145b801561094f575060035483115b95945050505050565b60008381526009602090815260408083206001600160a01b038616845260020190915290205481156109aa576001600160a01b0383166000908152600760205260409020546109a790826111a0565b90505b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600080546001600160a01b0319166001600160a01b0383161790556040517f5cbd8a0bb00196365d5eb3457c6734e7f06666c3c78e5469b4c9deec7edae04890610a2a908390611036565b60405180910390a150565b600180546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b683616990610a2a908390611036565b60015460405163a3d545f560e01b81524360048201526000916001600160a01b03169063a3d545f590602401602060405180830381865afa158015610ac9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aed91906111c9565b905080600360000154101561023457600180546003546000926001600160a01b039092169163468c96ae91610b21916111a0565b6040518263ffffffff1660e01b8152600401610b3f91815260200190565b6040805180830381865afa158015610b5b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7f9190611227565b60038490556000818152600960205260408120600454815493955090935091839190610bac9084906111a0565b9091555050600654600182018054600090610bc89084906111a0565b90915550600090505b600854811015610c6257600880546000919083908110610bf357610bf36111e2565b60009182526020808320909101546001600160a01b0316808352600782526040808420546002880190935283208054919450919290610c339084906111a0565b90915550506001600160a01b031660009081526007602052604081205580610c5a816111f8565b915050610bd1565b5060005b600454811015610d0257600060036001018281548110610c8857610c886111e2565b6000918252602082206002918202018054909350600a91839160ff1690811115610cb457610cb46111b3565b6002811115610cc557610cc56111b3565b8152602080820192909252604090810160009081206001909501548152939091529091206003018490555080610cfa816111f8565b915050610c66565b50610d0f60046000610ef0565b600060058181556006829055906106f0600882610ed2565b6000600a6000866002811115610d3f57610d3f6111b3565b6002811115610d5057610d506111b3565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff1615610d93575061036b565b6001600160a01b03831660009081526002820160205260408120805460ff19166001179055600382015490819003610e73576001600160a01b0384166000908152600760205260408120549003610e3057600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b0319166001600160a01b0386161790555b60068054906000610e40836111f8565b90915550506001600160a01b0384166000908152600760205260408120805491610e69836111f8565b9190505550610572565b8281036105725760008181526009602052604081206001810180549192610e99836111f8565b90915550506001600160a01b03851660009081526002820160205260408120805491610ec4836111f8565b919050555050505050505050565b50805460008255906000526020600020908101906102349190610f11565b50805460008255600202906000526020600020908101906102349190610f2a565b5b80821115610f265760008155600101610f12565b5090565b5b80821115610f2657805460ff1916815560006001820155600201610f2b565b80356001600160a01b038116811461039e57600080fd5b60008060408385031215610f7457600080fd5b82359150610f8460208401610f4a565b90509250929050565b600060208284031215610f9f57600080fd5b6101b682610f4a565b600080600060608486031215610fbd57600080fd5b610fc684610f4a565b9250610fd460208501610f4a565b9150604084013590509250925092565b600060208284031215610ff657600080fd5b5035919050565b80356003811061039e57600080fd5b6000806040838503121561101f57600080fd5b61102883610ffd565b946020939093013593505050565b6001600160a01b0391909116815260200190565b60008060006060848603121561105f57600080fd5b61106884610ffd565b92506020840135915061107d60408501610f4a565b90509250925092565b60008060006040848603121561109b57600080fd5b8335925060208401356001600160401b03808211156110b957600080fd5b818601915086601f8301126110cd57600080fd5b8135818111156110dc57600080fd5b8760208260051b85010111156110f157600080fd5b6020830194508093505050509250925092565b6020808252825182820181905260009190848201906040850190845b8181101561113c57835183529284019291840191600101611120565b50909695505050505050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b634e487b7160e01b600052601160045260246000fd5b808201808211156101b9576101b961118a565b634e487b7160e01b600052602160045260246000fd5b6000602082840312156111db57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b60006001820161120a5761120a61118a565b5060010190565b634e487b7160e01b600052604160045260246000fd5b6000806040838503121561123a57600080fd5b8251801515811461124a57600080fd5b602093909301519294929350505056fea2646970667358221220b554e2c4908e5ccf341f695394c743ac85220ea023f51f8e6d465c3babdda20e64736f6c63430008110033", - "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100a45760003560e01c806304375dcf146100a95780630b26cf66146100cf5780631794bb3c146100e457806319e6e158146100f7578063229f88ea1461010a578063889998ef1461011d5780639943908914610130578063c7c4fea91461014a578063cd5965831461015d578063cdf64a7614610165578063f67e815214610178578063f84bd12114610198575b600080fd5b6100bc6100b7366004610f61565b6101a1565b6040519081526020015b60405180910390f35b6100e26100dd366004610f8d565b6101bf565b005b6100e26100f2366004610fa8565b610237565b6100bc610105366004610fe4565b610371565b6100e261011836600461100c565b6103a3565b6100bc61012b366004610fe4565b61057c565b6001546001600160a01b03165b6040516100c69190611036565b6100e261015836600461104a565b6105a9565b61013d6106f7565b6100e2610173366004610f8d565b610706565b61018b610186366004611086565b610772565b6040516100c69190611104565b6100bc60025481565b60006101b683836101b186610839565b610958565b90505b92915050565b6101c76109b1565b6001600160a01b0316336001600160a01b0316146102005760405162461bcd60e51b81526004016101f790611148565b60405180910390fd5b6000816001600160a01b03163b1161022b57604051637bcd509160e01b815260040160405180910390fd5b610234816109df565b50565b600154600160a81b900460ff161580801561025d575060018054600160a01b900460ff16105b8061027d5750303b15801561027d575060018054600160a01b900460ff16145b6102e05760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016101f7565b6001805460ff60a01b1916600160a01b179055801561030d576001805460ff60a81b1916600160a81b1790555b610316846109df565b61031f83610a35565b6002829055801561036b576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b60008181526009602052604090205461038982610839565b1561039e5760045461039b90826111a0565b90505b919050565b336103ac6106f7565b6001600160a01b0316146103d357604051631812f26f60e11b815260040160405180910390fd5b6002544310610578576000600a60008460028111156103f4576103f46111b3565b6002811115610405576104056111b3565b81526020019081526020016000206000838152602001908152602001600020905080600001546000036105765761043a610a80565b6001546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa158015610483573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906104a791906111c9565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928792849260ff19909216918490811115610504576105046111b3565b02179055506001808201859055830160005b8154811015610563576105518787848481548110610536576105366111e2565b6000918252602090912001546001600160a01b031687610d27565b8061055b816111f8565b915050610516565b50610572600185016000610ed2565b5050505b505b5050565b60008181526009602052604090206001015461059782610839565b1561039e5760065461039b90826111a0565b336105b26106f7565b6001600160a01b0316146105d957604051631812f26f60e11b815260040160405180910390fd5b6002544310610576576001546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa15801561062b573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061064f91906111c9565b9050610659610a80565b6000600a6000866002811115610671576106716111b3565b6002811115610682576106826111b3565b81526020019081526020016000206000858152602001908152602001600020905080600001546000036106e4576001908101805491820181556000908152602090200180546001600160a01b0319166001600160a01b03841617905550610576565b6106f085858585610d27565b5050505050565b6000546001600160a01b031690565b61070e6109b1565b6001600160a01b0316336001600160a01b03161461073e5760405162461bcd60e51b81526004016101f790611148565b806001600160a01b03163b60000361076957604051637bcd509160e01b815260040160405180910390fd5b61023481610a35565b6060816001600160401b0381111561078c5761078c611211565b6040519080825280602002602001820160405280156107b5578160200160208202803683370190505b50905060006107c385610839565b905060005b8381101561083057610801868686848181106107e6576107e66111e2565b90506020020160208101906107fb9190610f8d565b84610958565b838281518110610813576108136111e2565b602090810291909101015280610828816111f8565b9150506107c8565b50509392505050565b60015460405163a3d545f560e01b815243600482015260009182916001600160a01b039091169063a3d545f590602401602060405180830381865afa158015610886573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108aa91906111c9565b6001805460035492935060009283926001600160a01b039092169163468c96ae916108d4916111a0565b6040518263ffffffff1660e01b81526004016108f291815260200190565b6040805180830381865afa15801561090e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109329190611227565b9150915081801561094257508085145b801561094f575060035483115b95945050505050565b60008381526009602090815260408083206001600160a01b038616845260020190915290205481156109aa576001600160a01b0383166000908152600760205260409020546109a790826111a0565b90505b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600080546001600160a01b0319166001600160a01b0383161790556040517f5cbd8a0bb00196365d5eb3457c6734e7f06666c3c78e5469b4c9deec7edae04890610a2a908390611036565b60405180910390a150565b600180546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b683616990610a2a908390611036565b60015460405163a3d545f560e01b81524360048201526000916001600160a01b03169063a3d545f590602401602060405180830381865afa158015610ac9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aed91906111c9565b905080600360000154101561023457600180546003546000926001600160a01b039092169163468c96ae91610b21916111a0565b6040518263ffffffff1660e01b8152600401610b3f91815260200190565b6040805180830381865afa158015610b5b573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7f9190611227565b60038490556000818152600960205260408120600454815493955090935091839190610bac9084906111a0565b9091555050600654600182018054600090610bc89084906111a0565b90915550600090505b600854811015610c6257600880546000919083908110610bf357610bf36111e2565b60009182526020808320909101546001600160a01b0316808352600782526040808420546002880190935283208054919450919290610c339084906111a0565b90915550506001600160a01b031660009081526007602052604081205580610c5a816111f8565b915050610bd1565b5060005b600454811015610d0257600060036001018281548110610c8857610c886111e2565b6000918252602082206002918202018054909350600a91839160ff1690811115610cb457610cb46111b3565b6002811115610cc557610cc56111b3565b8152602080820192909252604090810160009081206001909501548152939091529091206003018490555080610cfa816111f8565b915050610c66565b50610d0f60046000610ef0565b600060058181556006829055906106f0600882610ed2565b6000600a6000866002811115610d3f57610d3f6111b3565b6002811115610d5057610d506111b3565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff1615610d93575061036b565b6001600160a01b03831660009081526002820160205260408120805460ff19166001179055600382015490819003610e73576001600160a01b0384166000908152600760205260408120549003610e3057600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b0319166001600160a01b0386161790555b60068054906000610e40836111f8565b90915550506001600160a01b0384166000908152600760205260408120805491610e69836111f8565b9190505550610572565b8281036105725760008181526009602052604081206001810180549192610e99836111f8565b90915550506001600160a01b03851660009081526002820160205260408120805491610ec4836111f8565b919050555050505050505050565b50805460008255906000526020600020908101906102349190610f11565b50805460008255600202906000526020600020908101906102349190610f2a565b5b80821115610f265760008155600101610f12565b5090565b5b80821115610f2657805460ff1916815560006001820155600201610f2b565b80356001600160a01b038116811461039e57600080fd5b60008060408385031215610f7457600080fd5b82359150610f8460208401610f4a565b90509250929050565b600060208284031215610f9f57600080fd5b6101b682610f4a565b600080600060608486031215610fbd57600080fd5b610fc684610f4a565b9250610fd460208501610f4a565b9150604084013590509250925092565b600060208284031215610ff657600080fd5b5035919050565b80356003811061039e57600080fd5b6000806040838503121561101f57600080fd5b61102883610ffd565b946020939093013593505050565b6001600160a01b0391909116815260200190565b60008060006060848603121561105f57600080fd5b61106884610ffd565b92506020840135915061107d60408501610f4a565b90509250925092565b60008060006040848603121561109b57600080fd5b8335925060208401356001600160401b03808211156110b957600080fd5b818601915086601f8301126110cd57600080fd5b8135818111156110dc57600080fd5b8760208260051b85010111156110f157600080fd5b6020830194508093505050509250925092565b6020808252825182820181905260009190848201906040850190845b8181101561113c57835183529284019291840191600101611120565b50909695505050505050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b634e487b7160e01b600052601160045260246000fd5b808201808211156101b9576101b961118a565b634e487b7160e01b600052602160045260246000fd5b6000602082840312156111db57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b60006001820161120a5761120a61118a565b5060010190565b634e487b7160e01b600052604160045260246000fd5b6000806040838503121561123a57600080fd5b8251801515811461124a57600080fd5b602093909301519294929350505056fea2646970667358221220b554e2c4908e5ccf341f695394c743ac85220ea023f51f8e6d465c3babdda20e64736f6c63430008110033", + "numDeployments": 2, + "solcInputHash": "d5751a51f1eb067d18a7dec1633f85eb", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"indexed\":false,\"internalType\":\"bytes\",\"name\":\"reason\",\"type\":\"bytes\"}],\"name\":\"ExternalCallFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"operators\",\"type\":\"address[]\"}],\"name\":\"getManyTotalBallots\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum IBridgeTracking.VoteKind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"requestId\",\"type\":\"uint256\"}],\"name\":\"handleVoteApproved\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"startedAtBlock_\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeREP2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeManager\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeSlash\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeReward\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"dposGA\",\"type\":\"address\"}],\"name\":\"initializeV3\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum IBridgeTracking.VoteKind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"requestId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"operator\",\"type\":\"address\"}],\"name\":\"recordVote\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"startedAtBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"totalBallot\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"totalBallot_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"totalBallotOf\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"totalVote\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"totalVote_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getManyTotalBallots(uint256,address[])\":{\"details\":\"Returns the total number of ballots of bridge operators at the specific period `_period`.\"},\"handleVoteApproved(uint8,uint256)\":{\"details\":\"Handles the request once it is approved. Requirements: - The method caller is the bridge contract.\"},\"initialize(address,address,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"initializeREP2()\":{\"details\":\"Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod + 1` == `{BridgeSlash}._startedAtPeriod - 1` == `currentPeriod()`\"},\"recordVote(uint8,uint256,address)\":{\"details\":\"Records vote for a receipt and a operator. Requirements: - The method caller is the bridge contract.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"startedAtBlock()\":{\"details\":\"Returns the block that allow incomming mutable call.\"},\"totalBallot(uint256)\":{\"details\":\"Returns the total number of ballots at the specific period `_period`.\"},\"totalBallotOf(uint256,address)\":{\"details\":\"Returns the total number of ballots of a bridge operator at the specific period `_period`.\"},\"totalVote(uint256)\":{\"details\":\"Returns the total number of votes at the specific period `_period`.\"}},\"stateVariables\":{\"_bufferMetric\":{\"details\":\"The temporary info of votes and ballots\"},\"_lastSyncPeriod\":{\"details\":\"The latest period that get synced with bridge's slashing and rewarding contract\"},\"_periodMetric\":{\"details\":\"Mapping from period number => vote stats based on period\"},\"_receiptTrackingInfo\":{\"details\":\"Mapping from vote kind => receipt id => receipt stats\"},\"_startedAtBlock\":{\"details\":\"The block that the contract allows incoming mutable calls.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/BridgeTracking.sol\":\"BridgeTracking\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeReward.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { IBridgeRewardEvents } from \\\"./events/IBridgeRewardEvents.sol\\\";\\n\\ninterface IBridgeReward is IBridgeRewardEvents {\\n /**\\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\\n * @param periodLength The length of the reward period for which synchronization is requested.\\n */\\n function syncReward(uint256 periodLength) external;\\n\\n /**\\n * @dev Receives RON from any address.\\n */\\n function receiveRON() external payable;\\n\\n /**\\n * @dev Invoke calculate and transfer reward to operators based on their performance.\\n *\\n * Requirements:\\n * - This method is only called once each period.\\n * - The caller must be the bridge tracking contract or a bridge operator.\\n */\\n function execSyncReward(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external;\\n\\n /**\\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\\n * @return totalRewardToppedUp The total rewards topped up value.\\n */\\n function getTotalRewardToppedUp() external view returns (uint256);\\n\\n /**\\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\\n * @return totalRewardScattered The total rewards scattered value.\\n */\\n function getTotalRewardScattered() external view returns (uint256);\\n\\n /**\\n * @dev Getter for all bridge operators per period.\\n */\\n function getRewardPerPeriod() external view returns (uint256);\\n\\n /**\\n * @dev External function to retrieve the latest rewarded period in the contract.\\n * @return latestRewardedPeriod The latest rewarded period value.\\n */\\n function getLatestRewardedPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Setter for all bridge operators per period.\\n */\\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\\n}\\n\",\"keccak256\":\"0x781f5b4e9257231f008457d41b277058fe6a2b7366ecd3d64bce2591d0eaa216\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeSlashEvents } from \\\"./events/IBridgeSlashEvents.sol\\\";\\n\\n/**\\n * @title IBridgeSlash\\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\\n */\\ninterface IBridgeSlash is IBridgeSlashEvents {\\n /**\\n * @dev Slashes the unavailability of bridge operators during a specific period.\\n * @param period The period to slash the bridge operators for.\\n */\\n function execSlashBridgeOperators(\\n address[] calldata operators,\\n uint256[] calldata ballots,\\n uint256 totalBallot,\\n uint256 totalVote,\\n uint256 period\\n ) external;\\n\\n /**\\n * @dev Returns the penalize durations for the specified bridge operators.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @return untilPeriods The penalized periods for the bridge operators.\\n */\\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\\n\\n /**\\n * @dev Retrieves the added periods of the specified bridge operators.\\n * @param bridgeOperators An array of bridge operator addresses.\\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\\n */\\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\\n\\n /**\\n * @dev Gets the slash tier based on the given ballot and total ballots.\\n * @param ballot The ballot count for a bridge operator.\\n * @param totalVote The total vote count for the period.\\n * @return tier The slash tier.\\n */\\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\\n\\n /**\\n * @dev Retrieve the penalty durations for different slash tiers.\\n * @return penaltyDurations The array of penalty durations for each slash tier.\\n */\\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 1 slashing.\\n * @return The duration in period number for Tier 1 slashing.\\n */\\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the penalty duration for Tier 2 slashing.\\n * @return The duration in period number for Tier 2 slashing.\\n */\\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\\n\\n /**\\n * @dev Returns the threshold duration for removing bridge operators.\\n * @return The duration in period number that exceeds which a bridge operator will be removed.\\n */\\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\\n\\n /**\\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\\n * @return minimumVoteThreshold The minimum vote threshold value.\\n */\\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0xc28c29288397fa0a3a4f3b2c33e31158c6e09611dbbcb6db9ca99195256b1c34\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\\n\\n /**\\n * @dev Returns the block that allow incomming mutable call.\\n */\\n function startedAtBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVote(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallot(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(\\n uint256 _period,\\n address[] calldata _bridgeOperators\\n ) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\\n}\\n\",\"keccak256\":\"0x092841025351341cf7ff9cbf0eb6ef78752ffd2b1af329cb6048996d20c789a9\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeRewardEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeRewardEvents {\\n /**\\n * @dev Reward-related information for a bridge operator.\\n * @param claimed The amount of rewards claimed by the bridge operator.\\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\\n */\\n struct BridgeRewardInfo {\\n uint256 claimed;\\n uint256 slashed;\\n }\\n\\n /**\\n * @dev Emitted when RON are safely received as rewards in the contract.\\n * @param from The address of the sender who transferred RON tokens as rewards.\\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\\n * @param amount The amount of RON received.\\n */\\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\\n /// @dev Event emitted when the reward per period config is updated.\\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\\n /// @dev Event emitted when the requesting period to sync is too far.\\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\\n}\\n\",\"keccak256\":\"0xf0efa7130ba933552a16b7fb4040f23e276a41d8d698f27b11c3f82930916e51\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeSlashEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeSlashEvents {\\n /**\\n * @dev Enumeration representing the slashing tiers for bridge operators.\\n */\\n enum Tier {\\n Tier0,\\n Tier1,\\n Tier2\\n }\\n\\n /**\\n * @dev Struct representing the status of a bridge operator.\\n */\\n struct BridgeSlashInfo {\\n uint128 slashUntilPeriod;\\n uint128 newlyAddedAtPeriod;\\n }\\n\\n /**\\n * @dev Event emitted when a bridge operator is slashed.\\n * @param tier The slash tier of the operator.\\n * @param bridgeOperator The address of the slashed bridge operator.\\n * @param period The period in which the operator is slashed.\\n * @param slashUntilPeriod The period until which the operator is penalized.\\n */\\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\\n\\n /**\\n * @dev Emitted when a removal request is made for a bridge operator.\\n * @param period The period for which the removal request is made.\\n * @param bridgeOperator The address of the bridge operator being requested for removal.\\n */\\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\\n}\\n\",\"keccak256\":\"0x9611e0d8b85b50bdd8ba9e8148564af526e78ccce5d202e7c84043d2d2ccb75f\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/ronin/gateway/BridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../interfaces/bridge/IBridgeTracking.sol\\\";\\nimport { IBridgeManager } from \\\"../../interfaces/bridge/IBridgeManager.sol\\\";\\nimport { IBridgeSlash } from \\\"../../interfaces/bridge/IBridgeSlash.sol\\\";\\nimport { IBridgeReward } from \\\"../../interfaces/bridge/IBridgeReward.sol\\\";\\nimport { IRoninValidatorSet } from \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\n\\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\\n struct PeriodVotingMetric {\\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\\n uint256 totalRequest;\\n uint256 totalBallot;\\n mapping(address => uint256) totalBallotOf;\\n address[] voters;\\n }\\n\\n struct PeriodVotingMetricTimeWrapper {\\n uint256 lastEpoch;\\n Request[] requests;\\n PeriodVotingMetric data;\\n }\\n\\n struct ReceiptTrackingInfo {\\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\\n uint256 approvedPeriod;\\n /// @dev The address list of voters\\n address[] voters;\\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\\n mapping(address => bool) voted;\\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\\n uint256 trackedPeriod;\\n }\\n\\n /// @dev The block that the contract allows incoming mutable calls.\\n uint256 internal _startedAtBlock;\\n\\n /// @dev The temporary info of votes and ballots\\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\\n /// @dev Mapping from period number => vote stats based on period\\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\\n /// @dev Mapping from vote kind => receipt id => receipt stats\\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\\n uint256 internal _lastSyncPeriod;\\n\\n modifier skipOnNotStarted() {\\n _skipOnNotStarted();\\n _;\\n }\\n\\n /**\\n * @dev Returns the whole transaction in case the current block is less than start block.\\n */\\n function _skipOnNotStarted() private view {\\n if (block.number < _startedAtBlock) {\\n assembly {\\n return(0, 0)\\n }\\n }\\n }\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\\n _setContract(ContractType.BRIDGE, bridgeContract);\\n _setContract(ContractType.VALIDATOR, validatorContract);\\n _startedAtBlock = startedAtBlock_;\\n }\\n\\n function initializeV2() external reinitializer(2) {\\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\\n\\n delete ______deprecatedBridge;\\n delete ______deprecatedValidator;\\n }\\n\\n function initializeV3(\\n address bridgeManager,\\n address bridgeSlash,\\n address bridgeReward,\\n address dposGA\\n ) external reinitializer(3) {\\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\\n _lastSyncPeriod = type(uint256).max;\\n }\\n\\n /**\\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\\n * The following must be assured after initializing REP2:\\n * `_lastSyncPeriod`\\n * == `{BridgeReward}.latestRewardedPeriod + 1`\\n * == `{BridgeSlash}._startedAtPeriod - 1`\\n * == `currentPeriod()`\\n */\\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\\n require(_lastSyncPeriod == type(uint256).max, \\\"already init rep 2\\\");\\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function startedAtBlock() external view override returns (uint256) {\\n return _startedAtBlock;\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\\n totalVote_ = _periodMetric[period].totalRequest;\\n if (_isBufferCountedForPeriod(period)) {\\n totalVote_ += _bufferMetric.requests.length;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\\n totalBallot_ = _periodMetric[period].totalBallot;\\n if (_isBufferCountedForPeriod(period)) {\\n totalBallot_ += _bufferMetric.data.totalBallot;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function getManyTotalBallots(\\n uint256 period,\\n address[] calldata operators\\n ) external view override returns (uint256[] memory _res) {\\n _res = _getManyTotalBallots(period, operators);\\n }\\n\\n function _getManyTotalBallots(\\n uint256 period,\\n address[] memory operators\\n ) internal view returns (uint256[] memory res) {\\n uint256 length = operators.length;\\n res = new uint256[](length);\\n bool isBufferCounted = _isBufferCountedForPeriod(period);\\n for (uint i = 0; i < length; ) {\\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function handleVoteApproved(\\n VoteKind kind,\\n uint256 requestId\\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\\n\\n // Only records for the receipt which not approved\\n if (_receiptInfo.approvedPeriod == 0) {\\n _trySyncBuffer();\\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n _receiptInfo.approvedPeriod = currentPeriod;\\n\\n Request storage _bufferRequest = _bufferMetric.requests.push();\\n _bufferRequest.kind = kind;\\n _bufferRequest.id = requestId;\\n\\n address[] storage _voters = _receiptInfo.voters;\\n for (uint i = 0; i < _voters.length; ) {\\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n delete _receiptInfo.voters;\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeTracking\\n */\\n function recordVote(\\n VoteKind kind,\\n uint256 requestId,\\n address operator\\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n _trySyncBuffer();\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\\n\\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\\n // The ballot metric will be increased later in the {handleVoteApproved} method.\\n if (_receiptInfo.approvedPeriod == 0) {\\n _receiptInfo.voters.push(operator);\\n return;\\n }\\n\\n _increaseBallot(kind, requestId, operator, period);\\n\\n uint256 lastSyncPeriod = _lastSyncPeriod;\\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\\n if (lastSyncPeriod < period) {\\n _lastSyncPeriod = period;\\n\\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\\n\\n uint256 totalVote_ = totalVote(lastSyncPeriod);\\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\\n\\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\\n abi.encodeCall(\\n IBridgeSlash.execSlashBridgeOperators,\\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\\n )\\n );\\n if (!success) {\\n emit ExternalCallFailed(\\n bridgeSlashContract,\\n IBridgeSlash.execSlashBridgeOperators.selector,\\n returnOrRevertData\\n );\\n }\\n\\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\\n (success, returnOrRevertData) = bridgeRewardContract.call(\\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\\n );\\n if (!success) {\\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\\n }\\n }\\n }\\n\\n /**\\n * @dev Increases the ballot for the operator at a period.\\n */\\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\\n if (_receiptInfo.voted[operator]) {\\n return;\\n }\\n\\n _receiptInfo.voted[operator] = true;\\n\\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\\n\\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\\n // If the receipt is not tracked in a period, increase metric in buffer.\\n unchecked {\\n if (trackedPeriod == 0) {\\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\\n _bufferMetric.data.voters.push(operator);\\n }\\n _bufferMetric.data.totalBallot++;\\n _bufferMetric.data.totalBallotOf[operator]++;\\n }\\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\\n else if (trackedPeriod == currentPeriod) {\\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\\n _metric.totalBallot++;\\n _metric.totalBallotOf[operator]++;\\n }\\n }\\n }\\n\\n /**\\n * @dev See `totalBallotOf`.\\n */\\n function _totalBallotOf(\\n uint256 period,\\n address operator,\\n bool mustCountLastStats\\n ) internal view returns (uint256 _totalBallot) {\\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\\n if (mustCountLastStats) {\\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\\n }\\n }\\n\\n /**\\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\\n *\\n * Requirements:\\n * - The epoch after the buffer epoch is wrapped up.\\n */\\n function _trySyncBuffer() internal {\\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 currentEpoch = validatorContract.epochOf(block.number);\\n if (_bufferMetric.lastEpoch < currentEpoch) {\\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\\n _bufferMetric.lastEpoch = currentEpoch;\\n\\n // Copy numbers of totals\\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\\n _metric.totalRequest += _bufferMetric.requests.length;\\n _metric.totalBallot += _bufferMetric.data.totalBallot;\\n\\n // Copy voters info and voters' ballot\\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\\n address voter = _bufferMetric.data.voters[i];\\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\\n Request storage _bufferRequest = _bufferMetric.requests[i];\\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\\n _receiptInfo.trackedPeriod = trackedPeriod;\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n delete _bufferMetric.requests;\\n delete _bufferMetric.data;\\n }\\n }\\n\\n /**\\n * @dev Returns whether the buffer stats must be counted or not.\\n */\\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 currentEpoch = validatorContract.epochOf(block.number);\\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\\n _bufferMetric.lastEpoch + 1\\n );\\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\\n }\\n}\\n\",\"keccak256\":\"0x1cd071b36572435a146372bb34ab29d8d5b2cb8fe0c23c3145f2a07ba7c02748\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/DeprecatedSlots.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\n/**\\n * @title Deprecated Contracts\\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\\n * They provide functionality related to various aspects of a smart contract but have been marked\\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\\n */\\ncontract HasSlashIndicatorDeprecated {\\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\\n address internal ______deprecatedSlashIndicator;\\n}\\n\\ncontract HasStakingVestingDeprecated {\\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\\n address internal ______deprecatedStakingVesting;\\n}\\n\\ncontract HasBridgeDeprecated {\\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\\n address internal ______deprecatedBridge;\\n}\\n\\ncontract HasValidatorDeprecated {\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address internal ______deprecatedValidator;\\n}\\n\\ncontract HasStakingDeprecated {\\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\\n address internal ______deprecatedStakingContract;\\n}\\n\\ncontract HasMaintenanceDeprecated {\\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\\n address internal ______deprecatedMaintenance;\\n}\\n\\ncontract HasTrustedOrgDeprecated {\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address internal ______deprecatedTrustedOrg;\\n}\\n\\ncontract HasGovernanceAdminDeprecated {\\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\\n address internal ______deprecatedGovernanceAdmin;\\n}\\n\\ncontract HasBridgeTrackingDeprecated {\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address internal ______deprecatedBridgeTracking;\\n}\\n\",\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600154600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60015460ff600160a01b909104811610156100e9576001805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611ad9806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100cf5760003560e01c8063c7c4fea91161008c578063de981f1b11610066578063de981f1b1461017e578063e2a75f36146101a9578063f67e8152146101bc578063f84bd121146101dc57600080fd5b8063c7c4fea914610145578063ca21287e14610158578063d25ed4c61461016b57600080fd5b80631794bb3c146100d4578063229f88ea146100e95780633b154455146100fc5780634ac0bcda146101045780635cd8a76b1461012a578063865e6fd314610132575b600080fd5b6100e76100e23660046114e5565b6101e4565b005b6100e76100f7366004611535565b6102e4565b6100e761048c565b61011761011236600461155f565b61055c565b6040519081526020015b60405180910390f35b6100e761057a565b6100e761014036600461159e565b610673565b6100e76101533660046115ca565b610692565b6100e761016636600461160a565b610a71565b610117610179366004611666565b610b5c565b61019161018c36600461167f565b610b91565b6040516001600160a01b039091168152602001610121565b6101176101b7366004611666565b610c07565b6101cf6101ca36600461169a565b610c31565b6040516101219190611754565b600254610117565b600154600160a81b900460ff161580801561020a575060018054600160a01b900460ff16105b8061022a5750303b15801561022a575060018054600160a01b900460ff16145b61024f5760405162461bcd60e51b815260040161024690611767565b60405180910390fd5b6001805460ff60a01b1916600160a01b179055801561027c576001805460ff60a81b1916600160a81b1790555b610287600285610c78565b610292600884610c78565b600282905580156102de576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b60026102ef81610d1c565b6102f7610d68565b6000600a600085600281111561030f5761030f6117b5565b6002811115610320576103206117b5565b81526020019081526020016000206000848152602001908152602001600020905080600001546000036102de57610355610d76565b60006103616008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561039e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103c291906117cb565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928892849260ff1990921691849081111561041f5761041f6117b5565b02179055506001808201869055830160005b81548110156104745761046c8888848481548110610451576104516117e4565b6000918252602090912001546001600160a01b031687611018565b600101610431565b50610483600185016000611458565b50505050505050565b600461049781610d1c565b600019600b54146104df5760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b6044820152606401610246565b6104e96008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610526573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061054a91906117cb565b600b5561055960046000610c78565b50565b6000610571838361056c86611198565b6112be565b90505b92915050565b600154600290600160a81b900460ff161580156105a5575060015460ff808316600160a01b90920416105b6105c15760405162461bcd60e51b815260040161024690611767565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055600054610601906002906001600160a01b0316610c78565b600154610619906008906001600160a01b0316610c78565b600080546001600160a01b031916905560018054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b61067b611314565b6106848161136e565b61068e8282610c78565b5050565b600261069d81610d1c565b6106a5610d68565b60006106b16008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106ee573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061071291906117cb565b905061071c610d76565b6000600a6000876002811115610734576107346117b5565b6002811115610745576107456117b5565b81526020019081526020016000206000868152602001908152602001600020905080600001546000036107a7576001908101805491820181556000908152602090200180546001600160a01b0319166001600160a01b038516179055506102de565b6107b386868685611018565b600b548281101561048357600b8381556000906107cf90610b91565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa15801561080c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610834919081019061181b565b9050600061084283836113a4565b9050600061084f84610c07565b9050600061085c85610b5c565b9050600061086a600c610b91565b9050600080826001600160a01b0316878786888c6040516024016108929594939291906118e0565b60408051601f198184030181529181526020820180516001600160e01b0316634dca592560e01b179052516108c79190611979565b6000604051808303816000865af19150503d8060008114610904576040519150601f19603f3d011682016040523d82523d6000602084013e610909565b606091505b50915091508161096057604051634dca592560e01b906001600160a01b038516907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610957908590611995565b60405180910390a35b600061096c600d610b91565b9050806001600160a01b0316888887898d6040516024016109919594939291906118e0565b60408051601f198184030181529181526020820180516001600160e01b03166335e5b7eb60e11b179052516109c69190611979565b6000604051808303816000865af19150503d8060008114610a03576040519150601f19603f3d011682016040523d82523d6000602084013e610a08565b606091505b50909350915082610a60576040516335e5b7eb60e11b906001600160a01b038316907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610a57908690611995565b60405180910390a35b505050505050505050505050505050565b600154600390600160a81b900460ff16158015610a9c575060015460ff808316600160a01b90920416105b610ab85760405162461bcd60e51b815260040161024690611767565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055610aeb600b86610c78565b610af6600c85610c78565b610b01600d84610c78565b610b0c600483610c78565b600019600b556001805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050505050565b600081815260096020526040902060010154610b7782611198565b15610b8c57600654610b8990826119c8565b90505b919050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610bc857610bc86117b5565b60ff1681526020810191909152604001600020546001600160a01b0316905080610b8c578160405163409140df60e11b815260040161024691906119fd565b600081815260096020526040902054610c1f82611198565b15610b8c57600454610b8990826119c8565b6060610c70848484808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506113a492505050565b949350505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610cae57610cae6117b5565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610cef57610cef6117b5565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610d2581610b91565b6001600160a01b0316336001600160a01b031614610559576000356001600160e01b03191681336040516320e0f98d60e21b815260040161024693929190611a0b565b600254431015610d7457005b565b6000610d826008610b91565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015610dcc573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df091906117cb565b905080600360000154101561068e576000826001600160a01b031663468c96ae6003600001546001610e2291906119c8565b6040518263ffffffff1660e01b8152600401610e4091815260200190565b6040805180830381865afa158015610e5c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e809190611a42565b60038490556000818152600960205260408120600454815493955090935091839190610ead9084906119c8565b9091555050600654600182018054600090610ec99084906119c8565b90915550600090505b600854811015610f5957600880546000919083908110610ef457610ef46117e4565b60009182526020808320909101546001600160a01b0316808352600782526040808420546002880190935283208054919450919290610f349084906119c8565b90915550506001600160a01b0316600090815260076020526040812055600101610ed2565b5060005b600454811015610feb57600060036001018281548110610f7f57610f7f6117e4565b6000918252602082206002918202018054909350600a91839160ff1690811115610fab57610fab6117b5565b6002811115610fbc57610fbc6117b5565b815260208082019290925260409081016000908120600195860154825290925290206003018590555001610f5d565b50610ff860046000611476565b60006005818155600682905590611010600882611458565b505050505050565b6000600a6000866002811115611030576110306117b5565b6002811115611041576110416117b5565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff161561108457506102de565b6001600160a01b03831660009081526002820160205260408120805460ff19166001179055600382015490819003611151576001600160a01b038416600090815260076020526040812054900361112157600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b0319166001600160a01b0386161790555b6006805460019081019091556001600160a01b038516600090815260076020526040902080549091019055611010565b82810361101057600090815260096020908152604080832060018082018054820190556001600160a01b039790971684526002019091529020805490930190925550505050565b6000806111a56008610b91565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa1580156111ef573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061121391906117cb565b9050600080836001600160a01b031663468c96ae600360000154600161123991906119c8565b6040518263ffffffff1660e01b815260040161125791815260200190565b6040805180830381865afa158015611273573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112979190611a42565b915091508180156112a757508086145b80156112b4575060035483115b9695505050505050565b60008381526009602090815260408083206001600160a01b0386168452600201909152902054811561130d576001600160a01b038316600090815260076020526040902054610c7090826119c8565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610d74576000356001600160e01b0319166001604051620f948f60ea1b8152600401610246929190611a75565b806001600160a01b03163b60000361055957604051630bfc64a360e21b81526001600160a01b0382166004820152602401610246565b80516060908067ffffffffffffffff8111156113c2576113c26117fa565b6040519080825280602002602001820160405280156113eb578160200160208202803683370190505b50915060006113f985611198565b905060005b8281101561144f5761142a8686838151811061141c5761141c6117e4565b6020026020010151846112be565b84828151811061143c5761143c6117e4565b60209081029190910101526001016113fe565b50505092915050565b50805460008255906000526020600020908101906105599190611497565b508054600082556002029060005260206000209081019061055991906114b0565b5b808211156114ac5760008155600101611498565b5090565b5b808211156114ac57805460ff19168155600060018201556002016114b1565b6001600160a01b038116811461055957600080fd5b6000806000606084860312156114fa57600080fd5b8335611505816114d0565b92506020840135611515816114d0565b929592945050506040919091013590565b803560038110610b8c57600080fd5b6000806040838503121561154857600080fd5b61155183611526565b946020939093013593505050565b6000806040838503121561157257600080fd5b823591506020830135611584816114d0565b809150509250929050565b803560108110610b8c57600080fd5b600080604083850312156115b157600080fd5b6115ba8361158f565b91506020830135611584816114d0565b6000806000606084860312156115df57600080fd5b6115e884611526565b92506020840135915060408401356115ff816114d0565b809150509250925092565b6000806000806080858703121561162057600080fd5b843561162b816114d0565b9350602085013561163b816114d0565b9250604085013561164b816114d0565b9150606085013561165b816114d0565b939692955090935050565b60006020828403121561167857600080fd5b5035919050565b60006020828403121561169157600080fd5b6105718261158f565b6000806000604084860312156116af57600080fd5b83359250602084013567ffffffffffffffff808211156116ce57600080fd5b818601915086601f8301126116e257600080fd5b8135818111156116f157600080fd5b8760208260051b850101111561170657600080fd5b6020830194508093505050509250925092565b600081518084526020808501945080840160005b838110156117495781518752958201959082019060010161172d565b509495945050505050565b6020815260006105716020830184611719565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052602160045260246000fd5b6000602082840312156117dd57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b8051610b8c816114d0565b6000602080838503121561182e57600080fd5b825167ffffffffffffffff8082111561184657600080fd5b818501915085601f83011261185a57600080fd5b81518181111561186c5761186c6117fa565b8060051b604051601f19603f83011681018181108582111715611891576118916117fa565b6040529182528482019250838101850191888311156118af57600080fd5b938501935b828510156118d4576118c585611810565b845293850193928501926118b4565b98975050505050505050565b60a0808252865190820181905260009060209060c0840190828a01845b828110156119225781516001600160a01b0316845292840192908401906001016118fd565b505050838103828501526119368189611719565b6040850197909752505050606081019290925260809091015292915050565b60005b83811015611970578181015183820152602001611958565b50506000910152565b6000825161198b818460208701611955565b9190910192915050565b60208152600082518060208401526119b4816040850160208701611955565b601f01601f19169190910160400192915050565b8082018082111561057457634e487b7160e01b600052601160045260246000fd5b601081106119f9576119f96117b5565b9052565b6020810161057482846119e9565b6001600160e01b03198416815260608101611a2960208301856119e9565b6001600160a01b03929092166040919091015292915050565b60008060408385031215611a5557600080fd5b82518015158114611a6557600080fd5b6020939093015192949293505050565b6001600160e01b03198316815260408101600b8310611a9657611a966117b5565b826020830152939250505056fea26469706673582212207c1e9b1dc78cc32780128834c16297cb51ade3b76253c761438c2697dd9f7f4c64736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100cf5760003560e01c8063c7c4fea91161008c578063de981f1b11610066578063de981f1b1461017e578063e2a75f36146101a9578063f67e8152146101bc578063f84bd121146101dc57600080fd5b8063c7c4fea914610145578063ca21287e14610158578063d25ed4c61461016b57600080fd5b80631794bb3c146100d4578063229f88ea146100e95780633b154455146100fc5780634ac0bcda146101045780635cd8a76b1461012a578063865e6fd314610132575b600080fd5b6100e76100e23660046114e5565b6101e4565b005b6100e76100f7366004611535565b6102e4565b6100e761048c565b61011761011236600461155f565b61055c565b6040519081526020015b60405180910390f35b6100e761057a565b6100e761014036600461159e565b610673565b6100e76101533660046115ca565b610692565b6100e761016636600461160a565b610a71565b610117610179366004611666565b610b5c565b61019161018c36600461167f565b610b91565b6040516001600160a01b039091168152602001610121565b6101176101b7366004611666565b610c07565b6101cf6101ca36600461169a565b610c31565b6040516101219190611754565b600254610117565b600154600160a81b900460ff161580801561020a575060018054600160a01b900460ff16105b8061022a5750303b15801561022a575060018054600160a01b900460ff16145b61024f5760405162461bcd60e51b815260040161024690611767565b60405180910390fd5b6001805460ff60a01b1916600160a01b179055801561027c576001805460ff60a81b1916600160a81b1790555b610287600285610c78565b610292600884610c78565b600282905580156102de576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b60026102ef81610d1c565b6102f7610d68565b6000600a600085600281111561030f5761030f6117b5565b6002811115610320576103206117b5565b81526020019081526020016000206000848152602001908152602001600020905080600001546000036102de57610355610d76565b60006103616008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561039e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103c291906117cb565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928892849260ff1990921691849081111561041f5761041f6117b5565b02179055506001808201869055830160005b81548110156104745761046c8888848481548110610451576104516117e4565b6000918252602090912001546001600160a01b031687611018565b600101610431565b50610483600185016000611458565b50505050505050565b600461049781610d1c565b600019600b54146104df5760405162461bcd60e51b815260206004820152601260248201527130b63932b0b23c9034b734ba103932b8101960711b6044820152606401610246565b6104e96008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610526573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061054a91906117cb565b600b5561055960046000610c78565b50565b6000610571838361056c86611198565b6112be565b90505b92915050565b600154600290600160a81b900460ff161580156105a5575060015460ff808316600160a01b90920416105b6105c15760405162461bcd60e51b815260040161024690611767565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055600054610601906002906001600160a01b0316610c78565b600154610619906008906001600160a01b0316610c78565b600080546001600160a01b031916905560018054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b61067b611314565b6106848161136e565b61068e8282610c78565b5050565b600261069d81610d1c565b6106a5610d68565b60006106b16008610b91565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106ee573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061071291906117cb565b905061071c610d76565b6000600a6000876002811115610734576107346117b5565b6002811115610745576107456117b5565b81526020019081526020016000206000868152602001908152602001600020905080600001546000036107a7576001908101805491820181556000908152602090200180546001600160a01b0319166001600160a01b038516179055506102de565b6107b386868685611018565b600b548281101561048357600b8381556000906107cf90610b91565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa15801561080c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610834919081019061181b565b9050600061084283836113a4565b9050600061084f84610c07565b9050600061085c85610b5c565b9050600061086a600c610b91565b9050600080826001600160a01b0316878786888c6040516024016108929594939291906118e0565b60408051601f198184030181529181526020820180516001600160e01b0316634dca592560e01b179052516108c79190611979565b6000604051808303816000865af19150503d8060008114610904576040519150601f19603f3d011682016040523d82523d6000602084013e610909565b606091505b50915091508161096057604051634dca592560e01b906001600160a01b038516907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610957908590611995565b60405180910390a35b600061096c600d610b91565b9050806001600160a01b0316888887898d6040516024016109919594939291906118e0565b60408051601f198184030181529181526020820180516001600160e01b03166335e5b7eb60e11b179052516109c69190611979565b6000604051808303816000865af19150503d8060008114610a03576040519150601f19603f3d011682016040523d82523d6000602084013e610a08565b606091505b50909350915082610a60576040516335e5b7eb60e11b906001600160a01b038316907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610a57908690611995565b60405180910390a35b505050505050505050505050505050565b600154600390600160a81b900460ff16158015610a9c575060015460ff808316600160a01b90920416105b610ab85760405162461bcd60e51b815260040161024690611767565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055610aeb600b86610c78565b610af6600c85610c78565b610b01600d84610c78565b610b0c600483610c78565b600019600b556001805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050505050565b600081815260096020526040902060010154610b7782611198565b15610b8c57600654610b8990826119c8565b90505b919050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610bc857610bc86117b5565b60ff1681526020810191909152604001600020546001600160a01b0316905080610b8c578160405163409140df60e11b815260040161024691906119fd565b600081815260096020526040902054610c1f82611198565b15610b8c57600454610b8990826119c8565b6060610c70848484808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506113a492505050565b949350505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610cae57610cae6117b5565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610cef57610cef6117b5565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610d2581610b91565b6001600160a01b0316336001600160a01b031614610559576000356001600160e01b03191681336040516320e0f98d60e21b815260040161024693929190611a0b565b600254431015610d7457005b565b6000610d826008610b91565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015610dcc573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df091906117cb565b905080600360000154101561068e576000826001600160a01b031663468c96ae6003600001546001610e2291906119c8565b6040518263ffffffff1660e01b8152600401610e4091815260200190565b6040805180830381865afa158015610e5c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e809190611a42565b60038490556000818152600960205260408120600454815493955090935091839190610ead9084906119c8565b9091555050600654600182018054600090610ec99084906119c8565b90915550600090505b600854811015610f5957600880546000919083908110610ef457610ef46117e4565b60009182526020808320909101546001600160a01b0316808352600782526040808420546002880190935283208054919450919290610f349084906119c8565b90915550506001600160a01b0316600090815260076020526040812055600101610ed2565b5060005b600454811015610feb57600060036001018281548110610f7f57610f7f6117e4565b6000918252602082206002918202018054909350600a91839160ff1690811115610fab57610fab6117b5565b6002811115610fbc57610fbc6117b5565b815260208082019290925260409081016000908120600195860154825290925290206003018590555001610f5d565b50610ff860046000611476565b60006005818155600682905590611010600882611458565b505050505050565b6000600a6000866002811115611030576110306117b5565b6002811115611041576110416117b5565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff161561108457506102de565b6001600160a01b03831660009081526002820160205260408120805460ff19166001179055600382015490819003611151576001600160a01b038416600090815260076020526040812054900361112157600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30180546001600160a01b0319166001600160a01b0386161790555b6006805460019081019091556001600160a01b038516600090815260076020526040902080549091019055611010565b82810361101057600090815260096020908152604080832060018082018054820190556001600160a01b039790971684526002019091529020805490930190925550505050565b6000806111a56008610b91565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa1580156111ef573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061121391906117cb565b9050600080836001600160a01b031663468c96ae600360000154600161123991906119c8565b6040518263ffffffff1660e01b815260040161125791815260200190565b6040805180830381865afa158015611273573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112979190611a42565b915091508180156112a757508086145b80156112b4575060035483115b9695505050505050565b60008381526009602090815260408083206001600160a01b0386168452600201909152902054811561130d576001600160a01b038316600090815260076020526040902054610c7090826119c8565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610d74576000356001600160e01b0319166001604051620f948f60ea1b8152600401610246929190611a75565b806001600160a01b03163b60000361055957604051630bfc64a360e21b81526001600160a01b0382166004820152602401610246565b80516060908067ffffffffffffffff8111156113c2576113c26117fa565b6040519080825280602002602001820160405280156113eb578160200160208202803683370190505b50915060006113f985611198565b905060005b8281101561144f5761142a8686838151811061141c5761141c6117e4565b6020026020010151846112be565b84828151811061143c5761143c6117e4565b60209081029190910101526001016113fe565b50505092915050565b50805460008255906000526020600020908101906105599190611497565b508054600082556002029060005260206000209081019061055991906114b0565b5b808211156114ac5760008155600101611498565b5090565b5b808211156114ac57805460ff19168155600060018201556002016114b1565b6001600160a01b038116811461055957600080fd5b6000806000606084860312156114fa57600080fd5b8335611505816114d0565b92506020840135611515816114d0565b929592945050506040919091013590565b803560038110610b8c57600080fd5b6000806040838503121561154857600080fd5b61155183611526565b946020939093013593505050565b6000806040838503121561157257600080fd5b823591506020830135611584816114d0565b809150509250929050565b803560108110610b8c57600080fd5b600080604083850312156115b157600080fd5b6115ba8361158f565b91506020830135611584816114d0565b6000806000606084860312156115df57600080fd5b6115e884611526565b92506020840135915060408401356115ff816114d0565b809150509250925092565b6000806000806080858703121561162057600080fd5b843561162b816114d0565b9350602085013561163b816114d0565b9250604085013561164b816114d0565b9150606085013561165b816114d0565b939692955090935050565b60006020828403121561167857600080fd5b5035919050565b60006020828403121561169157600080fd5b6105718261158f565b6000806000604084860312156116af57600080fd5b83359250602084013567ffffffffffffffff808211156116ce57600080fd5b818601915086601f8301126116e257600080fd5b8135818111156116f157600080fd5b8760208260051b850101111561170657600080fd5b6020830194508093505050509250925092565b600081518084526020808501945080840160005b838110156117495781518752958201959082019060010161172d565b509495945050505050565b6020815260006105716020830184611719565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052602160045260246000fd5b6000602082840312156117dd57600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b8051610b8c816114d0565b6000602080838503121561182e57600080fd5b825167ffffffffffffffff8082111561184657600080fd5b818501915085601f83011261185a57600080fd5b81518181111561186c5761186c6117fa565b8060051b604051601f19603f83011681018181108582111715611891576118916117fa565b6040529182528482019250838101850191888311156118af57600080fd5b938501935b828510156118d4576118c585611810565b845293850193928501926118b4565b98975050505050505050565b60a0808252865190820181905260009060209060c0840190828a01845b828110156119225781516001600160a01b0316845292840192908401906001016118fd565b505050838103828501526119368189611719565b6040850197909752505050606081019290925260809091015292915050565b60005b83811015611970578181015183820152602001611958565b50506000910152565b6000825161198b818460208701611955565b9190910192915050565b60208152600082518060208401526119b4816040850160208701611955565b601f01601f19169190910160400192915050565b8082018082111561057457634e487b7160e01b600052601160045260246000fd5b601081106119f9576119f96117b5565b9052565b6020810161057482846119e9565b6001600160e01b03198416815260608101611a2960208301856119e9565b6001600160a01b03929092166040919091015292915050565b60008060408385031215611a5557600080fd5b82518015158114611a6557600080fd5b6020939093015192949293505050565b6001600160e01b03198316815260408101600b8310611a9657611a966117b5565b826020830152939250505056fea26469706673582212207c1e9b1dc78cc32780128834c16297cb51ade3b76253c761438c2697dd9f7f4c64736f6c63430008110033", "devdoc": { "errors": { - "ErrCallerMustBeBridgeContract()": [ + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ { - "details": "Error of method caller must be bridge contract." + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } } ], - "ErrCallerMustBeValidatorContract()": [ + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ { - "details": "Error of method caller must be validator contract." + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } } ], - "ErrZeroCodeContract()": [ + "ErrZeroCodeContract(address)": [ { "details": "Error of set to non-contract." } @@ -331,8 +434,14 @@ }, "kind": "dev", "methods": { - "bridgeContract()": { - "details": "Returns the bridge contract." + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } }, "getManyTotalBallots(uint256,address[])": { "details": "Returns the total number of ballots of bridge operators at the specific period `_period`." @@ -343,39 +452,46 @@ "initialize(address,address,uint256)": { "details": "Initializes the contract storage." }, + "initializeREP2()": { + "details": "Helper for running upgrade script, required to only revoked once by the DPoS's governance admin. The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod + 1` == `{BridgeSlash}._startedAtPeriod - 1` == `currentPeriod()`" + }, "recordVote(uint8,uint256,address)": { "details": "Records vote for a receipt and a operator. Requirements: - The method caller is the bridge contract." }, - "setBridgeContract(address)": { - "details": "Sets the bridge contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `BridgeContractUpdated`." + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } }, - "setValidatorContract(address)": { - "details": "Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`." + "startedAtBlock()": { + "details": "Returns the block that allow incomming mutable call." }, - "totalBallots(uint256)": { + "totalBallot(uint256)": { "details": "Returns the total number of ballots at the specific period `_period`." }, - "totalBallotsOf(uint256,address)": { + "totalBallotOf(uint256,address)": { "details": "Returns the total number of ballots of a bridge operator at the specific period `_period`." }, - "totalVotes(uint256)": { + "totalVote(uint256)": { "details": "Returns the total number of votes at the specific period `_period`." - }, - "validatorContract()": { - "details": "Returns the validator contract." } }, "stateVariables": { "_bufferMetric": { "details": "The temporary info of votes and ballots" }, + "_lastSyncPeriod": { + "details": "The latest period that get synced with bridge's slashing and rewarding contract" + }, "_periodMetric": { "details": "Mapping from period number => vote stats based on period" }, "_receiptTrackingInfo": { "details": "Mapping from vote kind => receipt id => receipt stats" }, - "startedAtBlock": { + "_startedAtBlock": { "details": "The block that the contract allows incoming mutable calls." } }, @@ -389,20 +505,20 @@ "storageLayout": { "storage": [ { - "astId": 6386, + "astId": 42044, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "_bridgeContract", + "label": "______deprecatedBridge", "offset": 0, "slot": "0", - "type": "t_contract(IBridge)9212" + "type": "t_address" }, { - "astId": 7051, + "astId": 42048, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "_validatorContract", + "label": "______deprecatedValidator", "offset": 0, "slot": "1", - "type": "t_contract(IRoninValidatorSet)11967" + "type": "t_address" }, { "astId": 1373, @@ -421,36 +537,44 @@ "type": "t_bool" }, { - "astId": 23076, + "astId": 28038, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "startedAtBlock", + "label": "_startedAtBlock", "offset": 0, "slot": "2", "type": "t_uint256" }, { - "astId": 23080, + "astId": 28042, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "_bufferMetric", "offset": 0, "slot": "3", - "type": "t_struct(PeriodVotingMetricTimeWrapper)23057_storage" + "type": "t_struct(PeriodVotingMetricTimeWrapper)28019_storage" }, { - "astId": 23086, + "astId": 28048, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "_periodMetric", "offset": 0, "slot": "9", - "type": "t_mapping(t_uint256,t_struct(PeriodVotingMetric)23047_storage)" + "type": "t_mapping(t_uint256,t_struct(PeriodVotingMetric)28009_storage)" }, { - "astId": 23095, + "astId": 28057, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "_receiptTrackingInfo", "offset": 0, "slot": "10", - "type": "t_mapping(t_enum(VoteKind)9224,t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)23073_storage))" + "type": "t_mapping(t_enum(VoteKind)12750,t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)28035_storage))" + }, + { + "astId": 28060, + "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", + "label": "_lastSyncPeriod", + "offset": 0, + "slot": "11", + "type": "t_uint256" } ], "types": { @@ -465,8 +589,8 @@ "label": "address[]", "numberOfBytes": "32" }, - "t_array(t_struct(Request)9220_storage)dyn_storage": { - "base": "t_struct(Request)9220_storage", + "t_array(t_struct(Request)12746_storage)dyn_storage": { + "base": "t_struct(Request)12746_storage", "encoding": "dynamic_array", "label": "struct IBridgeTracking.Request[]", "numberOfBytes": "32" @@ -476,17 +600,7 @@ "label": "bool", "numberOfBytes": "1" }, - "t_contract(IBridge)9212": { - "encoding": "inplace", - "label": "contract IBridge", - "numberOfBytes": "20" - }, - "t_contract(IRoninValidatorSet)11967": { - "encoding": "inplace", - "label": "contract IRoninValidatorSet", - "numberOfBytes": "20" - }, - "t_enum(VoteKind)9224": { + "t_enum(VoteKind)12750": { "encoding": "inplace", "label": "enum IBridgeTracking.VoteKind", "numberOfBytes": "1" @@ -505,57 +619,57 @@ "numberOfBytes": "32", "value": "t_uint256" }, - "t_mapping(t_enum(VoteKind)9224,t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)23073_storage))": { + "t_mapping(t_enum(VoteKind)12750,t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)28035_storage))": { "encoding": "mapping", - "key": "t_enum(VoteKind)9224", + "key": "t_enum(VoteKind)12750", "label": "mapping(enum IBridgeTracking.VoteKind => mapping(uint256 => struct BridgeTracking.ReceiptTrackingInfo))", "numberOfBytes": "32", - "value": "t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)23073_storage)" + "value": "t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)28035_storage)" }, - "t_mapping(t_uint256,t_struct(PeriodVotingMetric)23047_storage)": { + "t_mapping(t_uint256,t_struct(PeriodVotingMetric)28009_storage)": { "encoding": "mapping", "key": "t_uint256", "label": "mapping(uint256 => struct BridgeTracking.PeriodVotingMetric)", "numberOfBytes": "32", - "value": "t_struct(PeriodVotingMetric)23047_storage" + "value": "t_struct(PeriodVotingMetric)28009_storage" }, - "t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)23073_storage)": { + "t_mapping(t_uint256,t_struct(ReceiptTrackingInfo)28035_storage)": { "encoding": "mapping", "key": "t_uint256", "label": "mapping(uint256 => struct BridgeTracking.ReceiptTrackingInfo)", "numberOfBytes": "32", - "value": "t_struct(ReceiptTrackingInfo)23073_storage" + "value": "t_struct(ReceiptTrackingInfo)28035_storage" }, - "t_struct(PeriodVotingMetric)23047_storage": { + "t_struct(PeriodVotingMetric)28009_storage": { "encoding": "inplace", "label": "struct BridgeTracking.PeriodVotingMetric", "members": [ { - "astId": 23037, + "astId": 27999, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "totalRequests", + "label": "totalRequest", "offset": 0, "slot": "0", "type": "t_uint256" }, { - "astId": 23039, + "astId": 28001, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "totalBallots", + "label": "totalBallot", "offset": 0, "slot": "1", "type": "t_uint256" }, { - "astId": 23043, + "astId": 28005, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", - "label": "totalBallotsOf", + "label": "totalBallotOf", "offset": 0, "slot": "2", "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 23046, + "astId": 28008, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "voters", "offset": 0, @@ -565,12 +679,12 @@ ], "numberOfBytes": "128" }, - "t_struct(PeriodVotingMetricTimeWrapper)23057_storage": { + "t_struct(PeriodVotingMetricTimeWrapper)28019_storage": { "encoding": "inplace", "label": "struct BridgeTracking.PeriodVotingMetricTimeWrapper", "members": [ { - "astId": 23049, + "astId": 28011, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "lastEpoch", "offset": 0, @@ -578,30 +692,30 @@ "type": "t_uint256" }, { - "astId": 23053, + "astId": 28015, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "requests", "offset": 0, "slot": "1", - "type": "t_array(t_struct(Request)9220_storage)dyn_storage" + "type": "t_array(t_struct(Request)12746_storage)dyn_storage" }, { - "astId": 23056, + "astId": 28018, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "data", "offset": 0, "slot": "2", - "type": "t_struct(PeriodVotingMetric)23047_storage" + "type": "t_struct(PeriodVotingMetric)28009_storage" } ], "numberOfBytes": "192" }, - "t_struct(ReceiptTrackingInfo)23073_storage": { + "t_struct(ReceiptTrackingInfo)28035_storage": { "encoding": "inplace", "label": "struct BridgeTracking.ReceiptTrackingInfo", "members": [ { - "astId": 23060, + "astId": 28022, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "approvedPeriod", "offset": 0, @@ -609,7 +723,7 @@ "type": "t_uint256" }, { - "astId": 23064, + "astId": 28026, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "voters", "offset": 0, @@ -617,7 +731,7 @@ "type": "t_array(t_address)dyn_storage" }, { - "astId": 23069, + "astId": 28031, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "voted", "offset": 0, @@ -625,7 +739,7 @@ "type": "t_mapping(t_address,t_bool)" }, { - "astId": 23072, + "astId": 28034, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "trackedPeriod", "offset": 0, @@ -635,20 +749,20 @@ ], "numberOfBytes": "128" }, - "t_struct(Request)9220_storage": { + "t_struct(Request)12746_storage": { "encoding": "inplace", "label": "struct IBridgeTracking.Request", "members": [ { - "astId": 9217, + "astId": 12743, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "kind", "offset": 0, "slot": "0", - "type": "t_enum(VoteKind)9224" + "type": "t_enum(VoteKind)12750" }, { - "astId": 9219, + "astId": 12745, "contract": "contracts/ronin/gateway/BridgeTracking.sol:BridgeTracking", "label": "id", "offset": 0, diff --git a/deployments/ronin-mainnet/FastFinalityTrackingLogic.json b/deployments/ronin-mainnet/FastFinalityTrackingLogic.json new file mode 100644 index 000000000..d9787dbcd --- /dev/null +++ b/deployments/ronin-mainnet/FastFinalityTrackingLogic.json @@ -0,0 +1,356 @@ +{ + "address": "0x241e507363d674c77a9930F31ea26BBc8857949c", + "abi": [ + { + "inputs": [], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "inputs": [], + "name": "ErrCallerMustBeCoinbase", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrOncePerBlock", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "epoch", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "addrs", + "type": "address[]" + } + ], + "name": "getManyFinalityVoteCounts", + "outputs": [ + { + "internalType": "uint256[]", + "name": "voteCounts", + "type": "uint256[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "validatorContract", + "type": "address" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "voters", + "type": "address[]" + } + ], + "name": "recordFinality", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "transactionHash": "0x2b06f8639881c5802725c7bce1662ee1eba1189ee067b20e02b3be90c440136e", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x241e507363d674c77a9930F31ea26BBc8857949c", + "transactionIndex": 2, + "gasUsed": "544940", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000800000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000", + "blockHash": "0x6376a321e8810316fc906ba925fd4f6a987decdb9f3852be0422e2b3d4df86e0", + "transactionHash": "0x2b06f8639881c5802725c7bce1662ee1eba1189ee067b20e02b3be90c440136e", + "logs": [ + { + "transactionIndex": 2, + "blockNumber": 28139018, + "transactionHash": "0x2b06f8639881c5802725c7bce1662ee1eba1189ee067b20e02b3be90c440136e", + "address": "0x241e507363d674c77a9930F31ea26BBc8857949c", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", + "logIndex": 2, + "blockHash": "0x6376a321e8810316fc906ba925fd4f6a987decdb9f3852be0422e2b3d4df86e0" + } + ], + "blockNumber": 28139018, + "cumulativeGasUsed": "663784", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 1, + "solcInputHash": "c681844a462c08b610099ffca6511819", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeCoinbase\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrOncePerBlock\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"epoch\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"addrs\",\"type\":\"address[]\"}],\"name\":\"getManyFinalityVoteCounts\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"voteCounts\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validatorContract\",\"type\":\"address\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"voters\",\"type\":\"address[]\"}],\"name\":\"recordFinality\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallerMustBeCoinbase()\":[{\"details\":\"Error of method caller must be coinbase\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrOncePerBlock()\":[{\"details\":\"Error indicating that the method is only called once per block.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getManyFinalityVoteCounts(uint256,address[])\":{\"details\":\"Returns vote count of `addrs` in the `period`.\"},\"recordFinality(address[])\":{\"details\":\"Submit list of `voters` who vote for fast finality in the current block. Requirements: - Only called once per block - Only coinbase can call this method\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}}},\"stateVariables\":{\"_latestTrackingBlock\":{\"details\":\"The latest block that tracked the QC vote\"},\"_tracker\":{\"details\":\"Mapping from epoch number => consensus address => number of QC vote\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/fast-finality/FastFinalityTracking.sol\":\"FastFinalityTracking\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IFastFinalityTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IFastFinalityTracking {\\n /**\\n * @dev Submit list of `voters` who vote for fast finality in the current block.\\n *\\n * Requirements:\\n * - Only called once per block\\n * - Only coinbase can call this method\\n */\\n function recordFinality(address[] calldata voters) external;\\n\\n /**\\n * @dev Returns vote count of `addrs` in the `period`.\\n */\\n function getManyFinalityVoteCounts(\\n uint256 period,\\n address[] calldata addrs\\n ) external view returns (uint256[] memory voteCounts);\\n}\\n\",\"keccak256\":\"0xdc397642692af9710314e971f8de772d50d6bc304db9e5babd9ffcfb9d2f4434\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/ronin/fast-finality/FastFinalityTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport { IRoninValidatorSet } from \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport { IFastFinalityTracking } from \\\"../..//interfaces/IFastFinalityTracking.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\\n /// @dev Mapping from epoch number => consensus address => number of QC vote\\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\\n /// @dev The latest block that tracked the QC vote\\n uint256 internal _latestTrackingBlock;\\n\\n modifier oncePerBlock() {\\n if (block.number <= _latestTrackingBlock) {\\n revert ErrOncePerBlock();\\n }\\n\\n _latestTrackingBlock = block.number;\\n _;\\n }\\n\\n modifier onlyCoinbase() {\\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\\n _;\\n }\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n function initialize(address validatorContract) external initializer {\\n _setContract(ContractType.VALIDATOR, validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IFastFinalityTracking\\n */\\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\\n\\n for (uint i; i < voters.length; ) {\\n unchecked {\\n ++_tracker[currentEpoch][voters[i]];\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IFastFinalityTracking\\n */\\n function getManyFinalityVoteCounts(\\n uint256 epoch,\\n address[] calldata addrs\\n ) external view override returns (uint256[] memory voteCounts) {\\n uint256 length = addrs.length;\\n voteCounts = new uint256[](length);\\n for (uint i; i < length; ) {\\n voteCounts[i] = _tracker[epoch][addrs[i]];\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x8b7a1c5469f8e953fbbb3b8b1d565de573c7bd92d3a603a08c79a38d7944bd11\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100de565b600054610100900460ff161561008a5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff90811610156100dc576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61086a806100ed6000396000f3fe608060405234801561001057600080fd5b50600436106100575760003560e01c8063468d24be1461005c578063865e6fd314610085578063c245db0f1461009a578063c4d66de8146100ad578063de981f1b146100c0575b600080fd5b61006f61006a366004610629565b6100eb565b60405161007c9190610675565b60405180910390f35b6100986100933660046106df565b6101c3565b005b6100986100a8366004610712565b6101e2565b6100986100bb366004610754565b610310565b6100d36100ce366004610776565b610429565b6040516001600160a01b03909116815260200161007c565b6060818067ffffffffffffffff81111561010757610107610791565b604051908082528060200260200182016040528015610130578160200160208202803683370190505b50915060005b818110156101ba5760008681526001602052604081209086868481811061015f5761015f6107a7565b90506020020160208101906101749190610754565b6001600160a01b03166001600160a01b03168152602001908152602001600020548382815181106101a7576101a76107a7565b6020908102919091010152600101610136565b50509392505050565b6101cb6104a4565b6101d481610500565b6101de8282610539565b5050565b600254431161020457604051636907b55f60e01b815260040160405180910390fd5b43600255334114610228576040516309f358fd60e01b815260040160405180910390fd5b60006102346008610429565b60405163a3d545f560e01b81524360048201526001600160a01b03919091169063a3d545f590602401602060405180830381865afa15801561027a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061029e91906107bd565b905060005b8281101561030a576000828152600160205260408120908585848181106102cc576102cc6107a7565b90506020020160208101906102e19190610754565b6001600160a01b03168152602081019190915260400160002080546001908101909155016102a3565b50505050565b600054610100900460ff16158080156103305750600054600160ff909116105b8061034a5750303b15801561034a575060005460ff166001145b6103b25760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff1916600117905580156103d5576000805461ff0019166101001790555b6103e0600883610539565b80156101de576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610460576104606107d6565b60ff1681526020810191909152604001600020546001600160a01b031690508061049f578160405163409140df60e11b81526004016103a991906107ec565b919050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031633146104fe576000356001600160e01b0319166001604051620f948f60ea1b81526004016103a9929190610806565b565b806001600160a01b03163b60000361053657604051630bfc64a360e21b81526001600160a01b03821660048201526024016103a9565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561056f5761056f6107d6565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156105b0576105b06107d6565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b60008083601f8401126105ef57600080fd5b50813567ffffffffffffffff81111561060757600080fd5b6020830191508360208260051b850101111561062257600080fd5b9250929050565b60008060006040848603121561063e57600080fd5b83359250602084013567ffffffffffffffff81111561065c57600080fd5b610668868287016105dd565b9497909650939450505050565b6020808252825182820181905260009190848201906040850190845b818110156106ad57835183529284019291840191600101610691565b50909695505050505050565b80356010811061049f57600080fd5b80356001600160a01b038116811461049f57600080fd5b600080604083850312156106f257600080fd5b6106fb836106b9565b9150610709602084016106c8565b90509250929050565b6000806020838503121561072557600080fd5b823567ffffffffffffffff81111561073c57600080fd5b610748858286016105dd565b90969095509350505050565b60006020828403121561076657600080fd5b61076f826106c8565b9392505050565b60006020828403121561078857600080fd5b61076f826106b9565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6000602082840312156107cf57600080fd5b5051919050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610800576108006107d6565b91905290565b6001600160e01b03198316815260408101600b8310610827576108276107d6565b826020830152939250505056fea264697066735822122056aa632bd1859cb8217cd85fee3e983ca3e08c2bb790f3bf24c27d4e1c2a525564736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100575760003560e01c8063468d24be1461005c578063865e6fd314610085578063c245db0f1461009a578063c4d66de8146100ad578063de981f1b146100c0575b600080fd5b61006f61006a366004610629565b6100eb565b60405161007c9190610675565b60405180910390f35b6100986100933660046106df565b6101c3565b005b6100986100a8366004610712565b6101e2565b6100986100bb366004610754565b610310565b6100d36100ce366004610776565b610429565b6040516001600160a01b03909116815260200161007c565b6060818067ffffffffffffffff81111561010757610107610791565b604051908082528060200260200182016040528015610130578160200160208202803683370190505b50915060005b818110156101ba5760008681526001602052604081209086868481811061015f5761015f6107a7565b90506020020160208101906101749190610754565b6001600160a01b03166001600160a01b03168152602001908152602001600020548382815181106101a7576101a76107a7565b6020908102919091010152600101610136565b50509392505050565b6101cb6104a4565b6101d481610500565b6101de8282610539565b5050565b600254431161020457604051636907b55f60e01b815260040160405180910390fd5b43600255334114610228576040516309f358fd60e01b815260040160405180910390fd5b60006102346008610429565b60405163a3d545f560e01b81524360048201526001600160a01b03919091169063a3d545f590602401602060405180830381865afa15801561027a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061029e91906107bd565b905060005b8281101561030a576000828152600160205260408120908585848181106102cc576102cc6107a7565b90506020020160208101906102e19190610754565b6001600160a01b03168152602081019190915260400160002080546001908101909155016102a3565b50505050565b600054610100900460ff16158080156103305750600054600160ff909116105b8061034a5750303b15801561034a575060005460ff166001145b6103b25760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff1916600117905580156103d5576000805461ff0019166101001790555b6103e0600883610539565b80156101de576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610460576104606107d6565b60ff1681526020810191909152604001600020546001600160a01b031690508061049f578160405163409140df60e11b81526004016103a991906107ec565b919050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031633146104fe576000356001600160e01b0319166001604051620f948f60ea1b81526004016103a9929190610806565b565b806001600160a01b03163b60000361053657604051630bfc64a360e21b81526001600160a01b03821660048201526024016103a9565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561056f5761056f6107d6565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156105b0576105b06107d6565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b60008083601f8401126105ef57600080fd5b50813567ffffffffffffffff81111561060757600080fd5b6020830191508360208260051b850101111561062257600080fd5b9250929050565b60008060006040848603121561063e57600080fd5b83359250602084013567ffffffffffffffff81111561065c57600080fd5b610668868287016105dd565b9497909650939450505050565b6020808252825182820181905260009190848201906040850190845b818110156106ad57835183529284019291840191600101610691565b50909695505050505050565b80356010811061049f57600080fd5b80356001600160a01b038116811461049f57600080fd5b600080604083850312156106f257600080fd5b6106fb836106b9565b9150610709602084016106c8565b90509250929050565b6000806020838503121561072557600080fd5b823567ffffffffffffffff81111561073c57600080fd5b610748858286016105dd565b90969095509350505050565b60006020828403121561076657600080fd5b61076f826106c8565b9392505050565b60006020828403121561078857600080fd5b61076f826106b9565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6000602082840312156107cf57600080fd5b5051919050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610800576108006107d6565b91905290565b6001600160e01b03198316815260408101600b8310610827576108276107d6565b826020830152939250505056fea264697066735822122056aa632bd1859cb8217cd85fee3e983ca3e08c2bb790f3bf24c27d4e1c2a525564736f6c63430008110033", + "devdoc": { + "errors": { + "ErrCallerMustBeCoinbase()": [ + { + "details": "Error of method caller must be coinbase" + } + ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrOncePerBlock()": [ + { + "details": "Error indicating that the method is only called once per block." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getManyFinalityVoteCounts(uint256,address[])": { + "details": "Returns vote count of `addrs` in the `period`." + }, + "recordFinality(address[])": { + "details": "Submit list of `voters` who vote for fast finality in the current block. Requirements: - Only called once per block - Only coinbase can call this method" + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + } + }, + "stateVariables": { + "_latestTrackingBlock": { + "details": "The latest block that tracked the QC vote" + }, + "_tracker": { + "details": "Mapping from epoch number => consensus address => number of QC vote" + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 1373, + "contract": "contracts/ronin/fast-finality/FastFinalityTracking.sol:FastFinalityTracking", + "label": "_initialized", + "offset": 0, + "slot": "0", + "type": "t_uint8" + }, + { + "astId": 1376, + "contract": "contracts/ronin/fast-finality/FastFinalityTracking.sol:FastFinalityTracking", + "label": "_initializing", + "offset": 1, + "slot": "0", + "type": "t_bool" + }, + { + "astId": 25988, + "contract": "contracts/ronin/fast-finality/FastFinalityTracking.sol:FastFinalityTracking", + "label": "_tracker", + "offset": 0, + "slot": "1", + "type": "t_mapping(t_uint256,t_mapping(t_address,t_uint256))" + }, + { + "astId": 25991, + "contract": "contracts/ronin/fast-finality/FastFinalityTracking.sol:FastFinalityTracking", + "label": "_latestTrackingBlock", + "offset": 0, + "slot": "2", + "type": "t_uint256" + } + ], + "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_mapping(t_address,t_uint256)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_mapping(t_uint256,t_mapping(t_address,t_uint256))": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => mapping(address => uint256))", + "numberOfBytes": "32", + "value": "t_mapping(t_address,t_uint256)" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/FastFinalityTrackingProxy.json b/deployments/ronin-mainnet/FastFinalityTrackingProxy.json new file mode 100644 index 000000000..17cc8d1a0 --- /dev/null +++ b/deployments/ronin-mainnet/FastFinalityTrackingProxy.json @@ -0,0 +1,273 @@ +{ + "address": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "transactionIndex": 2, + "gasUsed": "689938", + "logsBloom": "0x00000000080000000000000000000000400000000000000000000000000000000000000000000000000000000800000000000000000080010100000000000000000000000000800000000000000002000000000000000000000000000000002000000000000000000000000000000000000000800000000000000004000000000080000000000000080000000000000000000000000080000000000000800000000000000000000000000000000400000000000000000000000000000000000040000020000000000000000000040000000000000400001010000000000000800000000000000004000000000000000000000000000000000000000000000000", + "blockHash": "0x109abf7cc1c22ed06005e4c97b5d1551eb1dab6eacb2c7e9d3f1b63ab69d5a5c", + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "logs": [ + { + "transactionIndex": 2, + "blockNumber": 28139075, + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "address": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x000000000000000000000000241e507363d674c77a9930f31ea26bbc8857949c" + ], + "data": "0x", + "logIndex": 2, + "blockHash": "0x109abf7cc1c22ed06005e4c97b5d1551eb1dab6eacb2c7e9d3f1b63ab69d5a5c" + }, + { + "transactionIndex": 2, + "blockNumber": 28139075, + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "address": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000008", + "0x000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "data": "0x", + "logIndex": 3, + "blockHash": "0x109abf7cc1c22ed06005e4c97b5d1551eb1dab6eacb2c7e9d3f1b63ab69d5a5c" + }, + { + "transactionIndex": 2, + "blockNumber": 28139075, + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "address": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000001", + "logIndex": 4, + "blockHash": "0x109abf7cc1c22ed06005e4c97b5d1551eb1dab6eacb2c7e9d3f1b63ab69d5a5c" + }, + { + "transactionIndex": 2, + "blockNumber": 28139075, + "transactionHash": "0x381c847967f0b32f9c676f1f5691beb941b016027fbc0c686f9b5b9ba3240b86", + "address": "0xA30B2932CD8b8A89E34551Cdfa13810af38dA576", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000004d58ea7231c394d5804e8b06b1365915f906e27f", + "logIndex": 5, + "blockHash": "0x109abf7cc1c22ed06005e4c97b5d1551eb1dab6eacb2c7e9d3f1b63ab69d5a5c" + } + ], + "blockNumber": 28139075, + "cumulativeGasUsed": "828629", + "status": 1, + "byzantium": true + }, + "args": [ + "0x241e507363d674c77a9930F31ea26BBc8857949c", + "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "0xc4d66de8000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "numDeployments": 1, + "solcInputHash": "c681844a462c08b610099ffca6511819", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405260405162000f5f38038062000f5f83398101604081905262000026916200048d565b8282828281620000398282600062000053565b506200004790508262000090565b505050505050620005c0565b6200005e83620000eb565b6000825111806200006c5750805b156200008b576200008983836200012d60201b620002911760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f620000bb6200015c565b604080516001600160a01b03928316815291841660208301520160405180910390a1620000e88162000195565b50565b620000f6816200024a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b606062000155838360405180606001604052806027815260200162000f3860279139620002fe565b9392505050565b60006200018660008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b546001600160a01b0316919050565b6001600160a01b038116620002005760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b806200022960008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b6200026081620003e760201b620002bd1760201c565b620002c45760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401620001f7565b80620002297f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc60001b620003e460201b6200024d1760201c565b60606001600160a01b0384163b620003685760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401620001f7565b600080856001600160a01b0316856040516200038591906200056d565b600060405180830381855af49150503d8060008114620003c2576040519150601f19603f3d011682016040523d82523d6000602084013e620003c7565b606091505b509092509050620003da828286620003f6565b9695505050505050565b90565b6001600160a01b03163b151590565b606083156200040757508162000155565b825115620004185782518084602001fd5b8160405162461bcd60e51b8152600401620001f791906200058b565b80516001600160a01b03811681146200044c57600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b83811015620004845781810151838201526020016200046a565b50506000910152565b600080600060608486031215620004a357600080fd5b620004ae8462000434565b9250620004be6020850162000434565b60408501519092506001600160401b0380821115620004dc57600080fd5b818601915086601f830112620004f157600080fd5b81518181111562000506576200050662000451565b604051601f8201601f19908116603f0116810190838211818310171562000531576200053162000451565b816040528281528960208487010111156200054b57600080fd5b6200055e83602083016020880162000467565b80955050505050509250925092565b600082516200058181846020870162000467565b9190910192915050565b6020815260008251806020840152620005ac81604085016020870162000467565b601f01601f19169190910160400192915050565b61094880620005d06000396000f3fe6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/MaintenanceLogic.json b/deployments/ronin-mainnet/MaintenanceLogic.json index 0856ef658..9f238f876 100644 --- a/deployments/ronin-mainnet/MaintenanceLogic.json +++ b/deployments/ronin-mainnet/MaintenanceLogic.json @@ -1,5 +1,5 @@ { - "address": "0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa", + "address": "0xca9F10769292F26850333264d618c1B5E91f394D", "abi": [ { "inputs": [], @@ -8,14 +8,111 @@ }, { "inputs": [], - "name": "ErrCallerMustBeValidatorContract", + "name": "ErrAlreadyOnMaintenance", "type": "error" }, { "inputs": [], + "name": "ErrAlreadyScheduled", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrCooldownTimeNotYetEnded", + "type": "error" + }, + { + "inputs": [], + "name": "ErrEndBlockOutOfRange", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidMaintenanceDuration", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidMaintenanceDurationConfig", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidOffsetToStartScheduleConfigs", + "type": "error" + }, + { + "inputs": [], + "name": "ErrStartBlockOutOfRange", + "type": "error" + }, + { + "inputs": [], + "name": "ErrTotalOfSchedulesExceeded", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [], + "name": "ErrUnexistedSchedule", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, { "anonymous": false, "inputs": [ @@ -126,19 +223,6 @@ "name": "MaintenanceScheduled", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "ValidatorContractUpdated", - "type": "event" - }, { "inputs": [ { @@ -160,7 +244,7 @@ "type": "address" } ], - "name": "checkCooldownEnds", + "name": "checkCooldownEnded", "outputs": [ { "internalType": "bool", @@ -309,6 +393,25 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -393,6 +496,13 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [], "name": "maxMaintenanceDurationInBlock", @@ -421,7 +531,7 @@ }, { "inputs": [], - "name": "maxSchedules", + "name": "maxSchedule", "outputs": [ { "internalType": "uint256", @@ -481,6 +591,24 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [ { @@ -519,22 +647,9 @@ "stateMutability": "nonpayable", "type": "function" }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setValidatorContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, { "inputs": [], - "name": "totalSchedules", + "name": "totalSchedule", "outputs": [ { "internalType": "uint256", @@ -544,64 +659,110 @@ ], "stateMutability": "view", "type": "function" - }, - { - "inputs": [], - "name": "validatorContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" } ], - "transactionHash": "0x4a0b26846fc54088b10b0fe0afd85420bc234dac81f23509eda3d1a4a45d55c2", + "transactionHash": "0x386e94a18f4869b8ded85a3b815d248553fa4aaa166dfb7e2abfb172220c329b", "receipt": { "to": null, "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", - "contractAddress": "0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa", - "transactionIndex": 1, - "gasUsed": "1410539", - "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0xde0c1aa121664bb771882b7b61c67e7cec6aa5db5a2c891aa978b67b3793acac", - "transactionHash": "0x4a0b26846fc54088b10b0fe0afd85420bc234dac81f23509eda3d1a4a45d55c2", + "contractAddress": "0xca9F10769292F26850333264d618c1B5E91f394D", + "transactionIndex": 0, + "gasUsed": "1265570", + "logsBloom": "0x00000000000000000000000080000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000", + "blockHash": "0x1632e7d1ee77ceeff8dd29209df4e5ad1b9ffd67b6ed1cd2df942db4be30f842", + "transactionHash": "0x386e94a18f4869b8ded85a3b815d248553fa4aaa166dfb7e2abfb172220c329b", "logs": [ { - "transactionIndex": 1, - "blockNumber": 24127446, - "transactionHash": "0x4a0b26846fc54088b10b0fe0afd85420bc234dac81f23509eda3d1a4a45d55c2", - "address": "0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa", + "transactionIndex": 0, + "blockNumber": 28538515, + "transactionHash": "0x386e94a18f4869b8ded85a3b815d248553fa4aaa166dfb7e2abfb172220c329b", + "address": "0xca9F10769292F26850333264d618c1B5E91f394D", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 1, - "blockHash": "0xde0c1aa121664bb771882b7b61c67e7cec6aa5db5a2c891aa978b67b3793acac" + "logIndex": 0, + "blockHash": "0x1632e7d1ee77ceeff8dd29209df4e5ad1b9ffd67b6ed1cd2df942db4be30f842" } ], - "blockNumber": 24127446, - "cumulativeGasUsed": "1469957", + "blockNumber": 28538515, + "cumulativeGasUsed": "1265570", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 2, - "solcInputHash": "85b953b22882c536a643bf4b61b3153b", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeValidatorContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxSchedules\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"MaintenanceConfigUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"}],\"name\":\"MaintenanceScheduleCancelled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"from\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"to\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"lastUpdatedBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"requestTimestamp\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IMaintenance.Schedule\",\"name\":\"\",\"type\":\"tuple\"}],\"name\":\"MaintenanceScheduled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"ValidatorContractUpdated\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"cancelSchedule\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"checkCooldownEnds\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"checkMaintained\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_fromBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_toBlock\",\"type\":\"uint256\"}],\"name\":\"checkMaintainedInBlockRange\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"checkManyMaintained\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_resList\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_fromBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_toBlock\",\"type\":\"uint256\"}],\"name\":\"checkManyMaintainedInBlockRange\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_resList\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"checkScheduled\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"cooldownSecsToMaintain\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getSchedule\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"from\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"to\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"lastUpdatedBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"requestTimestamp\",\"type\":\"uint256\"}],\"internalType\":\"struct IMaintenance.Schedule\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxSchedules\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxMaintenanceDurationInBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxOffsetToStartSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxSchedules\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minMaintenanceDurationInBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minOffsetToStartSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_startedAtBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_endedAtBlock\",\"type\":\"uint256\"}],\"name\":\"schedule\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxSchedules\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"setMaintenanceConfig\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setValidatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalSchedules\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_count\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallerMustBeValidatorContract()\":[{\"details\":\"Error of method caller must be validator contract.\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"cancelSchedule(address)\":{\"details\":\"Cancel the schedule of maintenance for the `_consensusAddr`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - A schedule for the `_consensusAddr` must be existent and not executed yet. Emits the event `MaintenanceScheduleCancelled`.\"},\"checkCooldownEnds(address)\":{\"details\":\"Returns whether the validator `_consensusAddr`\"},\"checkMaintained(address,uint256)\":{\"details\":\"Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\"},\"checkMaintainedInBlockRange(address,uint256,uint256)\":{\"details\":\"Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\"},\"checkManyMaintained(address[],uint256)\":{\"details\":\"Returns the bool array indicating the validators maintained at block number `_block` or not.\"},\"checkManyMaintainedInBlockRange(address[],uint256,uint256)\":{\"details\":\"Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\"},\"checkScheduled(address)\":{\"details\":\"Returns whether the validator `_consensusAddr` has scheduled.\"},\"getSchedule(address)\":{\"details\":\"Returns the detailed schedule of the validator `_consensusAddr`.\"},\"initialize(address,uint256,uint256,uint256,uint256,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"schedule(address,uint256,uint256)\":{\"details\":\"Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - The candidate `_consensusAddr` has no schedule yet or the previous is done. - The total number of schedules is not larger than `maxSchedules()`. - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block. - The end block is larger than the start block. - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`. - The start block is at the start of an epoch. - The end block is at the end of an epoch. Emits the event `MaintenanceScheduled`.\"},\"setMaintenanceConfig(uint256,uint256,uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the duration restriction, start time restriction, and max allowed for maintenance. Requirements: - The method caller is admin. - The max duration is larger than the min duration. - The max offset is larger than the min offset. Emits the event `MaintenanceConfigUpdated`.\"},\"setValidatorContract(address)\":{\"details\":\"Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`.\"},\"totalSchedules()\":{\"details\":\"Returns the total of current schedules.\"},\"validatorContract()\":{\"details\":\"Returns the validator contract.\"}},\"stateVariables\":{\"_schedule\":{\"details\":\"Mapping from consensus address => maintenance schedule.\"},\"cooldownSecsToMaintain\":{\"details\":\"The cooldown time to request new schedule.\"},\"maxMaintenanceDurationInBlock\":{\"details\":\"The max duration to maintenance in blocks.\"},\"maxOffsetToStartSchedule\":{\"details\":\"The offset to the max block number that the schedule can start.\"},\"maxSchedules\":{\"details\":\"The max number of scheduled maintenances.\"},\"minMaintenanceDurationInBlock\":{\"details\":\"The min duration to maintenance in blocks.\"},\"minOffsetToStartSchedule\":{\"details\":\"The offset to the min block number that the schedule can start.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/Maintenance.sol\":\"Maintenance\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\n\\ncontract HasValidatorContract is IHasValidatorContract, HasProxyAdmin {\\n IRoninValidatorSet internal _validatorContract;\\n\\n modifier onlyValidatorContract() {\\n if (validatorContract() != msg.sender) revert ErrCallerMustBeValidatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function validatorContract() public view override returns (address) {\\n return address(_validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function setValidatorContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setValidatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function _setValidatorContract(address _addr) internal {\\n _validatorContract = IRoninValidatorSet(_addr);\\n emit ValidatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xf0a7c4c2165ede118c6ba219ee1a20d293d94049b18aa6fc86a2c48661eb654d\",\"license\":\"MIT\"},\"contracts/interfaces/IMaintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IMaintenance {\\n struct Schedule {\\n uint256 from;\\n uint256 to;\\n uint256 lastUpdatedBlock;\\n uint256 requestTimestamp;\\n }\\n\\n /// @dev Emitted when a maintenance is scheduled.\\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\\n /// @dev Emitted when a schedule of maintenance is cancelled.\\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\\n /// @dev Emitted when the maintenance config is updated.\\n event MaintenanceConfigUpdated(\\n uint256 minMaintenanceDurationInBlock,\\n uint256 maxMaintenanceDurationInBlock,\\n uint256 minOffsetToStartSchedule,\\n uint256 maxOffsetToStartSchedule,\\n uint256 maxSchedules,\\n uint256 cooldownSecsToMaintain\\n );\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool);\\n\\n /**\\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\\n */\\n function checkScheduled(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr`\\n */\\n function checkCooldownEnds(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\\n */\\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\\n\\n /**\\n * @dev Returns the total of current schedules.\\n */\\n function totalSchedules() external view returns (uint256 _count);\\n\\n /**\\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The max duration is larger than the min duration.\\n * - The max offset is larger than the min offset.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external;\\n\\n /**\\n * @dev Returns the min duration for maintenance in block.\\n */\\n function minMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max duration for maintenance in block.\\n */\\n function maxMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the min block number that the schedule can start\\n */\\n function minOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the max block number that the schedule can start\\n */\\n function maxOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max number of scheduled maintenances.\\n */\\n function maxSchedules() external view returns (uint256);\\n\\n /**\\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\\n * - The total number of schedules is not larger than `maxSchedules()`.\\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\\n * - The end block is larger than the start block.\\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\\n * - The start block is at the start of an epoch.\\n * - The end block is at the end of an epoch.\\n *\\n * Emits the event `MaintenanceScheduled`.\\n *\\n */\\n function schedule(\\n address _consensusAddr,\\n uint256 _startedAtBlock,\\n uint256 _endedAtBlock\\n ) external;\\n\\n /**\\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\\n *\\n * Emits the event `MaintenanceScheduleCancelled`.\\n */\\n function cancelSchedule(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x4f06c8f3ad7ec8b863882c655ddf443675d557272445e51d8a1e1f3454089d09\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasValidatorContract is IHasContract {\\n /// @dev Emitted when the validator contract is updated.\\n event ValidatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be validator contract.\\n error ErrCallerMustBeValidatorContract();\\n\\n /**\\n * @dev Returns the validator contract.\\n */\\n function validatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function setValidatorContract(address) external;\\n}\\n\",\"keccak256\":\"0x35a715f123b0c5dc296d13583f946bef4e485201e122b5170988a7535f114559\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(\\n uint256 c,\\n uint256 a,\\n uint256 b\\n ) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(\\n uint256 x1,\\n uint256 x2,\\n uint256 y1,\\n uint256 y2\\n ) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(\\n uint256 a,\\n uint256 b,\\n uint256 upperbound\\n ) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xf719e74bc39be7aceb4e5cc455260f81b2b21e83aa693e0b50c390c9909e08c4\",\"license\":\"UNLICENSED\"},\"contracts/ronin/Maintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../interfaces/IMaintenance.sol\\\";\\nimport \\\"../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../extensions/collections/HasValidatorContract.sol\\\";\\nimport \\\"../libraries/Math.sol\\\";\\n\\ncontract Maintenance is IMaintenance, HasValidatorContract, Initializable {\\n using Math for uint256;\\n\\n /// @dev Mapping from consensus address => maintenance schedule.\\n mapping(address => Schedule) internal _schedule;\\n\\n /// @dev The min duration to maintenance in blocks.\\n uint256 public minMaintenanceDurationInBlock;\\n /// @dev The max duration to maintenance in blocks.\\n uint256 public maxMaintenanceDurationInBlock;\\n /// @dev The offset to the min block number that the schedule can start.\\n uint256 public minOffsetToStartSchedule;\\n /// @dev The offset to the max block number that the schedule can start.\\n uint256 public maxOffsetToStartSchedule;\\n /// @dev The max number of scheduled maintenances.\\n uint256 public maxSchedules;\\n /// @dev The cooldown time to request new schedule.\\n uint256 public cooldownSecsToMaintain;\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external initializer {\\n _setValidatorContract(__validatorContract);\\n _setMaintenanceConfig(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedules,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external onlyAdmin {\\n _setMaintenanceConfig(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedules,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function schedule(\\n address _consensusAddr,\\n uint256 _startedAtBlock,\\n uint256 _endedAtBlock\\n ) external override {\\n IRoninValidatorSet _validator = _validatorContract;\\n\\n require(_validator.isBlockProducer(_consensusAddr), \\\"Maintenance: consensus address must be a block producer\\\");\\n require(\\n _validator.isCandidateAdmin(_consensusAddr, msg.sender),\\n \\\"Maintenance: method caller must be a candidate admin\\\"\\n );\\n require(!checkScheduled(_consensusAddr), \\\"Maintenance: already scheduled\\\");\\n require(checkCooldownEnds(_consensusAddr), \\\"Maintainance: cooldown time not end\\\");\\n require(totalSchedules() < maxSchedules, \\\"Maintenance: exceeds total of schedules\\\");\\n require(\\n _startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule),\\n \\\"Maintenance: start block is out of offset\\\"\\n );\\n require(_startedAtBlock < _endedAtBlock, \\\"Maintenance: start block must be less than end block\\\");\\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\\n require(\\n _maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock),\\n \\\"Maintenance: invalid maintenance duration\\\"\\n );\\n require(_validator.epochEndingAt(_startedAtBlock - 1), \\\"Maintenance: start block is not at the start of an epoch\\\");\\n require(_validator.epochEndingAt(_endedAtBlock), \\\"Maintenance: end block is not at the end of an epoch\\\");\\n\\n Schedule storage _sSchedule = _schedule[_consensusAddr];\\n _sSchedule.from = _startedAtBlock;\\n _sSchedule.to = _endedAtBlock;\\n _sSchedule.lastUpdatedBlock = block.number;\\n _sSchedule.requestTimestamp = block.timestamp;\\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function cancelSchedule(address _consensusAddr) external override {\\n require(\\n _validatorContract.isCandidateAdmin(_consensusAddr, msg.sender),\\n \\\"Maintenance: method caller must be the candidate admin\\\"\\n );\\n require(checkScheduled(_consensusAddr), \\\"Maintenance: no schedule exists\\\");\\n require(!checkMaintained(_consensusAddr, block.number), \\\"Maintenance: already on maintenance\\\");\\n Schedule storage _sSchedule = _schedule[_consensusAddr];\\n delete _sSchedule.from;\\n delete _sSchedule.to;\\n _sSchedule.lastUpdatedBlock = block.number;\\n emit MaintenanceScheduleCancelled(_consensusAddr);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\\n return _schedule[_consensusAddr];\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block)\\n external\\n view\\n override\\n returns (bool[] memory _resList)\\n {\\n _resList = new bool[](_addrList.length);\\n for (uint _i = 0; _i < _addrList.length; _i++) {\\n _resList[_i] = checkMaintained(_addrList[_i], _block);\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view override returns (bool[] memory _resList) {\\n _resList = new bool[](_addrList.length);\\n for (uint _i = 0; _i < _addrList.length; _i++) {\\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function totalSchedules() public view override returns (uint256 _count) {\\n (address[] memory _validators, , ) = _validatorContract.getValidators();\\n for (uint _i = 0; _i < _validators.length; _i++) {\\n if (checkScheduled(_validators[_i])) {\\n _count++;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\\n Schedule storage _s = _schedule[_consensusAddr];\\n return _s.from <= _block && _block <= _s.to;\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) public view override returns (bool) {\\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\\n return block.number <= _schedule[_consensusAddr].to;\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkCooldownEnds(address _consensusAddr) public view override returns (bool) {\\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\\n }\\n\\n /**\\n * @dev Sets the min block period and max block period to maintenance.\\n *\\n * Requirements:\\n * - The max period is larger than the min period.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function _setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) internal {\\n require(\\n _minMaintenanceDurationInBlock < _maxMaintenanceDurationInBlock,\\n \\\"Maintenance: invalid maintenance duration configs\\\"\\n );\\n require(\\n _minOffsetToStartSchedule < _maxOffsetToStartSchedule,\\n \\\"Maintenance: invalid offset to start schedule configs\\\"\\n );\\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\\n maxSchedules = _maxSchedules;\\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\\n emit MaintenanceConfigUpdated(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedules,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n /**\\n * @dev Check if the validator was maintaining in the current period.\\n *\\n * Note: This method should be called at the end of the period.\\n */\\n function _maintainingInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) private view returns (bool) {\\n Schedule storage _s = _schedule[_consensusAddr];\\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\\n }\\n}\\n\",\"keccak256\":\"0xc7fc2e02a52063b981007e05eeb4db953b2e35fe4a6497f351a6e86dc38878c2\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600054600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff600160a01b909104811610156100e9576000805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61180e806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100fc5760003560e01c8063088e8de71461010157806309e34c38146101295780630fbeb37f146101405780632d538c2c146101535780632ddc08a2146101685780637a50802d1461017b5780638142951a14610184578063965720af14610197578063994390891461019f578063b59f403e146101b8578063ba303755146101cb578063bc1710e9146101eb578063bfa89b9b146101f4578063c09fe460146101fd578063c44cb23314610210578063cdf64a7614610219578063d39fee341461022c578063dec3628414610272578063f0caaafb1461027b578063fdadda811461028e575b600080fd5b61011461010f36600461128a565b6102a1565b60405190151581526020015b60405180910390f35b61013260025481565b604051908152602001610120565b61011461014e3660046112bf565b6102b6565b61016661016136600461128a565b6102ed565b005b6101146101763660046112eb565b61095f565b61013260055481565b61016661019236600461130f565b610981565b610132610ac3565b6000546001600160a01b03166040516101209190611364565b6101146101c63660046112eb565b610b90565b6101de6101d93660046113c3565b610bc2565b6040516101209190611413565b61013260045481565b61013260035481565b61016661020b366004611459565b610c81565b61013260065481565b6101666102273660046112eb565b610ccf565b61023f61023a3660046112eb565b610d3e565b60405161012091908151815260208083015190820152604080830151908201526060918201519181019190915260800190565b61013260075481565b6101666102893660046112eb565b610db6565b6101de61029c36600461149c565b610f8f565b60006102ae84848461104c565b949350505050565b6001600160a01b0382166000908152600160205260408120805483108015906102e3575080600101548311155b9150505b92915050565b600054604051633292276760e11b81526001600160a01b039091169081906365244ece9061031f908790600401611364565b602060405180830381865afa15801561033c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061036091906114e7565b6103d15760405162461bcd60e51b815260206004820152603760248201527f4d61696e74656e616e63653a20636f6e73656e7375732061646472657373206d6044820152763ab9ba103132903090313637b1b590383937b23ab1b2b960491b60648201526084015b60405180910390fd5b6040516304d971ab60e01b81526001600160a01b038216906304d971ab906103ff9087903390600401611509565b602060405180830381865afa15801561041c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061044091906114e7565b6104975760405162461bcd60e51b81526020600482015260346024820152600080516020611799833981519152604482015273313290309031b0b73234b230ba329030b236b4b760611b60648201526084016103c8565b6104a08461095f565b156104ed5760405162461bcd60e51b815260206004820152601e60248201527f4d61696e74656e616e63653a20616c7265616479207363686564756c6564000060448201526064016103c8565b6104f684610b90565b61054e5760405162461bcd60e51b815260206004820152602360248201527f4d61696e7461696e616e63653a20636f6f6c646f776e2074696d65206e6f7420604482015262195b9960ea1b60648201526084016103c8565b600654610559610ac3565b106105b65760405162461bcd60e51b815260206004820152602760248201527f4d61696e74656e616e63653a206578636565647320746f74616c206f66207363604482015266686564756c657360c81b60648201526084016103c8565b6105dc600454436105c79190611539565b6005546105d49043611539565b859190611084565b61063a5760405162461bcd60e51b815260206004820152602960248201527f4d61696e74656e616e63653a20737461727420626c6f636b206973206f7574206044820152681bd9881bd9999cd95d60ba1b60648201526084016103c8565b8183106106a65760405162461bcd60e51b815260206004820152603460248201527f4d61696e74656e616e63653a20737461727420626c6f636b206d757374206265604482015273206c657373207468616e20656e6420626c6f636b60601b60648201526084016103c8565b60006106b2848461154c565b6106bd906001611539565b90506106d8600254600354836110849092919063ffffffff16565b6107245760405162461bcd60e51b815260206004820152602960248201526000805160206117b983398151915260448201526810323ab930ba34b7b760b91b60648201526084016103c8565b6001600160a01b038216637593ff7161073e60018761154c565b6040518263ffffffff1660e01b815260040161075c91815260200190565b602060405180830381865afa158015610779573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061079d91906114e7565b61080a5760405162461bcd60e51b815260206004820152603860248201527f4d61696e74656e616e63653a20737461727420626c6f636b206973206e6f74206044820152770c2e840e8d0ca40e6e8c2e4e840decc40c2dc40cae0dec6d60431b60648201526084016103c8565b604051637593ff7160e01b8152600481018490526001600160a01b03831690637593ff7190602401602060405180830381865afa15801561084f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061087391906114e7565b6108dc5760405162461bcd60e51b815260206004820152603460248201527f4d61696e74656e616e63653a20656e6420626c6f636b206973206e6f74206174604482015273040e8d0ca40cadcc840decc40c2dc40cae0dec6d60631b60648201526084016103c8565b6001600160a01b0385166000818152600160208181526040928390208881559182018790554360028301819055426003840181905584518a815292830189905293820152606081019290925291907f48e8b2f7348b1ec693bbb999258a8d6bd514732a19c6057b6e2a56a4c405253b9060800160405180910390a2505050505050565b6001600160a01b03166000908152600160208190526040909120015443111590565b600054600160a81b900460ff16158080156109a957506000546001600160a01b90910460ff16105b806109ca5750303b1580156109ca5750600054600160a01b900460ff166001145b610a2d5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016103c8565b6000805460ff60a01b1916600160a01b1790558015610a5a576000805460ff60a81b1916600160a81b1790555b610a638861109b565b610a718787878787876110f1565b8015610ab9576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050565b600080546040805163b7ab4db560e01b8152905183926001600160a01b03169163b7ab4db591600480830192869291908290030181865afa158015610b0c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610b34919081019061163c565b5050905060005b8151811015610b8b57610b66828281518110610b5957610b59611727565b602002602001015161095f565b15610b795782610b758161173d565b9350505b80610b838161173d565b915050610b3b565b505090565b6007546001600160a01b0382166000908152600160205260408120600301549091610bba91611539565b421192915050565b6060836001600160401b03811115610bdc57610bdc61155f565b604051908082528060200260200182016040528015610c05578160200160208202803683370190505b50905060005b84811015610c7857610c44868683818110610c2857610c28611727565b9050602002016020810190610c3d91906112eb565b858561104c565b828281518110610c5657610c56611727565b9115156020928302919091019091015280610c708161173d565b915050610c0b565b50949350505050565b610c89611231565b6001600160a01b0316336001600160a01b031614610cb95760405162461bcd60e51b81526004016103c890611756565b610cc78686868686866110f1565b505050505050565b610cd7611231565b6001600160a01b0316336001600160a01b031614610d075760405162461bcd60e51b81526004016103c890611756565b806001600160a01b03163b600003610d3257604051637bcd509160e01b815260040160405180910390fd5b610d3b8161109b565b50565b610d696040518060800160405280600081526020016000815260200160008152602001600081525090565b506001600160a01b03166000908152600160208181526040928390208351608081018552815481529281015491830191909152600281015492820192909252600390910154606082015290565b6000546040516304d971ab60e01b81526001600160a01b03909116906304d971ab90610de89084903390600401611509565b602060405180830381865afa158015610e05573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e2991906114e7565b610e825760405162461bcd60e51b815260206004820152603660248201526000805160206117998339815191526044820152753132903a34329031b0b73234b230ba329030b236b4b760511b60648201526084016103c8565b610e8b8161095f565b610ed75760405162461bcd60e51b815260206004820152601f60248201527f4d61696e74656e616e63653a206e6f207363686564756c65206578697374730060448201526064016103c8565b610ee181436102b6565b15610f3a5760405162461bcd60e51b815260206004820152602360248201527f4d61696e74656e616e63653a20616c7265616479206f6e206d61696e74656e616044820152626e636560e81b60648201526084016103c8565b6001600160a01b0381166000818152600160208190526040808320838155918201839055436002830155519092917f72720a31deb222f77bbf95b88a540154648466770e5f41328ee1e25e5050737791a25050565b6060826001600160401b03811115610fa957610fa961155f565b604051908082528060200260200182016040528015610fd2578160200160208202803683370190505b50905060005b8381101561104457611010858583818110610ff557610ff5611727565b905060200201602081019061100a91906112eb565b846102b6565b82828151811061102257611022611727565b911515602092830291909101909101528061103c8161173d565b915050610fd8565b509392505050565b6001600160a01b03831660009081526001602081905260408220805491810154909161107b918691869161125f565b95945050505050565b60008383111580156102ae57505090911115919050565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169906110e6908390611364565b60405180910390a150565b8486106111485760405162461bcd60e51b815260206004820152603160248201526000805160206117b9833981519152604482015270206475726174696f6e20636f6e6669677360781b60648201526084016103c8565b8284106111b55760405162461bcd60e51b815260206004820152603560248201527f4d61696e74656e616e63653a20696e76616c6964206f666673657420746f207360448201527474617274207363686564756c6520636f6e6669677360581b60648201526084016103c8565b6002869055600385905560048490556005839055600682905560078190556040805187815260208101879052908101859052606081018490526080810183905260a081018290527f4edb6adef66a4b8e1ffbc8c67640d4f244ce904193fd65e5cc316bbb74b2e59b9060c00160405180910390a1505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600081851115801561107b575050501115919050565b6001600160a01b0381168114610d3b57600080fd5b60008060006060848603121561129f57600080fd5b83356112aa81611275565b95602085013595506040909401359392505050565b600080604083850312156112d257600080fd5b82356112dd81611275565b946020939093013593505050565b6000602082840312156112fd57600080fd5b813561130881611275565b9392505050565b600080600080600080600060e0888a03121561132a57600080fd5b873561133581611275565b9960208901359950604089013598606081013598506080810135975060a0810135965060c00135945092505050565b6001600160a01b0391909116815260200190565b60008083601f84011261138a57600080fd5b5081356001600160401b038111156113a157600080fd5b6020830191508360208260051b85010111156113bc57600080fd5b9250929050565b600080600080606085870312156113d957600080fd5b84356001600160401b038111156113ef57600080fd5b6113fb87828801611378565b90989097506020870135966040013595509350505050565b6020808252825182820181905260009190848201906040850190845b8181101561144d57835115158352928401929184019160010161142f565b50909695505050505050565b60008060008060008060c0878903121561147257600080fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b6000806000604084860312156114b157600080fd5b83356001600160401b038111156114c757600080fd5b6114d386828701611378565b909790965060209590950135949350505050565b6000602082840312156114f957600080fd5b8151801515811461130857600080fd5b6001600160a01b0392831681529116602082015260400190565b634e487b7160e01b600052601160045260246000fd5b808201808211156102e7576102e7611523565b818103818111156102e7576102e7611523565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b038111828210171561159d5761159d61155f565b604052919050565b60006001600160401b038211156115be576115be61155f565b5060051b60200190565b600082601f8301126115d957600080fd5b815160206115ee6115e9836115a5565b611575565b82815260059290921b8401810191818101908684111561160d57600080fd5b8286015b8481101561163157805161162481611275565b8352918301918301611611565b509695505050505050565b60008060006060848603121561165157600080fd5b83516001600160401b038082111561166857600080fd5b611674878388016115c8565b945060209150818601518181111561168b57600080fd5b611697888289016115c8565b9450506040860151818111156116ac57600080fd5b86019050601f810187136116bf57600080fd5b80516116cd6115e9826115a5565b81815260059190911b820183019083810190898311156116ec57600080fd5b928401925b82841015611718578351600481106117095760008081fd5b825292840192908401906116f1565b80955050505050509250925092565b634e487b7160e01b600052603260045260246000fd5b60006001820161174f5761174f611523565b5060010190565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b60608201526080019056fe4d61696e74656e616e63653a206d6574686f642063616c6c6572206d757374204d61696e74656e616e63653a20696e76616c6964206d61696e74656e616e6365a264697066735822122020d6e85a401c7371df2c8089f2290dbc1b507fb37b62e12da5f11aacfead033d64736f6c63430008110033", - "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100fc5760003560e01c8063088e8de71461010157806309e34c38146101295780630fbeb37f146101405780632d538c2c146101535780632ddc08a2146101685780637a50802d1461017b5780638142951a14610184578063965720af14610197578063994390891461019f578063b59f403e146101b8578063ba303755146101cb578063bc1710e9146101eb578063bfa89b9b146101f4578063c09fe460146101fd578063c44cb23314610210578063cdf64a7614610219578063d39fee341461022c578063dec3628414610272578063f0caaafb1461027b578063fdadda811461028e575b600080fd5b61011461010f36600461128a565b6102a1565b60405190151581526020015b60405180910390f35b61013260025481565b604051908152602001610120565b61011461014e3660046112bf565b6102b6565b61016661016136600461128a565b6102ed565b005b6101146101763660046112eb565b61095f565b61013260055481565b61016661019236600461130f565b610981565b610132610ac3565b6000546001600160a01b03166040516101209190611364565b6101146101c63660046112eb565b610b90565b6101de6101d93660046113c3565b610bc2565b6040516101209190611413565b61013260045481565b61013260035481565b61016661020b366004611459565b610c81565b61013260065481565b6101666102273660046112eb565b610ccf565b61023f61023a3660046112eb565b610d3e565b60405161012091908151815260208083015190820152604080830151908201526060918201519181019190915260800190565b61013260075481565b6101666102893660046112eb565b610db6565b6101de61029c36600461149c565b610f8f565b60006102ae84848461104c565b949350505050565b6001600160a01b0382166000908152600160205260408120805483108015906102e3575080600101548311155b9150505b92915050565b600054604051633292276760e11b81526001600160a01b039091169081906365244ece9061031f908790600401611364565b602060405180830381865afa15801561033c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061036091906114e7565b6103d15760405162461bcd60e51b815260206004820152603760248201527f4d61696e74656e616e63653a20636f6e73656e7375732061646472657373206d6044820152763ab9ba103132903090313637b1b590383937b23ab1b2b960491b60648201526084015b60405180910390fd5b6040516304d971ab60e01b81526001600160a01b038216906304d971ab906103ff9087903390600401611509565b602060405180830381865afa15801561041c573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061044091906114e7565b6104975760405162461bcd60e51b81526020600482015260346024820152600080516020611799833981519152604482015273313290309031b0b73234b230ba329030b236b4b760611b60648201526084016103c8565b6104a08461095f565b156104ed5760405162461bcd60e51b815260206004820152601e60248201527f4d61696e74656e616e63653a20616c7265616479207363686564756c6564000060448201526064016103c8565b6104f684610b90565b61054e5760405162461bcd60e51b815260206004820152602360248201527f4d61696e7461696e616e63653a20636f6f6c646f776e2074696d65206e6f7420604482015262195b9960ea1b60648201526084016103c8565b600654610559610ac3565b106105b65760405162461bcd60e51b815260206004820152602760248201527f4d61696e74656e616e63653a206578636565647320746f74616c206f66207363604482015266686564756c657360c81b60648201526084016103c8565b6105dc600454436105c79190611539565b6005546105d49043611539565b859190611084565b61063a5760405162461bcd60e51b815260206004820152602960248201527f4d61696e74656e616e63653a20737461727420626c6f636b206973206f7574206044820152681bd9881bd9999cd95d60ba1b60648201526084016103c8565b8183106106a65760405162461bcd60e51b815260206004820152603460248201527f4d61696e74656e616e63653a20737461727420626c6f636b206d757374206265604482015273206c657373207468616e20656e6420626c6f636b60601b60648201526084016103c8565b60006106b2848461154c565b6106bd906001611539565b90506106d8600254600354836110849092919063ffffffff16565b6107245760405162461bcd60e51b815260206004820152602960248201526000805160206117b983398151915260448201526810323ab930ba34b7b760b91b60648201526084016103c8565b6001600160a01b038216637593ff7161073e60018761154c565b6040518263ffffffff1660e01b815260040161075c91815260200190565b602060405180830381865afa158015610779573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061079d91906114e7565b61080a5760405162461bcd60e51b815260206004820152603860248201527f4d61696e74656e616e63653a20737461727420626c6f636b206973206e6f74206044820152770c2e840e8d0ca40e6e8c2e4e840decc40c2dc40cae0dec6d60431b60648201526084016103c8565b604051637593ff7160e01b8152600481018490526001600160a01b03831690637593ff7190602401602060405180830381865afa15801561084f573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061087391906114e7565b6108dc5760405162461bcd60e51b815260206004820152603460248201527f4d61696e74656e616e63653a20656e6420626c6f636b206973206e6f74206174604482015273040e8d0ca40cadcc840decc40c2dc40cae0dec6d60631b60648201526084016103c8565b6001600160a01b0385166000818152600160208181526040928390208881559182018790554360028301819055426003840181905584518a815292830189905293820152606081019290925291907f48e8b2f7348b1ec693bbb999258a8d6bd514732a19c6057b6e2a56a4c405253b9060800160405180910390a2505050505050565b6001600160a01b03166000908152600160208190526040909120015443111590565b600054600160a81b900460ff16158080156109a957506000546001600160a01b90910460ff16105b806109ca5750303b1580156109ca5750600054600160a01b900460ff166001145b610a2d5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084016103c8565b6000805460ff60a01b1916600160a01b1790558015610a5a576000805460ff60a81b1916600160a81b1790555b610a638861109b565b610a718787878787876110f1565b8015610ab9576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050565b600080546040805163b7ab4db560e01b8152905183926001600160a01b03169163b7ab4db591600480830192869291908290030181865afa158015610b0c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610b34919081019061163c565b5050905060005b8151811015610b8b57610b66828281518110610b5957610b59611727565b602002602001015161095f565b15610b795782610b758161173d565b9350505b80610b838161173d565b915050610b3b565b505090565b6007546001600160a01b0382166000908152600160205260408120600301549091610bba91611539565b421192915050565b6060836001600160401b03811115610bdc57610bdc61155f565b604051908082528060200260200182016040528015610c05578160200160208202803683370190505b50905060005b84811015610c7857610c44868683818110610c2857610c28611727565b9050602002016020810190610c3d91906112eb565b858561104c565b828281518110610c5657610c56611727565b9115156020928302919091019091015280610c708161173d565b915050610c0b565b50949350505050565b610c89611231565b6001600160a01b0316336001600160a01b031614610cb95760405162461bcd60e51b81526004016103c890611756565b610cc78686868686866110f1565b505050505050565b610cd7611231565b6001600160a01b0316336001600160a01b031614610d075760405162461bcd60e51b81526004016103c890611756565b806001600160a01b03163b600003610d3257604051637bcd509160e01b815260040160405180910390fd5b610d3b8161109b565b50565b610d696040518060800160405280600081526020016000815260200160008152602001600081525090565b506001600160a01b03166000908152600160208181526040928390208351608081018552815481529281015491830191909152600281015492820192909252600390910154606082015290565b6000546040516304d971ab60e01b81526001600160a01b03909116906304d971ab90610de89084903390600401611509565b602060405180830381865afa158015610e05573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e2991906114e7565b610e825760405162461bcd60e51b815260206004820152603660248201526000805160206117998339815191526044820152753132903a34329031b0b73234b230ba329030b236b4b760511b60648201526084016103c8565b610e8b8161095f565b610ed75760405162461bcd60e51b815260206004820152601f60248201527f4d61696e74656e616e63653a206e6f207363686564756c65206578697374730060448201526064016103c8565b610ee181436102b6565b15610f3a5760405162461bcd60e51b815260206004820152602360248201527f4d61696e74656e616e63653a20616c7265616479206f6e206d61696e74656e616044820152626e636560e81b60648201526084016103c8565b6001600160a01b0381166000818152600160208190526040808320838155918201839055436002830155519092917f72720a31deb222f77bbf95b88a540154648466770e5f41328ee1e25e5050737791a25050565b6060826001600160401b03811115610fa957610fa961155f565b604051908082528060200260200182016040528015610fd2578160200160208202803683370190505b50905060005b8381101561104457611010858583818110610ff557610ff5611727565b905060200201602081019061100a91906112eb565b846102b6565b82828151811061102257611022611727565b911515602092830291909101909101528061103c8161173d565b915050610fd8565b509392505050565b6001600160a01b03831660009081526001602081905260408220805491810154909161107b918691869161125f565b95945050505050565b60008383111580156102ae57505090911115919050565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169906110e6908390611364565b60405180910390a150565b8486106111485760405162461bcd60e51b815260206004820152603160248201526000805160206117b9833981519152604482015270206475726174696f6e20636f6e6669677360781b60648201526084016103c8565b8284106111b55760405162461bcd60e51b815260206004820152603560248201527f4d61696e74656e616e63653a20696e76616c6964206f666673657420746f207360448201527474617274207363686564756c6520636f6e6669677360581b60648201526084016103c8565b6002869055600385905560048490556005839055600682905560078190556040805187815260208101879052908101859052606081018490526080810183905260a081018290527f4edb6adef66a4b8e1ffbc8c67640d4f244ce904193fd65e5cc316bbb74b2e59b9060c00160405180910390a1505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600081851115801561107b575050501115919050565b6001600160a01b0381168114610d3b57600080fd5b60008060006060848603121561129f57600080fd5b83356112aa81611275565b95602085013595506040909401359392505050565b600080604083850312156112d257600080fd5b82356112dd81611275565b946020939093013593505050565b6000602082840312156112fd57600080fd5b813561130881611275565b9392505050565b600080600080600080600060e0888a03121561132a57600080fd5b873561133581611275565b9960208901359950604089013598606081013598506080810135975060a0810135965060c00135945092505050565b6001600160a01b0391909116815260200190565b60008083601f84011261138a57600080fd5b5081356001600160401b038111156113a157600080fd5b6020830191508360208260051b85010111156113bc57600080fd5b9250929050565b600080600080606085870312156113d957600080fd5b84356001600160401b038111156113ef57600080fd5b6113fb87828801611378565b90989097506020870135966040013595509350505050565b6020808252825182820181905260009190848201906040850190845b8181101561144d57835115158352928401929184019160010161142f565b50909695505050505050565b60008060008060008060c0878903121561147257600080fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b6000806000604084860312156114b157600080fd5b83356001600160401b038111156114c757600080fd5b6114d386828701611378565b909790965060209590950135949350505050565b6000602082840312156114f957600080fd5b8151801515811461130857600080fd5b6001600160a01b0392831681529116602082015260400190565b634e487b7160e01b600052601160045260246000fd5b808201808211156102e7576102e7611523565b818103818111156102e7576102e7611523565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b038111828210171561159d5761159d61155f565b604052919050565b60006001600160401b038211156115be576115be61155f565b5060051b60200190565b600082601f8301126115d957600080fd5b815160206115ee6115e9836115a5565b611575565b82815260059290921b8401810191818101908684111561160d57600080fd5b8286015b8481101561163157805161162481611275565b8352918301918301611611565b509695505050505050565b60008060006060848603121561165157600080fd5b83516001600160401b038082111561166857600080fd5b611674878388016115c8565b945060209150818601518181111561168b57600080fd5b611697888289016115c8565b9450506040860151818111156116ac57600080fd5b86019050601f810187136116bf57600080fd5b80516116cd6115e9826115a5565b81815260059190911b820183019083810190898311156116ec57600080fd5b928401925b82841015611718578351600481106117095760008081fd5b825292840192908401906116f1565b80955050505050509250925092565b634e487b7160e01b600052603260045260246000fd5b60006001820161174f5761174f611523565b5060010190565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b60608201526080019056fe4d61696e74656e616e63653a206d6574686f642063616c6c6572206d757374204d61696e74656e616e63653a20696e76616c6964206d61696e74656e616e6365a264697066735822122020d6e85a401c7371df2c8089f2290dbc1b507fb37b62e12da5f11aacfead033d64736f6c63430008110033", + "numDeployments": 3, + "solcInputHash": "0e13282b1de32a862f3ea9c3dc0543e9", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrAlreadyOnMaintenance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyScheduled\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCooldownTimeNotYetEnded\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrEndBlockOutOfRange\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMaintenanceDuration\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMaintenanceDurationConfig\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidOffsetToStartScheduleConfigs\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrStartBlockOutOfRange\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrTotalOfSchedulesExceeded\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnexistedSchedule\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxSchedules\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"MaintenanceConfigUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"}],\"name\":\"MaintenanceScheduleCancelled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"from\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"to\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"lastUpdatedBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"requestTimestamp\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IMaintenance.Schedule\",\"name\":\"\",\"type\":\"tuple\"}],\"name\":\"MaintenanceScheduled\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"cancelSchedule\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"checkCooldownEnded\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"checkMaintained\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_fromBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_toBlock\",\"type\":\"uint256\"}],\"name\":\"checkMaintainedInBlockRange\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"checkManyMaintained\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_resList\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_fromBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_toBlock\",\"type\":\"uint256\"}],\"name\":\"checkManyMaintainedInBlockRange\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_resList\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"checkScheduled\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"cooldownSecsToMaintain\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getSchedule\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"from\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"to\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"lastUpdatedBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"requestTimestamp\",\"type\":\"uint256\"}],\"internalType\":\"struct IMaintenance.Schedule\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxSchedules\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxMaintenanceDurationInBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxOffsetToStartSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minMaintenanceDurationInBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minOffsetToStartSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_startedAtBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_endedAtBlock\",\"type\":\"uint256\"}],\"name\":\"schedule\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_minMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxMaintenanceDurationInBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_minOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxOffsetToStartSchedule\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxSchedules\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cooldownSecsToMaintain\",\"type\":\"uint256\"}],\"name\":\"setMaintenanceConfig\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalSchedule\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_count\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrAlreadyOnMaintenance()\":[{\"details\":\"Error thrown when attempting to initiate maintenance while already in maintenance mode.\"}],\"ErrAlreadyScheduled()\":[{\"details\":\"Error thrown when attempting to schedule an already scheduled event.\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrCooldownTimeNotYetEnded()\":[{\"details\":\"Error thrown when attempting an action before the cooldown period has ended.\"}],\"ErrEndBlockOutOfRange()\":[{\"details\":\"Error thrown when the end block of a schedule is out of range.\"}],\"ErrInvalidMaintenanceDuration()\":[{\"details\":\"Error thrown when an invalid maintenance duration is specified.\"}],\"ErrInvalidMaintenanceDurationConfig()\":[{\"details\":\"Error thrown when an invalid maintenance duration configuration is provided.\"}],\"ErrInvalidOffsetToStartScheduleConfigs()\":[{\"details\":\"Error thrown when an invalid offset is specified to start the schedule configurations.\"}],\"ErrStartBlockOutOfRange()\":[{\"details\":\"Error thrown when the start block of a schedule is out of range.\"}],\"ErrTotalOfSchedulesExceeded()\":[{\"details\":\"Error thrown when the total number of schedules exceeds the limit.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexistedSchedule()\":[{\"details\":\"Error thrown when referring to a non-existent schedule.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"cancelSchedule(address)\":{\"details\":\"Cancel the schedule of maintenance for the `_consensusAddr`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - A schedule for the `_consensusAddr` must be existent and not executed yet. Emits the event `MaintenanceScheduleCancelled`.\"},\"checkCooldownEnded(address)\":{\"details\":\"Returns whether the validator `_consensusAddr`\"},\"checkMaintained(address,uint256)\":{\"details\":\"Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\"},\"checkMaintainedInBlockRange(address,uint256,uint256)\":{\"details\":\"Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\"},\"checkManyMaintained(address[],uint256)\":{\"details\":\"Returns the bool array indicating the validators maintained at block number `_block` or not.\"},\"checkManyMaintainedInBlockRange(address[],uint256,uint256)\":{\"details\":\"Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\"},\"checkScheduled(address)\":{\"details\":\"Returns whether the validator `_consensusAddr` has scheduled.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getSchedule(address)\":{\"details\":\"Returns the detailed schedule of the validator `_consensusAddr`.\"},\"initialize(address,uint256,uint256,uint256,uint256,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"schedule(address,uint256,uint256)\":{\"details\":\"Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - The candidate `_consensusAddr` has no schedule yet or the previous is done. - The total number of schedules is not larger than `maxSchedules()`. - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block. - The end block is larger than the start block. - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`. - The start block is at the start of an epoch. - The end block is at the end of an epoch. Emits the event `MaintenanceScheduled`.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setMaintenanceConfig(uint256,uint256,uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the duration restriction, start time restriction, and max allowed for maintenance. Requirements: - The method caller is admin. - The max duration is larger than the min duration. - The max offset is larger than the min offset. Emits the event `MaintenanceConfigUpdated`.\"},\"totalSchedule()\":{\"details\":\"Returns the total of current schedules.\"}},\"stateVariables\":{\"_schedule\":{\"details\":\"Mapping from consensus address => maintenance schedule.\"},\"cooldownSecsToMaintain\":{\"details\":\"The cooldown time to request new schedule.\"},\"maxMaintenanceDurationInBlock\":{\"details\":\"The max duration to maintenance in blocks.\"},\"maxOffsetToStartSchedule\":{\"details\":\"The offset to the max block number that the schedule can start.\"},\"maxSchedule\":{\"details\":\"The max number of scheduled maintenances.\"},\"minMaintenanceDurationInBlock\":{\"details\":\"The min duration to maintenance in blocks.\"},\"minOffsetToStartSchedule\":{\"details\":\"The offset to the min block number that the schedule can start.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/Maintenance.sol\":\"Maintenance\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IMaintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IMaintenance {\\n /**\\n * @dev Error thrown when attempting to schedule an already scheduled event.\\n */\\n error ErrAlreadyScheduled();\\n\\n /**\\n * @dev Error thrown when referring to a non-existent schedule.\\n */\\n error ErrUnexistedSchedule();\\n\\n /**\\n * @dev Error thrown when the end block of a schedule is out of range.\\n */\\n error ErrEndBlockOutOfRange();\\n\\n /**\\n * @dev Error thrown when the start block of a schedule is out of range.\\n */\\n error ErrStartBlockOutOfRange();\\n\\n /**\\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\\n */\\n error ErrAlreadyOnMaintenance();\\n\\n /**\\n * @dev Error thrown when attempting an action before the cooldown period has ended.\\n */\\n error ErrCooldownTimeNotYetEnded();\\n\\n /**\\n * @dev Error thrown when the total number of schedules exceeds the limit.\\n */\\n error ErrTotalOfSchedulesExceeded();\\n\\n /**\\n * @dev Error thrown when an invalid maintenance duration is specified.\\n */\\n error ErrInvalidMaintenanceDuration();\\n\\n /**\\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\\n */\\n error ErrInvalidMaintenanceDurationConfig();\\n\\n /**\\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\\n */\\n error ErrInvalidOffsetToStartScheduleConfigs();\\n\\n struct Schedule {\\n uint256 from;\\n uint256 to;\\n uint256 lastUpdatedBlock;\\n uint256 requestTimestamp;\\n }\\n\\n /// @dev Emitted when a maintenance is scheduled.\\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\\n /// @dev Emitted when a schedule of maintenance is cancelled.\\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\\n /// @dev Emitted when the maintenance config is updated.\\n event MaintenanceConfigUpdated(\\n uint256 minMaintenanceDurationInBlock,\\n uint256 maxMaintenanceDurationInBlock,\\n uint256 minOffsetToStartSchedule,\\n uint256 maxOffsetToStartSchedule,\\n uint256 maxSchedules,\\n uint256 cooldownSecsToMaintain\\n );\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool);\\n\\n /**\\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\\n */\\n function checkScheduled(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr`\\n */\\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\\n */\\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\\n\\n /**\\n * @dev Returns the total of current schedules.\\n */\\n function totalSchedule() external view returns (uint256 _count);\\n\\n /**\\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The max duration is larger than the min duration.\\n * - The max offset is larger than the min offset.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external;\\n\\n /**\\n * @dev Returns the min duration for maintenance in block.\\n */\\n function minMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max duration for maintenance in block.\\n */\\n function maxMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the min block number that the schedule can start\\n */\\n function minOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the max block number that the schedule can start\\n */\\n function maxOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max number of scheduled maintenances.\\n */\\n function maxSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\\n * - The total number of schedules is not larger than `maxSchedules()`.\\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\\n * - The end block is larger than the start block.\\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\\n * - The start block is at the start of an epoch.\\n * - The end block is at the end of an epoch.\\n *\\n * Emits the event `MaintenanceScheduled`.\\n *\\n */\\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\\n\\n /**\\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\\n *\\n * Emits the event `MaintenanceScheduleCancelled`.\\n */\\n function cancelSchedule(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0xe30d31be54b9f9044c6a5d1393f04f9093d619a705d00276359853a086a91e8a\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\"},\"contracts/ronin/Maintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../interfaces/IMaintenance.sol\\\";\\nimport \\\"../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../libraries/Math.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../utils/DeprecatedSlots.sol\\\";\\nimport { ErrUnauthorized, RoleAccess } from \\\"../utils/CommonErrors.sol\\\";\\n\\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\\n using Math for uint256;\\n\\n /// @dev Mapping from consensus address => maintenance schedule.\\n mapping(address => Schedule) internal _schedule;\\n\\n /// @dev The min duration to maintenance in blocks.\\n uint256 public minMaintenanceDurationInBlock;\\n /// @dev The max duration to maintenance in blocks.\\n uint256 public maxMaintenanceDurationInBlock;\\n /// @dev The offset to the min block number that the schedule can start.\\n uint256 public minOffsetToStartSchedule;\\n /// @dev The offset to the max block number that the schedule can start.\\n uint256 public maxOffsetToStartSchedule;\\n /// @dev The max number of scheduled maintenances.\\n uint256 public maxSchedule;\\n /// @dev The cooldown time to request new schedule.\\n uint256 public cooldownSecsToMaintain;\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external initializer {\\n _setContract(ContractType.VALIDATOR, __validatorContract);\\n _setMaintenanceConfig(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedules,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n function initializeV2() external reinitializer(2) {\\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\\n delete ______deprecatedValidator;\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external onlyAdmin {\\n _setMaintenanceConfig(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedules,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n\\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\\n revert ErrStartBlockOutOfRange();\\n }\\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\\n\\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\\n\\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\\n revert ErrInvalidMaintenanceDuration();\\n }\\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\\n\\n Schedule storage _sSchedule = _schedule[_consensusAddr];\\n _sSchedule.from = _startedAtBlock;\\n _sSchedule.to = _endedAtBlock;\\n _sSchedule.lastUpdatedBlock = block.number;\\n _sSchedule.requestTimestamp = block.timestamp;\\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function cancelSchedule(address _consensusAddr) external override {\\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\\n }\\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\\n\\n Schedule storage _sSchedule = _schedule[_consensusAddr];\\n delete _sSchedule.from;\\n delete _sSchedule.to;\\n _sSchedule.lastUpdatedBlock = block.number;\\n emit MaintenanceScheduleCancelled(_consensusAddr);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\\n return _schedule[_consensusAddr];\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkManyMaintained(\\n address[] calldata _addrList,\\n uint256 _block\\n ) external view override returns (bool[] memory _resList) {\\n _resList = new bool[](_addrList.length);\\n for (uint _i = 0; _i < _addrList.length; ) {\\n _resList[_i] = checkMaintained(_addrList[_i], _block);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view override returns (bool[] memory _resList) {\\n _resList = new bool[](_addrList.length);\\n for (uint _i = 0; _i < _addrList.length; ) {\\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function totalSchedule() public view override returns (uint256 _count) {\\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\\n unchecked {\\n for (uint _i = 0; _i < _validators.length; _i++) {\\n if (checkScheduled(_validators[_i])) {\\n _count++;\\n }\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\\n Schedule storage _s = _schedule[_consensusAddr];\\n return _s.from <= _block && _block <= _s.to;\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) public view override returns (bool) {\\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\\n return block.number <= _schedule[_consensusAddr].to;\\n }\\n\\n /**\\n * @inheritdoc IMaintenance\\n */\\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\\n }\\n\\n /**\\n * @dev Sets the min block period and max block period to maintenance.\\n *\\n * Requirements:\\n * - The max period is larger than the min period.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function _setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedule,\\n uint256 _cooldownSecsToMaintain\\n ) internal {\\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\\n\\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\\n maxSchedule = _maxSchedule;\\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\\n emit MaintenanceConfigUpdated(\\n _minMaintenanceDurationInBlock,\\n _maxMaintenanceDurationInBlock,\\n _minOffsetToStartSchedule,\\n _maxOffsetToStartSchedule,\\n _maxSchedule,\\n _cooldownSecsToMaintain\\n );\\n }\\n\\n /**\\n * @dev Check if the validator was maintaining in the current period.\\n *\\n * Note: This method should be called at the end of the period.\\n */\\n function _maintainingInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) private view returns (bool) {\\n Schedule storage _s = _schedule[_consensusAddr];\\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\\n }\\n}\\n\",\"keccak256\":\"0xc556867bd252296f354a021531d456b082ae9203bd278087d9605e5e1744b34f\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/DeprecatedSlots.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\n/**\\n * @title Deprecated Contracts\\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\\n * They provide functionality related to various aspects of a smart contract but have been marked\\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\\n */\\ncontract HasSlashIndicatorDeprecated {\\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\\n address internal ______deprecatedSlashIndicator;\\n}\\n\\ncontract HasStakingVestingDeprecated {\\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\\n address internal ______deprecatedStakingVesting;\\n}\\n\\ncontract HasBridgeDeprecated {\\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\\n address internal ______deprecatedBridge;\\n}\\n\\ncontract HasValidatorDeprecated {\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address internal ______deprecatedValidator;\\n}\\n\\ncontract HasStakingDeprecated {\\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\\n address internal ______deprecatedStakingContract;\\n}\\n\\ncontract HasMaintenanceDeprecated {\\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\\n address internal ______deprecatedMaintenance;\\n}\\n\\ncontract HasTrustedOrgDeprecated {\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address internal ______deprecatedTrustedOrg;\\n}\\n\\ncontract HasGovernanceAdminDeprecated {\\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\\n address internal ______deprecatedGovernanceAdmin;\\n}\\n\\ncontract HasBridgeTrackingDeprecated {\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address internal ______deprecatedBridgeTracking;\\n}\\n\",\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600054600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff600160a01b909104811610156100e9576000805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611570806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106101375760003560e01c8063865e6fd3116100b8578063c09fe4601161007c578063c09fe46014610243578063d39fee3414610256578063de981f1b1461029c578063dec36284146102c7578063f0caaafb146102d0578063fdadda81146102e357600080fd5b8063865e6fd3146101f5578063ba30375514610208578063ba7e57bb14610228578063bc1710e914610231578063bfa89b9b1461023a57600080fd5b80632ddc08a2116100ff5780632ddc08a2146101b65780635cd8a76b146101c95780637a50802d146101d15780638142951a146101da57806384a9573b146101ed57600080fd5b806301b502091461013c578063088e8de71461016457806309e34c38146101775780630fbeb37f1461018e5780632d538c2c146101a1575b600080fd5b61014f61014a366004611087565b6102f6565b60405190151581526020015b60405180910390f35b61014f6101723660046110ab565b610328565b61018060025481565b60405190815260200161015b565b61014f61019c3660046110e0565b61033d565b6101b46101af3660046110ab565b610374565b005b61014f6101c4366004611087565b610788565b6101b46107aa565b61018060055481565b6101b46101e836600461110c565b61087a565b610180610977565b6101b4610203366004611170565b610a32565b61021b6102163660046111f3565b610a51565b60405161015b9190611244565b61018060065481565b61018060045481565b61018060035481565b6101b461025136600461128a565b610b07565b610269610264366004611087565b610b25565b60405161015b91908151815260208083015190820152604080830151908201526060918201519181019190915260800190565b6102af6102aa3660046112cd565b610b9d565b6040516001600160a01b03909116815260200161015b565b61018060075481565b6101b46102de366004611087565b610c18565b61021b6102f13660046112e8565b610d64565b6007546001600160a01b03821660009081526001602052604081206003015490916103209161134a565b421192915050565b6000610335848484610e18565b949350505050565b6001600160a01b03821660009081526001602052604081208054831080159061036a575080600101548311155b9150505b92915050565b60006103806008610b9d565b604051633292276760e11b81526001600160a01b038681166004830152919250908216906365244ece90602401602060405180830381865afa1580156103ca573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103ee919061135d565b610424576000356001600160e01b0319166007604051620f948f60ea1b815260040161041b929190611395565b60405180910390fd5b6040516304d971ab60e01b81526001600160a01b0385811660048301523360248301528216906304d971ab90604401602060405180830381865afa158015610470573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610494919061135d565b6104c1576000356001600160e01b0319166004604051620f948f60ea1b815260040161041b929190611395565b6104ca84610788565b156104e85760405163b194497760e01b815260040160405180910390fd5b6104f1846102f6565b61050e5760405163207dfd7760e11b815260040160405180910390fd5b600654610519610977565b106105375760405163437494d360e01b815260040160405180910390fd5b61055d60045443610548919061134a565b600554610555904361134a565b859190610e50565b61057a576040516301f19fb760e61b815260040160405180910390fd5b81831061059a576040516301f19fb760e61b815260040160405180910390fd5b60006105a684846113c3565b6105b190600161134a565b90506105cc60025460035483610e509092919063ffffffff16565b6105e95760405163a1f1aaf560e01b815260040160405180910390fd5b6001600160a01b038216637593ff716106036001876113c3565b6040518263ffffffff1660e01b815260040161062191815260200190565b602060405180830381865afa15801561063e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610662919061135d565b61067f576040516301f19fb760e61b815260040160405180910390fd5b604051637593ff7160e01b8152600481018490526001600160a01b03831690637593ff7190602401602060405180830381865afa1580156106c4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106e8919061135d565b6107055760405163ec67bbc560e01b815260040160405180910390fd5b6001600160a01b0385166000818152600160208181526040928390208881559182018790554360028301819055426003840181905584518a815292830189905293820152606081019290925291907f48e8b2f7348b1ec693bbb999258a8d6bd514732a19c6057b6e2a56a4c405253b9060800160405180910390a2505050505050565b6001600160a01b03166000908152600160208190526040909120015443111590565b600054600290600160a81b900460ff161580156107d5575060005460ff808316600160a01b90920416105b6107f15760405162461bcd60e51b815260040161041b906113d6565b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790819055610830906008906001600160a01b0316610e67565b60008054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b600054600160a81b900460ff16158080156108a257506000546001600160a01b90910460ff16105b806108c35750303b1580156108c35750600054600160a01b900460ff166001145b6108df5760405162461bcd60e51b815260040161041b906113d6565b6000805460ff60a01b1916600160a01b179055801561090c576000805460ff60a81b1916600160a81b1790555b610917600889610e67565b610925878787878787610f0b565b801561096d576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050565b6000806109846008610b9d565b6001600160a01b031663b7ab4db56040518163ffffffff1660e01b8152600401600060405180830381865afa1580156109c1573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526109e99190810190611445565b905060005b8151811015610a2d57610a19828281518110610a0c57610a0c61150a565b6020026020010151610788565b15610a25576001909201915b6001016109ee565b505090565b610a3a610fc7565b610a4381611023565b610a4d8282610e67565b5050565b60608367ffffffffffffffff811115610a6c57610a6c611424565b604051908082528060200260200182016040528015610a95578160200160208202803683370190505b50905060005b84811015610afe57610ad4868683818110610ab857610ab861150a565b9050602002016020810190610acd9190611087565b8585610e18565b828281518110610ae657610ae661150a565b91151560209283029190910190910152600101610a9b565b50949350505050565b610b0f610fc7565b610b1d868686868686610f0b565b505050505050565b610b506040518060800160405280600081526020016000815260200160008152602001600081525090565b506001600160a01b03166000908152600160208181526040928390208351608081018552815481529281015491830191909152600281015492820192909252600390910154606082015290565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610bd457610bd461137f565b60ff1681526020810191909152604001600020546001600160a01b0316905080610c13578160405163409140df60e11b815260040161041b9190611520565b919050565b610c226008610b9d565b6040516304d971ab60e01b81526001600160a01b03838116600483015233602483015291909116906304d971ab90604401602060405180830381865afa158015610c70573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c94919061135d565b610cc1576000356001600160e01b0319166004604051620f948f60ea1b815260040161041b929190611395565b610cca81610788565b610ce75760405163f7050bef60e01b815260040160405180910390fd5b610cf1814361033d565b15610d0f5760405163070dff8360e01b815260040160405180910390fd5b6001600160a01b0381166000818152600160208190526040808320838155918201839055436002830155519092917f72720a31deb222f77bbf95b88a540154648466770e5f41328ee1e25e5050737791a25050565b60608267ffffffffffffffff811115610d7f57610d7f611424565b604051908082528060200260200182016040528015610da8578160200160208202803683370190505b50905060005b83811015610e1057610de6858583818110610dcb57610dcb61150a565b9050602002016020810190610de09190611087565b8461033d565b828281518110610df857610df861150a565b91151560209283029190910190910152600101610dae565b509392505050565b6001600160a01b038316600090815260016020819052604082208054918101549091610e47918691869161105c565b95945050505050565b600083831115801561033557505090911115919050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610e9d57610e9d61137f565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610ede57610ede61137f565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b848610610f2b576040516338f4062560e11b815260040160405180910390fd5b828410610f4b576040516316c7c7ef60e31b815260040160405180910390fd5b6002869055600385905560048490556005839055600682905560078190556040805187815260208101879052908101859052606081018490526080810183905260a081018290527f4edb6adef66a4b8e1ffbc8c67640d4f244ce904193fd65e5cc316bbb74b2e59b9060c00160405180910390a1505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611021576000356001600160e01b0319166001604051620f948f60ea1b815260040161041b929190611395565b565b806001600160a01b03163b60000361105957604051630bfc64a360e21b81526001600160a01b038216600482015260240161041b565b50565b6000818511158015610e47575050501115919050565b6001600160a01b038116811461105957600080fd5b60006020828403121561109957600080fd5b81356110a481611072565b9392505050565b6000806000606084860312156110c057600080fd5b83356110cb81611072565b95602085013595506040909401359392505050565b600080604083850312156110f357600080fd5b82356110fe81611072565b946020939093013593505050565b600080600080600080600060e0888a03121561112757600080fd5b873561113281611072565b9960208901359950604089013598606081013598506080810135975060a0810135965060c00135945092505050565b803560108110610c1357600080fd5b6000806040838503121561118357600080fd5b61118c83611161565b9150602083013561119c81611072565b809150509250929050565b60008083601f8401126111b957600080fd5b50813567ffffffffffffffff8111156111d157600080fd5b6020830191508360208260051b85010111156111ec57600080fd5b9250929050565b6000806000806060858703121561120957600080fd5b843567ffffffffffffffff81111561122057600080fd5b61122c878288016111a7565b90989097506020870135966040013595509350505050565b6020808252825182820181905260009190848201906040850190845b8181101561127e578351151583529284019291840191600101611260565b50909695505050505050565b60008060008060008060c087890312156112a357600080fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b6000602082840312156112df57600080fd5b6110a482611161565b6000806000604084860312156112fd57600080fd5b833567ffffffffffffffff81111561131457600080fd5b611320868287016111a7565b909790965060209590950135949350505050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561036e5761036e611334565b60006020828403121561136f57600080fd5b815180151581146110a457600080fd5b634e487b7160e01b600052602160045260246000fd5b6001600160e01b03198316815260408101600b83106113b6576113b661137f565b8260208301529392505050565b8181038181111561036e5761036e611334565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b8051610c1381611072565b6000602080838503121561145857600080fd5b825167ffffffffffffffff8082111561147057600080fd5b818501915085601f83011261148457600080fd5b81518181111561149657611496611424565b8060051b604051601f19603f830116810181811085821117156114bb576114bb611424565b6040529182528482019250838101850191888311156114d957600080fd5b938501935b828510156114fe576114ef8561143a565b845293850193928501926114de565b98975050505050505050565b634e487b7160e01b600052603260045260246000fd5b60208101601083106115345761153461137f565b9190529056fea2646970667358221220d038baa37b40453af767489a44e654a345493e612873a2fd35fae4b2db0e4b0064736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101375760003560e01c8063865e6fd3116100b8578063c09fe4601161007c578063c09fe46014610243578063d39fee3414610256578063de981f1b1461029c578063dec36284146102c7578063f0caaafb146102d0578063fdadda81146102e357600080fd5b8063865e6fd3146101f5578063ba30375514610208578063ba7e57bb14610228578063bc1710e914610231578063bfa89b9b1461023a57600080fd5b80632ddc08a2116100ff5780632ddc08a2146101b65780635cd8a76b146101c95780637a50802d146101d15780638142951a146101da57806384a9573b146101ed57600080fd5b806301b502091461013c578063088e8de71461016457806309e34c38146101775780630fbeb37f1461018e5780632d538c2c146101a1575b600080fd5b61014f61014a366004611087565b6102f6565b60405190151581526020015b60405180910390f35b61014f6101723660046110ab565b610328565b61018060025481565b60405190815260200161015b565b61014f61019c3660046110e0565b61033d565b6101b46101af3660046110ab565b610374565b005b61014f6101c4366004611087565b610788565b6101b46107aa565b61018060055481565b6101b46101e836600461110c565b61087a565b610180610977565b6101b4610203366004611170565b610a32565b61021b6102163660046111f3565b610a51565b60405161015b9190611244565b61018060065481565b61018060045481565b61018060035481565b6101b461025136600461128a565b610b07565b610269610264366004611087565b610b25565b60405161015b91908151815260208083015190820152604080830151908201526060918201519181019190915260800190565b6102af6102aa3660046112cd565b610b9d565b6040516001600160a01b03909116815260200161015b565b61018060075481565b6101b46102de366004611087565b610c18565b61021b6102f13660046112e8565b610d64565b6007546001600160a01b03821660009081526001602052604081206003015490916103209161134a565b421192915050565b6000610335848484610e18565b949350505050565b6001600160a01b03821660009081526001602052604081208054831080159061036a575080600101548311155b9150505b92915050565b60006103806008610b9d565b604051633292276760e11b81526001600160a01b038681166004830152919250908216906365244ece90602401602060405180830381865afa1580156103ca573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103ee919061135d565b610424576000356001600160e01b0319166007604051620f948f60ea1b815260040161041b929190611395565b60405180910390fd5b6040516304d971ab60e01b81526001600160a01b0385811660048301523360248301528216906304d971ab90604401602060405180830381865afa158015610470573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610494919061135d565b6104c1576000356001600160e01b0319166004604051620f948f60ea1b815260040161041b929190611395565b6104ca84610788565b156104e85760405163b194497760e01b815260040160405180910390fd5b6104f1846102f6565b61050e5760405163207dfd7760e11b815260040160405180910390fd5b600654610519610977565b106105375760405163437494d360e01b815260040160405180910390fd5b61055d60045443610548919061134a565b600554610555904361134a565b859190610e50565b61057a576040516301f19fb760e61b815260040160405180910390fd5b81831061059a576040516301f19fb760e61b815260040160405180910390fd5b60006105a684846113c3565b6105b190600161134a565b90506105cc60025460035483610e509092919063ffffffff16565b6105e95760405163a1f1aaf560e01b815260040160405180910390fd5b6001600160a01b038216637593ff716106036001876113c3565b6040518263ffffffff1660e01b815260040161062191815260200190565b602060405180830381865afa15801561063e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610662919061135d565b61067f576040516301f19fb760e61b815260040160405180910390fd5b604051637593ff7160e01b8152600481018490526001600160a01b03831690637593ff7190602401602060405180830381865afa1580156106c4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106e8919061135d565b6107055760405163ec67bbc560e01b815260040160405180910390fd5b6001600160a01b0385166000818152600160208181526040928390208881559182018790554360028301819055426003840181905584518a815292830189905293820152606081019290925291907f48e8b2f7348b1ec693bbb999258a8d6bd514732a19c6057b6e2a56a4c405253b9060800160405180910390a2505050505050565b6001600160a01b03166000908152600160208190526040909120015443111590565b600054600290600160a81b900460ff161580156107d5575060005460ff808316600160a01b90920416105b6107f15760405162461bcd60e51b815260040161041b906113d6565b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790819055610830906008906001600160a01b0316610e67565b60008054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b600054600160a81b900460ff16158080156108a257506000546001600160a01b90910460ff16105b806108c35750303b1580156108c35750600054600160a01b900460ff166001145b6108df5760405162461bcd60e51b815260040161041b906113d6565b6000805460ff60a01b1916600160a01b179055801561090c576000805460ff60a81b1916600160a81b1790555b610917600889610e67565b610925878787878787610f0b565b801561096d576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050505050565b6000806109846008610b9d565b6001600160a01b031663b7ab4db56040518163ffffffff1660e01b8152600401600060405180830381865afa1580156109c1573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526109e99190810190611445565b905060005b8151811015610a2d57610a19828281518110610a0c57610a0c61150a565b6020026020010151610788565b15610a25576001909201915b6001016109ee565b505090565b610a3a610fc7565b610a4381611023565b610a4d8282610e67565b5050565b60608367ffffffffffffffff811115610a6c57610a6c611424565b604051908082528060200260200182016040528015610a95578160200160208202803683370190505b50905060005b84811015610afe57610ad4868683818110610ab857610ab861150a565b9050602002016020810190610acd9190611087565b8585610e18565b828281518110610ae657610ae661150a565b91151560209283029190910190910152600101610a9b565b50949350505050565b610b0f610fc7565b610b1d868686868686610f0b565b505050505050565b610b506040518060800160405280600081526020016000815260200160008152602001600081525090565b506001600160a01b03166000908152600160208181526040928390208351608081018552815481529281015491830191909152600281015492820192909252600390910154606082015290565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610bd457610bd461137f565b60ff1681526020810191909152604001600020546001600160a01b0316905080610c13578160405163409140df60e11b815260040161041b9190611520565b919050565b610c226008610b9d565b6040516304d971ab60e01b81526001600160a01b03838116600483015233602483015291909116906304d971ab90604401602060405180830381865afa158015610c70573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c94919061135d565b610cc1576000356001600160e01b0319166004604051620f948f60ea1b815260040161041b929190611395565b610cca81610788565b610ce75760405163f7050bef60e01b815260040160405180910390fd5b610cf1814361033d565b15610d0f5760405163070dff8360e01b815260040160405180910390fd5b6001600160a01b0381166000818152600160208190526040808320838155918201839055436002830155519092917f72720a31deb222f77bbf95b88a540154648466770e5f41328ee1e25e5050737791a25050565b60608267ffffffffffffffff811115610d7f57610d7f611424565b604051908082528060200260200182016040528015610da8578160200160208202803683370190505b50905060005b83811015610e1057610de6858583818110610dcb57610dcb61150a565b9050602002016020810190610de09190611087565b8461033d565b828281518110610df857610df861150a565b91151560209283029190910190910152600101610dae565b509392505050565b6001600160a01b038316600090815260016020819052604082208054918101549091610e47918691869161105c565b95945050505050565b600083831115801561033557505090911115919050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610e9d57610e9d61137f565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610ede57610ede61137f565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b848610610f2b576040516338f4062560e11b815260040160405180910390fd5b828410610f4b576040516316c7c7ef60e31b815260040160405180910390fd5b6002869055600385905560048490556005839055600682905560078190556040805187815260208101879052908101859052606081018490526080810183905260a081018290527f4edb6adef66a4b8e1ffbc8c67640d4f244ce904193fd65e5cc316bbb74b2e59b9060c00160405180910390a1505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611021576000356001600160e01b0319166001604051620f948f60ea1b815260040161041b929190611395565b565b806001600160a01b03163b60000361105957604051630bfc64a360e21b81526001600160a01b038216600482015260240161041b565b50565b6000818511158015610e47575050501115919050565b6001600160a01b038116811461105957600080fd5b60006020828403121561109957600080fd5b81356110a481611072565b9392505050565b6000806000606084860312156110c057600080fd5b83356110cb81611072565b95602085013595506040909401359392505050565b600080604083850312156110f357600080fd5b82356110fe81611072565b946020939093013593505050565b600080600080600080600060e0888a03121561112757600080fd5b873561113281611072565b9960208901359950604089013598606081013598506080810135975060a0810135965060c00135945092505050565b803560108110610c1357600080fd5b6000806040838503121561118357600080fd5b61118c83611161565b9150602083013561119c81611072565b809150509250929050565b60008083601f8401126111b957600080fd5b50813567ffffffffffffffff8111156111d157600080fd5b6020830191508360208260051b85010111156111ec57600080fd5b9250929050565b6000806000806060858703121561120957600080fd5b843567ffffffffffffffff81111561122057600080fd5b61122c878288016111a7565b90989097506020870135966040013595509350505050565b6020808252825182820181905260009190848201906040850190845b8181101561127e578351151583529284019291840191600101611260565b50909695505050505050565b60008060008060008060c087890312156112a357600080fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b6000602082840312156112df57600080fd5b6110a482611161565b6000806000604084860312156112fd57600080fd5b833567ffffffffffffffff81111561131457600080fd5b611320868287016111a7565b909790965060209590950135949350505050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561036e5761036e611334565b60006020828403121561136f57600080fd5b815180151581146110a457600080fd5b634e487b7160e01b600052602160045260246000fd5b6001600160e01b03198316815260408101600b83106113b6576113b661137f565b8260208301529392505050565b8181038181111561036e5761036e611334565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b8051610c1381611072565b6000602080838503121561145857600080fd5b825167ffffffffffffffff8082111561147057600080fd5b818501915085601f83011261148457600080fd5b81518181111561149657611496611424565b8060051b604051601f19603f830116810181811085821117156114bb576114bb611424565b6040529182528482019250838101850191888311156114d957600080fd5b938501935b828510156114fe576114ef8561143a565b845293850193928501926114de565b98975050505050505050565b634e487b7160e01b600052603260045260246000fd5b60208101601083106115345761153461137f565b9190529056fea2646970667358221220d038baa37b40453af767489a44e654a345493e612873a2fd35fae4b2db0e4b0064736f6c63430008110033", "devdoc": { "errors": { - "ErrCallerMustBeValidatorContract()": [ + "ErrAlreadyOnMaintenance()": [ + { + "details": "Error thrown when attempting to initiate maintenance while already in maintenance mode." + } + ], + "ErrAlreadyScheduled()": [ + { + "details": "Error thrown when attempting to schedule an already scheduled event." + } + ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrCooldownTimeNotYetEnded()": [ + { + "details": "Error thrown when attempting an action before the cooldown period has ended." + } + ], + "ErrEndBlockOutOfRange()": [ + { + "details": "Error thrown when the end block of a schedule is out of range." + } + ], + "ErrInvalidMaintenanceDuration()": [ + { + "details": "Error thrown when an invalid maintenance duration is specified." + } + ], + "ErrInvalidMaintenanceDurationConfig()": [ + { + "details": "Error thrown when an invalid maintenance duration configuration is provided." + } + ], + "ErrInvalidOffsetToStartScheduleConfigs()": [ { - "details": "Error of method caller must be validator contract." + "details": "Error thrown when an invalid offset is specified to start the schedule configurations." } ], - "ErrZeroCodeContract()": [ + "ErrStartBlockOutOfRange()": [ + { + "details": "Error thrown when the start block of a schedule is out of range." + } + ], + "ErrTotalOfSchedulesExceeded()": [ + { + "details": "Error thrown when the total number of schedules exceeds the limit." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnexistedSchedule()": [ + { + "details": "Error thrown when referring to a non-existent schedule." + } + ], + "ErrZeroCodeContract(address)": [ { "details": "Error of set to non-contract." } @@ -612,7 +773,7 @@ "cancelSchedule(address)": { "details": "Cancel the schedule of maintenance for the `_consensusAddr`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - A schedule for the `_consensusAddr` must be existent and not executed yet. Emits the event `MaintenanceScheduleCancelled`." }, - "checkCooldownEnds(address)": { + "checkCooldownEnded(address)": { "details": "Returns whether the validator `_consensusAddr`" }, "checkMaintained(address,uint256)": { @@ -630,6 +791,15 @@ "checkScheduled(address)": { "details": "Returns whether the validator `_consensusAddr` has scheduled." }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, "getSchedule(address)": { "details": "Returns the detailed schedule of the validator `_consensusAddr`." }, @@ -639,17 +809,18 @@ "schedule(address,uint256,uint256)": { "details": "Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`. Requirements: - The candidate `_consensusAddr` is the block producer. - The method caller is candidate admin of the candidate `_consensusAddr`. - The candidate `_consensusAddr` has no schedule yet or the previous is done. - The total number of schedules is not larger than `maxSchedules()`. - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block. - The end block is larger than the start block. - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`. - The start block is at the start of an epoch. - The end block is at the end of an epoch. Emits the event `MaintenanceScheduled`." }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, "setMaintenanceConfig(uint256,uint256,uint256,uint256,uint256,uint256)": { "details": "Sets the duration restriction, start time restriction, and max allowed for maintenance. Requirements: - The method caller is admin. - The max duration is larger than the min duration. - The max offset is larger than the min offset. Emits the event `MaintenanceConfigUpdated`." }, - "setValidatorContract(address)": { - "details": "Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`." - }, - "totalSchedules()": { + "totalSchedule()": { "details": "Returns the total of current schedules." - }, - "validatorContract()": { - "details": "Returns the validator contract." } }, "stateVariables": { @@ -665,7 +836,7 @@ "maxOffsetToStartSchedule": { "details": "The offset to the max block number that the schedule can start." }, - "maxSchedules": { + "maxSchedule": { "details": "The max number of scheduled maintenances." }, "minMaintenanceDurationInBlock": { @@ -685,12 +856,12 @@ "storageLayout": { "storage": [ { - "astId": 7051, + "astId": 41900, "contract": "contracts/ronin/Maintenance.sol:Maintenance", - "label": "_validatorContract", + "label": "______deprecatedValidator", "offset": 0, "slot": "0", - "type": "t_contract(IRoninValidatorSet)11973" + "type": "t_address" }, { "astId": 1373, @@ -709,15 +880,15 @@ "type": "t_bool" }, { - "astId": 20853, + "astId": 24315, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "_schedule", "offset": 0, "slot": "1", - "type": "t_mapping(t_address,t_struct(Schedule)9487_storage)" + "type": "t_mapping(t_address,t_struct(Schedule)11412_storage)" }, { - "astId": 20856, + "astId": 24318, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "minMaintenanceDurationInBlock", "offset": 0, @@ -725,7 +896,7 @@ "type": "t_uint256" }, { - "astId": 20859, + "astId": 24321, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "maxMaintenanceDurationInBlock", "offset": 0, @@ -733,7 +904,7 @@ "type": "t_uint256" }, { - "astId": 20862, + "astId": 24324, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "minOffsetToStartSchedule", "offset": 0, @@ -741,7 +912,7 @@ "type": "t_uint256" }, { - "astId": 20865, + "astId": 24327, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "maxOffsetToStartSchedule", "offset": 0, @@ -749,15 +920,15 @@ "type": "t_uint256" }, { - "astId": 20868, + "astId": 24330, "contract": "contracts/ronin/Maintenance.sol:Maintenance", - "label": "maxSchedules", + "label": "maxSchedule", "offset": 0, "slot": "6", "type": "t_uint256" }, { - "astId": 20871, + "astId": 24333, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "cooldownSecsToMaintain", "offset": 0, @@ -776,24 +947,19 @@ "label": "bool", "numberOfBytes": "1" }, - "t_contract(IRoninValidatorSet)11973": { - "encoding": "inplace", - "label": "contract IRoninValidatorSet", - "numberOfBytes": "20" - }, - "t_mapping(t_address,t_struct(Schedule)9487_storage)": { + "t_mapping(t_address,t_struct(Schedule)11412_storage)": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => struct IMaintenance.Schedule)", "numberOfBytes": "32", - "value": "t_struct(Schedule)9487_storage" + "value": "t_struct(Schedule)11412_storage" }, - "t_struct(Schedule)9487_storage": { + "t_struct(Schedule)11412_storage": { "encoding": "inplace", "label": "struct IMaintenance.Schedule", "members": [ { - "astId": 9480, + "astId": 11405, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "from", "offset": 0, @@ -801,7 +967,7 @@ "type": "t_uint256" }, { - "astId": 9482, + "astId": 11407, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "to", "offset": 0, @@ -809,7 +975,7 @@ "type": "t_uint256" }, { - "astId": 9484, + "astId": 11409, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "lastUpdatedBlock", "offset": 0, @@ -817,7 +983,7 @@ "type": "t_uint256" }, { - "astId": 9486, + "astId": 11411, "contract": "contracts/ronin/Maintenance.sol:Maintenance", "label": "requestTimestamp", "offset": 0, diff --git a/deployments/ronin-mainnet/ProfileLogic.json b/deployments/ronin-mainnet/ProfileLogic.json new file mode 100644 index 000000000..b8ddc98a7 --- /dev/null +++ b/deployments/ronin-mainnet/ProfileLogic.json @@ -0,0 +1,686 @@ +{ + "address": "0x3EC92e7a835bb58832Df64E7f8206467e07d54a3", + "abi": [ + { + "inputs": [], + "stateMutability": "nonpayable", + "type": "constructor" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum RoleAccess", + "name": "infoType", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "value", + "type": "uint256" + } + ], + "name": "ErrDuplicatedInfo", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "name": "ErrDuplicatedPubkey", + "type": "error" + }, + { + "inputs": [], + "name": "ErrExistentProfile", + "type": "error" + }, + { + "inputs": [], + "name": "ErrIdAndConsensusDiffer", + "type": "error" + }, + { + "inputs": [], + "name": "ErrNonExistentProfile", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum RoleAccess", + "name": "infoType", + "type": "uint8" + } + ], + "name": "ErrZeroAddress", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "inputs": [], + "name": "ErrZeroPubkey", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "id", + "type": "address" + } + ], + "name": "ProfileAdded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "indexed": true, + "internalType": "enum RoleAccess", + "name": "addressType", + "type": "uint8" + } + ], + "name": "ProfileAddressChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "indexed": false, + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "name": "PubkeyChanged", + "type": "event" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "internalType": "address", + "name": "consensus", + "type": "address" + }, + { + "internalType": "address", + "name": "admin", + "type": "address" + }, + { + "internalType": "address payable", + "name": "treasury", + "type": "address" + }, + { + "internalType": "address", + "name": "governor", + "type": "address" + }, + { + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "internalType": "struct IProfile.CandidateProfile", + "name": "profile", + "type": "tuple" + } + ], + "name": "addNewProfile", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "name": "changePubkey", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "id", + "type": "address" + } + ], + "name": "getId2Profile", + "outputs": [ + { + "components": [ + { + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "internalType": "address", + "name": "consensus", + "type": "address" + }, + { + "internalType": "address", + "name": "admin", + "type": "address" + }, + { + "internalType": "address payable", + "name": "treasury", + "type": "address" + }, + { + "internalType": "address", + "name": "governor", + "type": "address" + }, + { + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "internalType": "struct IProfile.CandidateProfile", + "name": "", + "type": "tuple" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "validatorContract", + "type": "address" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "migrateMainnetV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "address", + "name": "id", + "type": "address" + }, + { + "internalType": "address", + "name": "consensus", + "type": "address" + }, + { + "internalType": "address", + "name": "admin", + "type": "address" + }, + { + "internalType": "address payable", + "name": "treasury", + "type": "address" + }, + { + "internalType": "address", + "name": "governor", + "type": "address" + }, + { + "internalType": "bytes", + "name": "pubkey", + "type": "bytes" + } + ], + "internalType": "struct IProfile.CandidateProfile", + "name": "profile", + "type": "tuple" + } + ], + "name": "registerProfile", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + } + ], + "transactionHash": "0xa3cc9306660f232648f8045ae524c06993cf78850ca914c1bf806181c03b101b", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x3EC92e7a835bb58832Df64E7f8206467e07d54a3", + "transactionIndex": 0, + "gasUsed": "1206843", + "logsBloom": "0x00000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x3d1c72eb8270a7c1b53418082f30594e4460f347f871b0760f7d3cc87180a771", + "transactionHash": "0xa3cc9306660f232648f8045ae524c06993cf78850ca914c1bf806181c03b101b", + "logs": [ + { + "transactionIndex": 0, + "blockNumber": 28139406, + "transactionHash": "0xa3cc9306660f232648f8045ae524c06993cf78850ca914c1bf806181c03b101b", + "address": "0x3EC92e7a835bb58832Df64E7f8206467e07d54a3", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", + "logIndex": 0, + "blockHash": "0x3d1c72eb8270a7c1b53418082f30594e4460f347f871b0760f7d3cc87180a771" + } + ], + "blockNumber": 28139406, + "cumulativeGasUsed": "1206843", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 2, + "solcInputHash": "d621ebdfe20690422990472986e02493", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum RoleAccess\",\"name\":\"infoType\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"value\",\"type\":\"uint256\"}],\"name\":\"ErrDuplicatedInfo\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"name\":\"ErrDuplicatedPubkey\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrExistentProfile\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrIdAndConsensusDiffer\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrNonExistentProfile\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum RoleAccess\",\"name\":\"infoType\",\"type\":\"uint8\"}],\"name\":\"ErrZeroAddress\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroPubkey\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"}],\"name\":\"ProfileAdded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"enum RoleAccess\",\"name\":\"addressType\",\"type\":\"uint8\"}],\"name\":\"ProfileAddressChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"name\":\"PubkeyChanged\",\"type\":\"event\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensus\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasury\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"internalType\":\"struct IProfile.CandidateProfile\",\"name\":\"profile\",\"type\":\"tuple\"}],\"name\":\"addNewProfile\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"name\":\"changePubkey\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"}],\"name\":\"getId2Profile\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensus\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasury\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"internalType\":\"struct IProfile.CandidateProfile\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validatorContract\",\"type\":\"address\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"migrateMainnetV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"id\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensus\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasury\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"pubkey\",\"type\":\"bytes\"}],\"internalType\":\"struct IProfile.CandidateProfile\",\"name\":\"profile\",\"type\":\"tuple\"}],\"name\":\"registerProfile\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrDuplicatedInfo(uint8,uint256)\":[{\"details\":\"Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key, and with value type of `infoType`.\"}],\"ErrExistentProfile()\":[{\"details\":\"Error of already existed profile.\"}],\"ErrIdAndConsensusDiffer()\":[{\"details\":\"Error when create a new profile whose id and consensus are not identical.\"}],\"ErrNonExistentProfile()\":[{\"details\":\"Error of non existed profile.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"addNewProfile((address,address,address,address,address,bytes))\":{\"details\":\"Requirements: - The profile must not be existent before. - Only contract admin can call this method.\"},\"changePubkey(address,bytes)\":{\"details\":\"Requirements: - The profile must be existed. - Only user with candidate admin role can call this method. - New public key must not be duplicated.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getId2Profile(address)\":{\"details\":\"Getter to query full `profile` from `id` address.\"},\"registerProfile((address,address,address,address,address,bytes))\":{\"details\":\"Requirements: - The profile must not be existent before. - Only user with candidate admin role can call this method.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"addNewProfile((address,address,address,address,address,bytes))\":{\"notice\":\"Add a new profile.\"},\"changePubkey(address,bytes)\":{\"notice\":\"The candidate admin changes the public key.\"},\"registerProfile((address,address,address,address,address,bytes))\":{\"notice\":\"The candidate admin registers a new profile.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/profile/Profile.sol\":\"Profile\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IProfile.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../utils/RoleAccess.sol\\\";\\n\\ninterface IProfile {\\n struct CandidateProfile {\\n /**\\n * @dev Primary key of the profile, use for backward querying.\\n *\\n * {Staking} Contract: index of pool\\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\\n *\\n */\\n address id;\\n /// @dev Consensus address.\\n address consensus;\\n /// @dev Pool admin address.\\n address admin;\\n /// @dev Treasury address.\\n address payable treasury;\\n /// @dev Address to voting proposal.\\n address governor;\\n /// @dev Public key for fast finality.\\n bytes pubkey;\\n }\\n\\n /// @dev Event emitted when a profile with `id` is added.\\n event ProfileAdded(address indexed id);\\n /// @dev Event emitted when a address in a profile is changed.\\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\\n /// @dev Event emitted when the pubkey of the `id` is changed.\\n event PubkeyChanged(address indexed id, bytes pubkey);\\n\\n /// @dev Error of already existed profile.\\n error ErrExistentProfile();\\n /// @dev Error of non existed profile.\\n error ErrNonExistentProfile();\\n /// @dev Error when create a new profile whose id and consensus are not identical.\\n error ErrIdAndConsensusDiffer();\\n /**\\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\\n * and with value type of `infoType`.\\n */\\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\\n error ErrDuplicatedPubkey(bytes pubkey);\\n error ErrZeroAddress(RoleAccess infoType);\\n error ErrZeroPubkey();\\n\\n /// @dev Getter to query full `profile` from `id` address.\\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\\n\\n /**\\n * @notice Add a new profile.\\n *\\n * @dev Requirements:\\n * - The profile must not be existent before.\\n * - Only contract admin can call this method.\\n */\\n function addNewProfile(CandidateProfile memory profile) external;\\n\\n /**\\n * @notice The candidate admin registers a new profile.\\n *\\n * @dev Requirements:\\n * - The profile must not be existent before.\\n * - Only user with candidate admin role can call this method.\\n */\\n\\n function registerProfile(CandidateProfile memory profile) external;\\n\\n /**\\n * @notice The candidate admin changes the public key.\\n *\\n * @dev Requirements:\\n * - The profile must be existed.\\n * - Only user with candidate admin role can call this method.\\n * - New public key must not be duplicated.\\n */\\n\\n function changePubkey(address id, bytes memory pubkey) external;\\n}\\n\",\"keccak256\":\"0xa22fc36c00bc641b74359a9df037b8b00028ae679b2b5fa48cb23f1c5f07dbcf\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/ronin/profile/Profile.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../interfaces/validator/ICandidateManager.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../interfaces/IProfile.sol\\\";\\nimport { ErrUnauthorized, RoleAccess } from \\\"../../utils/CommonErrors.sol\\\";\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\nimport \\\"./ProfileHandler.sol\\\";\\n\\npragma solidity ^0.8.9;\\n\\ncontract Profile is IProfile, ProfileHandler, Initializable {\\n constructor() {\\n _disableInitializers();\\n }\\n\\n function initialize(address validatorContract) external initializer {\\n _setContract(ContractType.VALIDATOR, validatorContract);\\n }\\n\\n function migrateMainnetV2() external {\\n require(block.chainid == 2020, \\\"mismatch chainID\\\");\\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \\\"not mainnet deployer\\\");\\n\\n address[29] memory consensusList = [\\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\\n ];\\n\\n CandidateProfile storage _profile;\\n for (uint i; i < consensusList.length; i++) {\\n _profile = _id2Profile[consensusList[i]];\\n _profile.id = consensusList[i];\\n }\\n }\\n\\n /**\\n * @inheritdoc IProfile\\n */\\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\\n return _id2Profile[id];\\n }\\n\\n /**\\n * @inheritdoc IProfile\\n */\\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\\n CandidateProfile storage _profile = _id2Profile[profile.id];\\n if (_profile.id != address(0)) revert ErrExistentProfile();\\n _addNewProfile(_profile, profile);\\n }\\n\\n /**\\n * @inheritdoc IProfile\\n */\\n function registerProfile(CandidateProfile memory profile) external {\\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\\n\\n CandidateProfile storage _profile = _id2Profile[profile.id];\\n if (_profile.id != address(0)) revert ErrExistentProfile();\\n if (\\n msg.sender != profile.admin ||\\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n _checkDuplicatedInRegistry(profile);\\n\\n _addNewProfile(_profile, profile);\\n }\\n\\n /**\\n * @inheritdoc IProfile\\n */\\n function changePubkey(address id, bytes memory pubkey) external {\\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n _checkNonDuplicatedPubkey(pubkey);\\n _setPubkey(_profile, pubkey);\\n\\n emit PubkeyChanged(id, pubkey);\\n }\\n}\\n\",\"keccak256\":\"0x0a54fc9b75c37ea1f2f16e105d02ddd1dd9bb21a4440adfce22e3a1d497cdde4\",\"license\":\"MIT\"},\"contracts/ronin/profile/ProfileHandler.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../utils/RoleAccess.sol\\\";\\nimport { ProfileStorage } from \\\"./ProfileStorage.sol\\\";\\n\\nabstract contract ProfileHandler is ProfileStorage {\\n /**\\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\\n */\\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\\n _checkNonDuplicatedPubkey(profile.pubkey);\\n }\\n\\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\\n if (addr == address(0)) revert ErrZeroAddress(addressType);\\n _checkNonDuplicated(addressType, addr);\\n }\\n\\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\\n if (_registry[uint256(uint160(addr))]) {\\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\\n }\\n }\\n\\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\\n if (_registry[_hashPubkey(pubkey)]) {\\n revert ErrDuplicatedPubkey(pubkey);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xccc5e5a3769f7cc2265f73e3a2117754a71d1e504c0ee697ae5d25bcaa19d982\",\"license\":\"MIT\"},\"contracts/ronin/profile/ProfileStorage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { IProfile } from \\\"../../interfaces/IProfile.sol\\\";\\n\\nabstract contract ProfileStorage is IProfile, HasContracts {\\n /// @dev Mapping from id address => candidate profile.\\n mapping(address => CandidateProfile) internal _id2Profile;\\n /**\\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\\n * cannot be reused.\\n */\\n mapping(uint256 => bool) internal _registry;\\n /// @dev Upgradeable gap.\\n bytes32[49] __gap;\\n\\n /**\\n * @dev Add a profile from memory to storage.\\n */\\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\\n _profile.id = newProfile.id;\\n\\n _setConsensus(_profile, newProfile.consensus);\\n _setAdmin(_profile, newProfile.admin);\\n _setTreasury(_profile, newProfile.treasury);\\n _setGovernor(_profile, newProfile.governor);\\n _setPubkey(_profile, newProfile.pubkey);\\n\\n emit ProfileAdded(newProfile.id);\\n }\\n\\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\\n _profile.consensus = consensus;\\n _registry[uint256(uint160(consensus))] = true;\\n }\\n\\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\\n _profile.admin = admin;\\n _registry[uint256(uint160(admin))] = true;\\n }\\n\\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\\n _profile.treasury = treasury;\\n _registry[uint256(uint160(address(treasury)))] = true;\\n }\\n\\n /**\\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\\n */\\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\\n _profile.governor = governor;\\n if (governor != address(0)) {\\n _registry[uint256(uint160(governor))] = true;\\n }\\n }\\n\\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\\n _profile.pubkey = pubkey;\\n _registry[_hashPubkey(pubkey)] = true;\\n }\\n\\n /**\\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\\n */\\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\\n _profile = _id2Profile[id];\\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\\n }\\n\\n /**\\n * @dev Returns hash of a public key.\\n */\\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\\n return uint256(keccak256(pubkey));\\n }\\n}\\n\",\"keccak256\":\"0x9f3cc490c413463e17adc5319380dc5bd2d284282a25e50f73248db87b32af69\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100de565b603354610100900460ff161561008a5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60335460ff90811610156100dc576033805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611461806100ed6000396000f3fe608060405234801561001057600080fd5b50600436106100885760003560e01c806392d487561161005b57806392d48756146100d0578063c4d66de8146100e3578063de981f1b146100f6578063f46609401461012657600080fd5b806368a5c1231461008d578063865e6fd3146100a25780639029bc60146100b557806391486604146100c8575b600080fd5b6100a061009b366004610f96565b610146565b005b6100a06100b0366004610ff5565b6101f3565b6100a06100c336600461102c565b610212565b6100a0610373565b6100a06100de36600461102c565b6107b3565b6100a06100f13660046110f4565b6107f9565b610109610104366004611118565b61090d565b6040516001600160a01b0390911681526020015b60405180910390f35b6101396101343660046110f4565b610988565b60405161011d9190611179565b600061015183610ab8565b60028101549091506001600160a01b0316331461019a576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b60405180910390fd5b6101a382610af3565b6101ad8183610b33565b826001600160a01b03167fe13225a225fbfeebd9d707546f3d7adee5d72738ac686cc5b97266c49745a56b836040516101e69190611228565b60405180910390a2505050565b6101fb610b79565b61020481610bd5565b61020e8282610c0b565b5050565b80602001516001600160a01b031681600001516001600160a01b03161461024c5760405163491db47560e01b815260040160405180910390fd5b80516001600160a01b03908116600090815260208190526040902080549091161561028a5760405163249b38f960e01b815260040160405180910390fd5b81604001516001600160a01b0316336001600160a01b031614158061033257506102b4600861090d565b602083015160408085015190516304d971ab60e01b81526001600160a01b03928316600482015290821660248201529116906304d971ab90604401602060405180830381865afa15801561030c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610330919061123b565b155b15610360576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b61036982610caf565b61020e8183610cf8565b466107e4146103b75760405162461bcd60e51b815260206004820152601060248201526f1b5a5cdb585d18da0818da185a5b925160821b6044820152606401610191565b734d58ea7231c394d5804e8b06b1365915f906e27f33146104115760405162461bcd60e51b81526020600482015260146024820152733737ba1036b0b4b73732ba103232b83637bcb2b960611b6044820152606401610191565b604080516103a0810182527352c0dcd83aa1999ba6c3b0324c8299e30207373c815273f41af21f0a800dc4d86efb14ad46cfb9884fdf38602082015273e07d7e56588a6fd860c5073c70a099658c060f3d918101919091527352349003240770727900b06a3b3a90f5c0219ade6060820152732bddcaae1c6ccd53e436179b3fc07307ee6f3ef8608082015273ec702628f44c31acc56c3a59555be47e1f16eb1e60a082015273bd4bf317da1928cc2f9f4da9006401f3944a0ab560c082015273d11d9842babd5209b9b1155e46f5878c989125b760e08201527361089875ff9e506ae78c7fe9f7c388416520e38661010082015273d7fef73d95ccedb26483fd3c6c48393e507081596101208201527347cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1610140820152738eec4f1c0878f73e8e09c1be78ac1465cc16544d610160820152739b959d27840a31988410ee69991bcf0110d61f0261018082015273ee11d2016e9f2fae606b2f12986811f4abbe62156101a082015273ca54a1700e0403dcb531f8db4ae3847758b90b016101c0820152734e7ea047ec7e95c7a02cb117128b94ccdd8356bf6101e0820152736e46924371d0e910769aabe0d867590deac2068461020082015273ae53daac1bf3c4633d4921b8c3f8d579e757f5bc6102208201527305ad3ded6fcc510324af8e2631717af6da5c8b5b6102408201527332d619dc6188409cebbc52f921ab306f07db085b61026082015273210744c64eea863cf0f972e5aebc683b98fb198461028082015273edcafc4ad8097c2012980a2a7087d74b86bddaf96102a082015273fc3e31519b551bd594235dd0ef014375a87c4e216102c0820152736aaabf51c5f6d2d93212cf7dad73d67afa0148d06102e08201527322c23429e46e7944d2918f2b368b799b11c417c16103008201527303a7b98c226225e330d11d1b9177891391fa4f806103208201527320238eb5643d4d7b7ab3c30f3bf7b8e2b85ca1e76103408201527307d28f88d677c4056ea6722aa35d92903b2a63da61036082015273262b9fcfe8cfa900af4d1f5c20396e969b9655dd6103808201526000805b601d8110156107ae576000808483601d81106107445761074461125d565b60200201516001600160a01b03166001600160a01b0316815260200190815260200160002091508281601d811061077d5761077d61125d565b602002015182546001600160a01b0319166001600160a01b03909116178255806107a681611273565b915050610726565b505050565b6107bb610b79565b80516001600160a01b0390811660009081526020819052604090208054909116156103695760405163249b38f960e01b815260040160405180910390fd5b603354610100900460ff16158080156108195750603354600160ff909116105b806108335750303b158015610833575060335460ff166001145b6108965760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610191565b6033805460ff1916600117905580156108b9576033805461ff0019166101001790555b6108c4600883610c0b565b801561020e576033805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610944576109446111e0565b60ff1681526020810191909152604001600020546001600160a01b0316905080610983578160405163409140df60e11b8152600401610191919061129a565b919050565b6040805160c0810182526000808252602082018190529181018290526060808201839052608082019290925260a08101919091526001600160a01b0380831660009081526020818152604091829020825160c081018452815485168152600182015485169281019290925260028101548416928201929092526003820154831660608201526004820154909216608083015260058101805460a084019190610a2f906112b4565b80601f0160208091040260200160405190810160405280929190818152602001828054610a5b906112b4565b8015610aa85780601f10610a7d57610100808354040283529160200191610aa8565b820191906000526020600020905b815481529060010190602001808311610a8b57829003601f168201915b5050505050815250509050919050565b6001600160a01b0380821660009081526020819052604090208054909116610983576040516334152acb60e11b815260040160405180910390fd5b805160208083019190912060009081526001909152604090205460ff1615610b305780604051630f32bad960e31b81526004016101919190611228565b50565b60058201610b41828261133c565b506001806000610b5684805160209091012090565b81526020810191909152604001600020805460ff19169115159190911790555050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610bd3576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b565b806001600160a01b03163b600003610b3057604051630bfc64a360e21b81526001600160a01b0382166004820152602401610191565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c4157610c416111e0565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610c8257610c826111e0565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610cbe60098260200151610de7565b610ccd60048260400151610de7565b610cdc600a8260600151610de7565b610ceb600a8260800151610e16565b610b308160a00151610af3565b805182546001600160a01b039182166001600160a01b031991821617845560208084015160018087018054928616928516831790556000918252918290526040808220805460ff199081168517909155818701516002890180549188169187168217905583528183208054821685179055606087015160038901805491909716951685179095559281529190912080549092161790556080810151610d9e908390610e5d565b610dac828260a00151610b33565b80516040516001600160a01b03909116907fc9da0ae38bd4761b72da1045c9b2618f0cd991dcac01e1f9bbf68474025f074390600090a25050565b6001600160a01b038116610e1057816040516315fb58b960e21b815260040161019191906113fc565b61020e82825b6001600160a01b03811660009081526001602052604090205460ff161561020e5781816001600160a01b031660405163720b355560e11b8152600401610191929190611410565b6004820180546001600160a01b0319166001600160a01b0383169081179091551561020e576001600160a01b03166000908152600160208190526040909120805460ff1916909117905550565b6001600160a01b0381168114610b3057600080fd5b803561098381610eaa565b634e487b7160e01b600052604160045260246000fd5b60405160c0810167ffffffffffffffff81118282101715610f0357610f03610eca565b60405290565b600082601f830112610f1a57600080fd5b813567ffffffffffffffff80821115610f3557610f35610eca565b604051601f8301601f19908116603f01168101908282118183101715610f5d57610f5d610eca565b81604052838152866020858801011115610f7657600080fd5b836020870160208301376000602085830101528094505050505092915050565b60008060408385031215610fa957600080fd5b8235610fb481610eaa565b9150602083013567ffffffffffffffff811115610fd057600080fd5b610fdc85828601610f09565b9150509250929050565b80356010811061098357600080fd5b6000806040838503121561100857600080fd5b61101183610fe6565b9150602083013561102181610eaa565b809150509250929050565b60006020828403121561103e57600080fd5b813567ffffffffffffffff8082111561105657600080fd5b9083019060c0828603121561106a57600080fd5b611072610ee0565b823561107d81610eaa565b8152602083013561108d81610eaa565b602082015260408301356110a081610eaa565b60408201526110b160608401610ebf565b60608201526110c260808401610ebf565b608082015260a0830135828111156110d957600080fd5b6110e587828601610f09565b60a08301525095945050505050565b60006020828403121561110657600080fd5b813561111181610eaa565b9392505050565b60006020828403121561112a57600080fd5b61111182610fe6565b6000815180845260005b818110156111595760208185018101518683018201520161113d565b506000602082860101526020601f19601f83011685010191505092915050565b60208152600060018060a01b038084511660208401528060208501511660408401528060408501511660608401528060608501511660808401528060808501511660a08401525060a083015160c0808401526111d860e0840182611133565b949350505050565b634e487b7160e01b600052602160045260246000fd5b600b8110611206576112066111e0565b9052565b6001600160e01b0319831681526040810161111160208301846111f6565b6020815260006111116020830184611133565b60006020828403121561124d57600080fd5b8151801515811461111157600080fd5b634e487b7160e01b600052603260045260246000fd5b60006001820161129357634e487b7160e01b600052601160045260246000fd5b5060010190565b60208101601083106112ae576112ae6111e0565b91905290565b600181811c908216806112c857607f821691505b6020821081036112e857634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156107ae57600081815260208120601f850160051c810160208610156113155750805b601f850160051c820191505b8181101561133457828155600101611321565b505050505050565b815167ffffffffffffffff81111561135657611356610eca565b61136a8161136484546112b4565b846112ee565b602080601f83116001811461139f57600084156113875750858301515b600019600386901b1c1916600185901b178555611334565b600085815260208120601f198616915b828110156113ce578886015182559484019460019091019084016113af565b50858210156113ec5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6020810161140a82846111f6565b92915050565b6040810161141e82856111f6565b826020830152939250505056fea264697066735822122091a8a709868deb3194f783de7e7eda583eccec29b46aecd3eb33f207b70ac15364736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106100885760003560e01c806392d487561161005b57806392d48756146100d0578063c4d66de8146100e3578063de981f1b146100f6578063f46609401461012657600080fd5b806368a5c1231461008d578063865e6fd3146100a25780639029bc60146100b557806391486604146100c8575b600080fd5b6100a061009b366004610f96565b610146565b005b6100a06100b0366004610ff5565b6101f3565b6100a06100c336600461102c565b610212565b6100a0610373565b6100a06100de36600461102c565b6107b3565b6100a06100f13660046110f4565b6107f9565b610109610104366004611118565b61090d565b6040516001600160a01b0390911681526020015b60405180910390f35b6101396101343660046110f4565b610988565b60405161011d9190611179565b600061015183610ab8565b60028101549091506001600160a01b0316331461019a576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b60405180910390fd5b6101a382610af3565b6101ad8183610b33565b826001600160a01b03167fe13225a225fbfeebd9d707546f3d7adee5d72738ac686cc5b97266c49745a56b836040516101e69190611228565b60405180910390a2505050565b6101fb610b79565b61020481610bd5565b61020e8282610c0b565b5050565b80602001516001600160a01b031681600001516001600160a01b03161461024c5760405163491db47560e01b815260040160405180910390fd5b80516001600160a01b03908116600090815260208190526040902080549091161561028a5760405163249b38f960e01b815260040160405180910390fd5b81604001516001600160a01b0316336001600160a01b031614158061033257506102b4600861090d565b602083015160408085015190516304d971ab60e01b81526001600160a01b03928316600482015290821660248201529116906304d971ab90604401602060405180830381865afa15801561030c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610330919061123b565b155b15610360576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b61036982610caf565b61020e8183610cf8565b466107e4146103b75760405162461bcd60e51b815260206004820152601060248201526f1b5a5cdb585d18da0818da185a5b925160821b6044820152606401610191565b734d58ea7231c394d5804e8b06b1365915f906e27f33146104115760405162461bcd60e51b81526020600482015260146024820152733737ba1036b0b4b73732ba103232b83637bcb2b960611b6044820152606401610191565b604080516103a0810182527352c0dcd83aa1999ba6c3b0324c8299e30207373c815273f41af21f0a800dc4d86efb14ad46cfb9884fdf38602082015273e07d7e56588a6fd860c5073c70a099658c060f3d918101919091527352349003240770727900b06a3b3a90f5c0219ade6060820152732bddcaae1c6ccd53e436179b3fc07307ee6f3ef8608082015273ec702628f44c31acc56c3a59555be47e1f16eb1e60a082015273bd4bf317da1928cc2f9f4da9006401f3944a0ab560c082015273d11d9842babd5209b9b1155e46f5878c989125b760e08201527361089875ff9e506ae78c7fe9f7c388416520e38661010082015273d7fef73d95ccedb26483fd3c6c48393e507081596101208201527347cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1610140820152738eec4f1c0878f73e8e09c1be78ac1465cc16544d610160820152739b959d27840a31988410ee69991bcf0110d61f0261018082015273ee11d2016e9f2fae606b2f12986811f4abbe62156101a082015273ca54a1700e0403dcb531f8db4ae3847758b90b016101c0820152734e7ea047ec7e95c7a02cb117128b94ccdd8356bf6101e0820152736e46924371d0e910769aabe0d867590deac2068461020082015273ae53daac1bf3c4633d4921b8c3f8d579e757f5bc6102208201527305ad3ded6fcc510324af8e2631717af6da5c8b5b6102408201527332d619dc6188409cebbc52f921ab306f07db085b61026082015273210744c64eea863cf0f972e5aebc683b98fb198461028082015273edcafc4ad8097c2012980a2a7087d74b86bddaf96102a082015273fc3e31519b551bd594235dd0ef014375a87c4e216102c0820152736aaabf51c5f6d2d93212cf7dad73d67afa0148d06102e08201527322c23429e46e7944d2918f2b368b799b11c417c16103008201527303a7b98c226225e330d11d1b9177891391fa4f806103208201527320238eb5643d4d7b7ab3c30f3bf7b8e2b85ca1e76103408201527307d28f88d677c4056ea6722aa35d92903b2a63da61036082015273262b9fcfe8cfa900af4d1f5c20396e969b9655dd6103808201526000805b601d8110156107ae576000808483601d81106107445761074461125d565b60200201516001600160a01b03166001600160a01b0316815260200190815260200160002091508281601d811061077d5761077d61125d565b602002015182546001600160a01b0319166001600160a01b03909116178255806107a681611273565b915050610726565b505050565b6107bb610b79565b80516001600160a01b0390811660009081526020819052604090208054909116156103695760405163249b38f960e01b815260040160405180910390fd5b603354610100900460ff16158080156108195750603354600160ff909116105b806108335750303b158015610833575060335460ff166001145b6108965760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610191565b6033805460ff1916600117905580156108b9576033805461ff0019166101001790555b6108c4600883610c0b565b801561020e576033805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610944576109446111e0565b60ff1681526020810191909152604001600020546001600160a01b0316905080610983578160405163409140df60e11b8152600401610191919061129a565b919050565b6040805160c0810182526000808252602082018190529181018290526060808201839052608082019290925260a08101919091526001600160a01b0380831660009081526020818152604091829020825160c081018452815485168152600182015485169281019290925260028101548416928201929092526003820154831660608201526004820154909216608083015260058101805460a084019190610a2f906112b4565b80601f0160208091040260200160405190810160405280929190818152602001828054610a5b906112b4565b8015610aa85780601f10610a7d57610100808354040283529160200191610aa8565b820191906000526020600020905b815481529060010190602001808311610a8b57829003601f168201915b5050505050815250509050919050565b6001600160a01b0380821660009081526020819052604090208054909116610983576040516334152acb60e11b815260040160405180910390fd5b805160208083019190912060009081526001909152604090205460ff1615610b305780604051630f32bad960e31b81526004016101919190611228565b50565b60058201610b41828261133c565b506001806000610b5684805160209091012090565b81526020810191909152604001600020805460ff19169115159190911790555050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610bd3576000356001600160e01b0319166001604051620f948f60ea1b815260040161019192919061120a565b565b806001600160a01b03163b600003610b3057604051630bfc64a360e21b81526001600160a01b0382166004820152602401610191565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610c4157610c416111e0565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115610c8257610c826111e0565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610cbe60098260200151610de7565b610ccd60048260400151610de7565b610cdc600a8260600151610de7565b610ceb600a8260800151610e16565b610b308160a00151610af3565b805182546001600160a01b039182166001600160a01b031991821617845560208084015160018087018054928616928516831790556000918252918290526040808220805460ff199081168517909155818701516002890180549188169187168217905583528183208054821685179055606087015160038901805491909716951685179095559281529190912080549092161790556080810151610d9e908390610e5d565b610dac828260a00151610b33565b80516040516001600160a01b03909116907fc9da0ae38bd4761b72da1045c9b2618f0cd991dcac01e1f9bbf68474025f074390600090a25050565b6001600160a01b038116610e1057816040516315fb58b960e21b815260040161019191906113fc565b61020e82825b6001600160a01b03811660009081526001602052604090205460ff161561020e5781816001600160a01b031660405163720b355560e11b8152600401610191929190611410565b6004820180546001600160a01b0319166001600160a01b0383169081179091551561020e576001600160a01b03166000908152600160208190526040909120805460ff1916909117905550565b6001600160a01b0381168114610b3057600080fd5b803561098381610eaa565b634e487b7160e01b600052604160045260246000fd5b60405160c0810167ffffffffffffffff81118282101715610f0357610f03610eca565b60405290565b600082601f830112610f1a57600080fd5b813567ffffffffffffffff80821115610f3557610f35610eca565b604051601f8301601f19908116603f01168101908282118183101715610f5d57610f5d610eca565b81604052838152866020858801011115610f7657600080fd5b836020870160208301376000602085830101528094505050505092915050565b60008060408385031215610fa957600080fd5b8235610fb481610eaa565b9150602083013567ffffffffffffffff811115610fd057600080fd5b610fdc85828601610f09565b9150509250929050565b80356010811061098357600080fd5b6000806040838503121561100857600080fd5b61101183610fe6565b9150602083013561102181610eaa565b809150509250929050565b60006020828403121561103e57600080fd5b813567ffffffffffffffff8082111561105657600080fd5b9083019060c0828603121561106a57600080fd5b611072610ee0565b823561107d81610eaa565b8152602083013561108d81610eaa565b602082015260408301356110a081610eaa565b60408201526110b160608401610ebf565b60608201526110c260808401610ebf565b608082015260a0830135828111156110d957600080fd5b6110e587828601610f09565b60a08301525095945050505050565b60006020828403121561110657600080fd5b813561111181610eaa565b9392505050565b60006020828403121561112a57600080fd5b61111182610fe6565b6000815180845260005b818110156111595760208185018101518683018201520161113d565b506000602082860101526020601f19601f83011685010191505092915050565b60208152600060018060a01b038084511660208401528060208501511660408401528060408501511660608401528060608501511660808401528060808501511660a08401525060a083015160c0808401526111d860e0840182611133565b949350505050565b634e487b7160e01b600052602160045260246000fd5b600b8110611206576112066111e0565b9052565b6001600160e01b0319831681526040810161111160208301846111f6565b6020815260006111116020830184611133565b60006020828403121561124d57600080fd5b8151801515811461111157600080fd5b634e487b7160e01b600052603260045260246000fd5b60006001820161129357634e487b7160e01b600052601160045260246000fd5b5060010190565b60208101601083106112ae576112ae6111e0565b91905290565b600181811c908216806112c857607f821691505b6020821081036112e857634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156107ae57600081815260208120601f850160051c810160208610156113155750805b601f850160051c820191505b8181101561133457828155600101611321565b505050505050565b815167ffffffffffffffff81111561135657611356610eca565b61136a8161136484546112b4565b846112ee565b602080601f83116001811461139f57600084156113875750858301515b600019600386901b1c1916600185901b178555611334565b600085815260208120601f198616915b828110156113ce578886015182559484019460019091019084016113af565b50858210156113ec5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6020810161140a82846111f6565b92915050565b6040810161141e82856111f6565b826020830152939250505056fea264697066735822122091a8a709868deb3194f783de7e7eda583eccec29b46aecd3eb33f207b70ac15364736f6c63430008110033", + "devdoc": { + "errors": { + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrDuplicatedInfo(uint8,uint256)": [ + { + "details": "Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key, and with value type of `infoType`." + } + ], + "ErrExistentProfile()": [ + { + "details": "Error of already existed profile." + } + ], + "ErrIdAndConsensusDiffer()": [ + { + "details": "Error when create a new profile whose id and consensus are not identical." + } + ], + "ErrNonExistentProfile()": [ + { + "details": "Error of non existed profile." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "addNewProfile((address,address,address,address,address,bytes))": { + "details": "Requirements: - The profile must not be existent before. - Only contract admin can call this method." + }, + "changePubkey(address,bytes)": { + "details": "Requirements: - The profile must be existed. - Only user with candidate admin role can call this method. - New public key must not be duplicated." + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getId2Profile(address)": { + "details": "Getter to query full `profile` from `id` address." + }, + "registerProfile((address,address,address,address,address,bytes))": { + "details": "Requirements: - The profile must not be existent before. - Only user with candidate admin role can call this method." + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "addNewProfile((address,address,address,address,address,bytes))": { + "notice": "Add a new profile." + }, + "changePubkey(address,bytes)": { + "notice": "The candidate admin changes the public key." + }, + "registerProfile((address,address,address,address,address,bytes))": { + "notice": "The candidate admin registers a new profile." + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 2947, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "_id2Profile", + "offset": 0, + "slot": "0", + "type": "t_mapping(t_address,t_struct(CandidateProfile)1339_storage)" + }, + { + "astId": 2952, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "_registry", + "offset": 0, + "slot": "1", + "type": "t_mapping(t_uint256,t_bool)" + }, + { + "astId": 2957, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "__gap", + "offset": 0, + "slot": "2", + "type": "t_array(t_bytes32)49_storage" + }, + { + "astId": 581, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "_initialized", + "offset": 0, + "slot": "51", + "type": "t_uint8" + }, + { + "astId": 584, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "_initializing", + "offset": 1, + "slot": "51", + "type": "t_bool" + } + ], + "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, + "t_address_payable": { + "encoding": "inplace", + "label": "address payable", + "numberOfBytes": "20" + }, + "t_array(t_bytes32)49_storage": { + "base": "t_bytes32", + "encoding": "inplace", + "label": "bytes32[49]", + "numberOfBytes": "1568" + }, + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_bytes32": { + "encoding": "inplace", + "label": "bytes32", + "numberOfBytes": "32" + }, + "t_bytes_storage": { + "encoding": "bytes", + "label": "bytes", + "numberOfBytes": "32" + }, + "t_mapping(t_address,t_struct(CandidateProfile)1339_storage)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => struct IProfile.CandidateProfile)", + "numberOfBytes": "32", + "value": "t_struct(CandidateProfile)1339_storage" + }, + "t_mapping(t_uint256,t_bool)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => bool)", + "numberOfBytes": "32", + "value": "t_bool" + }, + "t_struct(CandidateProfile)1339_storage": { + "encoding": "inplace", + "label": "struct IProfile.CandidateProfile", + "members": [ + { + "astId": 1323, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "id", + "offset": 0, + "slot": "0", + "type": "t_address" + }, + { + "astId": 1326, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "consensus", + "offset": 0, + "slot": "1", + "type": "t_address" + }, + { + "astId": 1329, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "admin", + "offset": 0, + "slot": "2", + "type": "t_address" + }, + { + "astId": 1332, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "treasury", + "offset": 0, + "slot": "3", + "type": "t_address_payable" + }, + { + "astId": 1335, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "governor", + "offset": 0, + "slot": "4", + "type": "t_address" + }, + { + "astId": 1338, + "contract": "contracts/ronin/profile/Profile.sol:Profile", + "label": "pubkey", + "offset": 0, + "slot": "5", + "type": "t_bytes_storage" + } + ], + "numberOfBytes": "192" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/ProfileProxy.json b/deployments/ronin-mainnet/ProfileProxy.json new file mode 100644 index 000000000..c28deacd7 --- /dev/null +++ b/deployments/ronin-mainnet/ProfileProxy.json @@ -0,0 +1,273 @@ +{ + "address": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "transactionIndex": 2, + "gasUsed": "689910", + "logsBloom": "0x00000000080000000000000000000000400000000000000000000000000000000000000000000000000000000000000000000000000080010000000000000004000000000000800000000000000002000000000000000000000000800000000000000000000000000000000000000000000000800000000000020004000000000080000000000000000000000000000000000000000080000000000000800000000000000000000000000000000400000000000000000000000000000000000040000020000000000000000000040000000000000400001010000000000000000000000000000000000002000000000000000000014000000000000000000000", + "blockHash": "0x56af0e37317cb6042bd4fe86e3353d664f6874f860edcd7eec8d9c8b684418a0", + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "logs": [ + { + "transactionIndex": 2, + "blockNumber": 28139101, + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "address": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x00000000000000000000000084e66e2d8b634036c6b719a72ea49d3923cf5c4c" + ], + "data": "0x", + "logIndex": 7, + "blockHash": "0x56af0e37317cb6042bd4fe86e3353d664f6874f860edcd7eec8d9c8b684418a0" + }, + { + "transactionIndex": 2, + "blockNumber": 28139101, + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "address": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000008", + "0x000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "data": "0x", + "logIndex": 8, + "blockHash": "0x56af0e37317cb6042bd4fe86e3353d664f6874f860edcd7eec8d9c8b684418a0" + }, + { + "transactionIndex": 2, + "blockNumber": 28139101, + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "address": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "topics": [ + "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000001", + "logIndex": 9, + "blockHash": "0x56af0e37317cb6042bd4fe86e3353d664f6874f860edcd7eec8d9c8b684418a0" + }, + { + "transactionIndex": 2, + "blockNumber": 28139101, + "transactionHash": "0xcf8f95df247fef18f9ffee234b7f1f6a7495372bfc0b98f35714a5573accd8d7", + "address": "0x840EBf1CA767CB690029E91856A357a43B85d035", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000004d58ea7231c394d5804e8b06b1365915f906e27f", + "logIndex": 10, + "blockHash": "0x56af0e37317cb6042bd4fe86e3353d664f6874f860edcd7eec8d9c8b684418a0" + } + ], + "blockNumber": 28139101, + "cumulativeGasUsed": "1039993", + "status": 1, + "byzantium": true + }, + "args": [ + "0x84E66E2D8b634036c6b719a72EA49d3923Cf5c4C", + "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "0xc4d66de8000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f" + ], + "numDeployments": 1, + "solcInputHash": "c681844a462c08b610099ffca6511819", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405260405162000f5f38038062000f5f83398101604081905262000026916200048d565b8282828281620000398282600062000053565b506200004790508262000090565b505050505050620005c0565b6200005e83620000eb565b6000825111806200006c5750805b156200008b576200008983836200012d60201b620002911760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f620000bb6200015c565b604080516001600160a01b03928316815291841660208301520160405180910390a1620000e88162000195565b50565b620000f6816200024a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b606062000155838360405180606001604052806027815260200162000f3860279139620002fe565b9392505050565b60006200018660008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b546001600160a01b0316919050565b6001600160a01b038116620002005760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b806200022960008051602062000f1883398151915260001b620003e460201b6200024d1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b6200026081620003e760201b620002bd1760201c565b620002c45760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401620001f7565b80620002297f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc60001b620003e460201b6200024d1760201c565b60606001600160a01b0384163b620003685760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401620001f7565b600080856001600160a01b0316856040516200038591906200056d565b600060405180830381855af49150503d8060008114620003c2576040519150601f19603f3d011682016040523d82523d6000602084013e620003c7565b606091505b509092509050620003da828286620003f6565b9695505050505050565b90565b6001600160a01b03163b151590565b606083156200040757508162000155565b825115620004185782518084602001fd5b8160405162461bcd60e51b8152600401620001f791906200058b565b80516001600160a01b03811681146200044c57600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b83811015620004845781810151838201526020016200046a565b50506000910152565b600080600060608486031215620004a357600080fd5b620004ae8462000434565b9250620004be6020850162000434565b60408501519092506001600160401b0380821115620004dc57600080fd5b818601915086601f830112620004f157600080fd5b81518181111562000506576200050662000451565b604051601f8201601f19908116603f0116810190838211818310171562000531576200053162000451565b816040528281528960208487010111156200054b57600080fd5b6200055e83602083016020880162000467565b80955050505050509250925092565b600082516200058181846020870162000467565b9190910192915050565b6020815260008251806020840152620005ac81604085016020870162000467565b601f01601f19169190910160400192915050565b61094880620005d06000396000f3fe6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100595760003560e01c80633659cfe6146100705780634bb5274a146100905780634f1ef286146100a35780635c60da1b146100b65780638f283970146100e7578063f851a4401461010757610068565b366100685761006661011c565b005b61006661011c565b34801561007c57600080fd5b5061006661008b366004610713565b610136565b61006661009e366004610744565b610173565b6100666100b13660046107f5565b6101b8565b3480156100c257600080fd5b506100cb61021f565b6040516001600160a01b03909116815260200160405180910390f35b3480156100f357600080fd5b50610066610102366004610713565b610250565b34801561011357600080fd5b506100cb610270565b6101246102cc565b61013461012f610361565b61036b565b565b61013e61038a565b6001600160a01b0316330361016b57610168816040518060200160405280600081525060006103bd565b50565b61016861011c565b61017b61038a565b6001600160a01b0316330361016b576000610194610361565b9050600080835160208501845af43d6000803e8080156101b3573d6000f35b3d6000fd5b6101c061038a565b6001600160a01b03163303610217576102128383838080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250600192506103bd915050565b505050565b61021261011c565b600061022961038a565b6001600160a01b0316330361024557610240610361565b905090565b61024d61011c565b90565b61025861038a565b6001600160a01b0316330361016b57610168816103e8565b600061027a61038a565b6001600160a01b031633036102455761024061038a565b60606102b683836040518060600160405280602781526020016108ec6027913961043c565b9392505050565b6001600160a01b03163b151590565b6102d461038a565b6001600160a01b031633036101345760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f78792074617267606482015261195d60f21b608482015260a4015b60405180910390fd5b6000610240610519565b3660008037600080366000845af43d6000803e8080156101b3573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b6103c683610541565b6000825111806103d35750805b15610212576103e28383610291565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f61041161038a565b604080516001600160a01b03928316815291841660208301520160405180910390a161016881610581565b60606001600160a01b0384163b6104a45760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b6064820152608401610358565b600080856001600160a01b0316856040516104bf919061089c565b600060405180830381855af49150503d80600081146104fa576040519150601f19603f3d011682016040523d82523d6000602084013e6104ff565b606091505b509150915061050f82828661062a565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6103ae565b61054a81610663565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166105e65760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b6064820152608401610358565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80546001600160a01b0319166001600160a01b039290921691909117905550565b606083156106395750816102b6565b8251156106495782518084602001fd5b8160405162461bcd60e51b815260040161035891906108b8565b6001600160a01b0381163b6106d05760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b6064820152608401610358565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc610609565b80356001600160a01b038116811461070e57600080fd5b919050565b60006020828403121561072557600080fd5b6102b6826106f7565b634e487b7160e01b600052604160045260246000fd5b60006020828403121561075657600080fd5b813567ffffffffffffffff8082111561076e57600080fd5b818401915084601f83011261078257600080fd5b8135818111156107945761079461072e565b604051601f8201601f19908116603f011681019083821181831017156107bc576107bc61072e565b816040528281528760208487010111156107d557600080fd5b826020860160208301376000928101602001929092525095945050505050565b60008060006040848603121561080a57600080fd5b610813846106f7565b9250602084013567ffffffffffffffff8082111561083057600080fd5b818601915086601f83011261084457600080fd5b81358181111561085357600080fd5b87602082850101111561086557600080fd5b6020830194508093505050509250925092565b60005b8381101561089357818101518382015260200161087b565b50506000910152565b600082516108ae818460208701610878565b9190910192915050565b60208152600082518060208401526108d7816040850160208701610878565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a2646970667358221220bebb3300d99b476bd2f64bbccc422fc4bd31a9389ff1c675d867f0aac8101a5664736f6c63430008110033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function. Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": {}, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/RoninBridgeManager.json b/deployments/ronin-mainnet/RoninBridgeManager.json new file mode 100644 index 000000000..6b60c8c1d --- /dev/null +++ b/deployments/ronin-mainnet/RoninBridgeManager.json @@ -0,0 +1,2198 @@ +{ + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "abi": [ + { + "inputs": [ + { + "internalType": "uint256", + "name": "num", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "roninChainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryDuration", + "type": "uint256" + }, + { + "internalType": "address", + "name": "bridgeContract", + "type": "address" + }, + { + "internalType": "address[]", + "name": "callbackRegisters", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "voter", + "type": "address" + } + ], + "name": "ErrAlreadyVoted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "ErrBridgeOperatorAlreadyExisted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "ErrBridgeOperatorUpdateFailed", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrCurrentProposalIsNotCompleted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrDuplicated", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ErrInsufficientGas", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidArguments", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "actual", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expected", + "type": "uint256" + } + ], + "name": "ErrInvalidChainId", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidExpiryTimestamp", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidOrder", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "actual", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "expected", + "type": "bytes32" + } + ], + "name": "ErrInvalidProposal", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidProposalNonce", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidSignatures", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidVoteWeight", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrOnlySelfCall", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForEmptyVote", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "interfaceId", + "type": "bytes4" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrUnsupportedInterface", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrUnsupportedVoteType", + "type": "error" + }, + { + "inputs": [], + "name": "ErrVoteIsFinalized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrZeroAddress", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "governor", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "fromBridgeOperator", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "toBridgeOperator", + "type": "address" + } + ], + "name": "BridgeOperatorUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "BridgeOperatorsAdded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "BridgeOperatorsRemoved", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "round", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "bytes32", + "name": "globalProposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct GlobalProposal.GlobalProposalDetail", + "name": "globalProposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "address", + "name": "creator", + "type": "address" + } + ], + "name": "GlobalProposalCreated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes", + "name": "callData", + "type": "bytes" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "registers", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "bool[]", + "name": "statuses", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "bytes[]", + "name": "returnDatas", + "type": "bytes[]" + } + ], + "name": "Notified", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalApproved", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "round", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "indexed": false, + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "indexed": false, + "internalType": "address", + "name": "creator", + "type": "address" + } + ], + "name": "ProposalCreated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "indexed": false, + "internalType": "bool[]", + "name": "successCalls", + "type": "bool[]" + }, + { + "indexed": false, + "internalType": "bytes[]", + "name": "returnDatas", + "type": "bytes[]" + } + ], + "name": "ProposalExecuted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalExpired", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "duration", + "type": "uint256" + } + ], + "name": "ProposalExpiryDurationChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + } + ], + "name": "ProposalRejected", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "proposalHash", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "voter", + "type": "address" + }, + { + "indexed": false, + "internalType": "enum Ballot.VoteType", + "name": "support", + "type": "uint8" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "weight", + "type": "uint256" + } + ], + "name": "ProposalVoted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum GlobalProposal.TargetOption", + "name": "targetOption", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "TargetOptionUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "ThresholdUpdated", + "type": "event" + }, + { + "inputs": [], + "name": "DOMAIN_SEPARATOR", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint96[]", + "name": "voteWeights", + "type": "uint96[]" + }, + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "addBridgeOperators", + "outputs": [ + { + "internalType": "bool[]", + "name": "addeds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct GlobalProposal.GlobalProposalDetail", + "name": "globalProposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "name": "castGlobalProposalBySignatures", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "name": "castProposalBySignatures", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct Proposal.ProposalDetail", + "name": "proposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType", + "name": "support", + "type": "uint8" + } + ], + "name": "castProposalVoteForCurrentNetwork", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_voteWeight", + "type": "uint256" + } + ], + "name": "checkThreshold", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_round", + "type": "uint256" + } + ], + "name": "deleteExpired", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "getBridgeOperatorOf", + "outputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + } + ], + "name": "getBridgeOperatorWeight", + "outputs": [ + { + "internalType": "uint96", + "name": "weight", + "type": "uint96" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getBridgeOperators", + "outputs": [ + { + "internalType": "address[]", + "name": "", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getCallbackRegisters", + "outputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getFullBridgeOperatorInfos", + "outputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + }, + { + "internalType": "uint96[]", + "name": "weights", + "type": "uint96[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "round_", + "type": "uint256" + } + ], + "name": "getGlobalProposalSignatures", + "outputs": [ + { + "internalType": "address[]", + "name": "voters", + "type": "address[]" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "governor", + "type": "address" + } + ], + "name": "getGovernorWeight", + "outputs": [ + { + "internalType": "uint96", + "name": "weight", + "type": "uint96" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "getGovernorWeights", + "outputs": [ + { + "internalType": "uint96[]", + "name": "weights", + "type": "uint96[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getGovernors", + "outputs": [ + { + "internalType": "address[]", + "name": "", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "getGovernorsOf", + "outputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getProposalExpiryDuration", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_round", + "type": "uint256" + } + ], + "name": "getProposalSignatures", + "outputs": [ + { + "internalType": "address[]", + "name": "_voters", + "type": "address[]" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "_supports", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "_signatures", + "type": "tuple[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "num_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getTotalWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "round_", + "type": "uint256" + }, + { + "internalType": "address", + "name": "voter", + "type": "address" + } + ], + "name": "globalProposalVoted", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "isBridgeOperator", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "minimumVoteWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_round", + "type": "uint256" + }, + { + "internalType": "address", + "name": "_voter", + "type": "address" + } + ], + "name": "proposalVoted", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "_targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "_calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "_gasAmounts", + "type": "uint256[]" + } + ], + "name": "propose", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "name": "proposeGlobal", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct GlobalProposal.GlobalProposalDetail", + "name": "globalProposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "supports_", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "signatures", + "type": "tuple[]" + } + ], + "name": "proposeGlobalProposalStructAndCastVotes", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + }, + { + "internalType": "enum Ballot.VoteType", + "name": "support", + "type": "uint8" + } + ], + "name": "proposeProposalForCurrentNetwork", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "values", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "calldatas", + "type": "bytes[]" + }, + { + "internalType": "uint256[]", + "name": "gasAmounts", + "type": "uint256[]" + } + ], + "internalType": "struct Proposal.ProposalDetail", + "name": "_proposal", + "type": "tuple" + }, + { + "internalType": "enum Ballot.VoteType[]", + "name": "_supports", + "type": "uint8[]" + }, + { + "components": [ + { + "internalType": "uint8", + "name": "v", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "r", + "type": "bytes32" + }, + { + "internalType": "bytes32", + "name": "s", + "type": "bytes32" + } + ], + "internalType": "struct SignatureConsumer.Signature[]", + "name": "_signatures", + "type": "tuple[]" + } + ], + "name": "proposeProposalStructAndCastVotes", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "name": "registerCallbacks", + "outputs": [ + { + "internalType": "bool[]", + "name": "registereds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "bridgeOperators", + "type": "address[]" + } + ], + "name": "removeBridgeOperators", + "outputs": [ + { + "internalType": "bool[]", + "name": "removeds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + } + ], + "name": "resolveTargets", + "outputs": [ + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "round", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + } + ], + "name": "setThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "governors", + "type": "address[]" + } + ], + "name": "sumGovernorsWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "sum", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "totalBridgeOperator", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "registers", + "type": "address[]" + } + ], + "name": "unregisterCallbacks", + "outputs": [ + { + "internalType": "bool[]", + "name": "unregistereds", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newBridgeOperator", + "type": "address" + } + ], + "name": "updateBridgeOperator", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum GlobalProposal.TargetOption[]", + "name": "targetOptions", + "type": "uint8[]" + }, + { + "internalType": "address[]", + "name": "targets", + "type": "address[]" + } + ], + "name": "updateManyTargetOption", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "vote", + "outputs": [ + { + "internalType": "enum VoteStatusConsumer.VoteStatus", + "name": "status", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "hash", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "againstVoteWeight", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "forVoteWeight", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expiryTimestamp", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + } + ], + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "transactionIndex": 1, + "gasUsed": "5957731", + "logsBloom": "0x042202000000000000000000000000000000800000002000001000080000000400004000000000000080000000000040000100000200040100000000022c0000010000000000800000000000000000000000000000040000000400000000000008000000020000140000000000000800000000000000400000000000000000000000000080000000000000000000004000000000000400000000000400000000000000000000001000010100000000400020000000800000202008000000400040000100000000000000000000000000080000808000001000000000000060000080020000000000100000000000800100000000008000008000000000001000", + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67", + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "logs": [ + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8", + "0x0000000000000000000000000000000000000000000000000000000000000001", + "0x0000000000000000000000000000000000000000000000000000000000000046", + "0x0000000000000000000000000000000000000000000000000000000000000064" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 1, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c59", + "0x0000000000000000000000000000000000000000000000000000000000000002", + "0x0000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df" + ], + "data": "0x", + "logIndex": 2, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0xc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b63" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000018000000000000000000000000000000000000000000000000000000000000001c0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000000c45ebae8a000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000000100000000000000000000000032015e8b982c61bc8a593816fdbf03a603eec82300000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000205ebae8a000000000000000000000000000000000000000000000000000000000", + "logIndex": 3, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b78" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000010000000000000000000000003200a8eb56767c3760e108aa27c65bfff036d8e6000000000000000000000000000000000000000000000000000000000000000100000000000000000000000032015e8b982c61bc8a593816fdbf03a603eec823", + "logIndex": 4, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0xe5cd1c123a8cf63fa1b7229678db61fe8ae99dbbd27889370b6667c8cae97da1", + "0x0000000000000000000000000000000000000000000000000000000000127500" + ], + "data": "0x", + "logIndex": 5, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a" + ], + "data": "0x", + "logIndex": 6, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000001", + "0x0000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df" + ], + "data": "0x", + "logIndex": 7, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000002", + "0x000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad1" + ], + "data": "0x", + "logIndex": 8, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000003", + "0x000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24" + ], + "data": "0x", + "logIndex": 9, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + }, + { + "transactionIndex": 1, + "blockNumber": 28595551, + "transactionHash": "0xb1b498b06977573910a36b0e06d0ff47cf567104f698076f856ecbd815428589", + "address": "0x5FA49E6CA54a9daa8eCa4F403ADBDE5ee075D84a", + "topics": [ + "0x356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d", + "0x0000000000000000000000000000000000000000000000000000000000000004", + "0x0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2" + ], + "data": "0x", + "logIndex": 10, + "blockHash": "0x244bce6409fa22944be883f76af04c437af3d1dbaf8f21aac55d9aa9ca646b67" + } + ], + "blockNumber": 28595551, + "cumulativeGasUsed": "6045394", + "status": 1, + "byzantium": true + }, + "args": [ + 70, + 100, + 2020, + 1209600, + "0x0cf8ff40a508bdbc39fbe1bb679dcba64e65c7df", + [ + "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24" + ], + [ + "0x32015E8B982c61bc8a593816FdBf03A603EEC823" + ], + [ + "0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6" + ], + [ + 100 + ], + [ + 1, + 2, + 3, + 4 + ], + [ + "0x0cf8ff40a508bdbc39fbe1bb679dcba64e65c7df", + "0x796A163A21e9a659fc9773166e0AfDC1eB01aaD1", + "0x273cdA3AFE17eB7BcB028b058382A9010ae82B24", + "0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2" + ] + ], + "numDeployments": 2, + "solcInputHash": "dc057a85cb82f6c5109f62edfa65ae8d", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"num\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"roninChainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryDuration\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"bridgeContract\",\"type\":\"address\"},{\"internalType\":\"address[]\",\"name\":\"callbackRegisters\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"}],\"name\":\"ErrAlreadyVoted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"ErrBridgeOperatorAlreadyExisted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"ErrBridgeOperatorUpdateFailed\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCurrentProposalIsNotCompleted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrDuplicated\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ErrInsufficientGas\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidArguments\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"actual\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expected\",\"type\":\"uint256\"}],\"name\":\"ErrInvalidChainId\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidExpiryTimestamp\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidOrder\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"actual\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"expected\",\"type\":\"bytes32\"}],\"name\":\"ErrInvalidProposal\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidProposalNonce\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidSignatures\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidVoteWeight\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrOnlySelfCall\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForEmptyVote\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrUnsupportedInterface\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrUnsupportedVoteType\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrVoteIsFinalized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrZeroAddress\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"fromBridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"toBridgeOperator\",\"type\":\"address\"}],\"name\":\"BridgeOperatorUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorsAdded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorsRemoved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"round\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"globalProposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct GlobalProposal.GlobalProposalDetail\",\"name\":\"globalProposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"creator\",\"type\":\"address\"}],\"name\":\"GlobalProposalCreated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes\",\"name\":\"callData\",\"type\":\"bytes\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"statuses\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"bytes[]\",\"name\":\"returnDatas\",\"type\":\"bytes[]\"}],\"name\":\"Notified\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalApproved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"round\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"indexed\":false,\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"creator\",\"type\":\"address\"}],\"name\":\"ProposalCreated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"indexed\":false,\"internalType\":\"bool[]\",\"name\":\"successCalls\",\"type\":\"bool[]\"},{\"indexed\":false,\"internalType\":\"bytes[]\",\"name\":\"returnDatas\",\"type\":\"bytes[]\"}],\"name\":\"ProposalExecuted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalExpired\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"duration\",\"type\":\"uint256\"}],\"name\":\"ProposalExpiryDurationChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"}],\"name\":\"ProposalRejected\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"proposalHash\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"enum Ballot.VoteType\",\"name\":\"support\",\"type\":\"uint8\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"}],\"name\":\"ProposalVoted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum GlobalProposal.TargetOption\",\"name\":\"targetOption\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"TargetOptionUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"inputs\":[],\"name\":\"DOMAIN_SEPARATOR\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint96[]\",\"name\":\"voteWeights\",\"type\":\"uint96[]\"},{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"addBridgeOperators\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"addeds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct GlobalProposal.GlobalProposalDetail\",\"name\":\"globalProposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"name\":\"castGlobalProposalBySignatures\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"name\":\"castProposalBySignatures\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"proposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType\",\"name\":\"support\",\"type\":\"uint8\"}],\"name\":\"castProposalVoteForCurrentNetwork\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_round\",\"type\":\"uint256\"}],\"name\":\"deleteExpired\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"getBridgeOperatorOf\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"getBridgeOperatorWeight\",\"outputs\":[{\"internalType\":\"uint96\",\"name\":\"weight\",\"type\":\"uint96\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeOperators\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCallbackRegisters\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getFullBridgeOperatorInfos\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"uint96[]\",\"name\":\"weights\",\"type\":\"uint96[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"round_\",\"type\":\"uint256\"}],\"name\":\"getGlobalProposalSignatures\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"voters\",\"type\":\"address[]\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"}],\"name\":\"getGovernorWeight\",\"outputs\":[{\"internalType\":\"uint96\",\"name\":\"weight\",\"type\":\"uint96\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"getGovernorWeights\",\"outputs\":[{\"internalType\":\"uint96[]\",\"name\":\"weights\",\"type\":\"uint96[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getGovernors\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"getGovernorsOf\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getProposalExpiryDuration\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_round\",\"type\":\"uint256\"}],\"name\":\"getProposalSignatures\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_voters\",\"type\":\"address[]\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"_supports\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"_signatures\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getTotalWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"round_\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"}],\"name\":\"globalProposalVoted\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"isBridgeOperator\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_round\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_voter\",\"type\":\"address\"}],\"name\":\"proposalVoted\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"_targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"_calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_gasAmounts\",\"type\":\"uint256[]\"}],\"name\":\"propose\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"name\":\"proposeGlobal\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct GlobalProposal.GlobalProposalDetail\",\"name\":\"globalProposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"supports_\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"signatures\",\"type\":\"tuple[]\"}],\"name\":\"proposeGlobalProposalStructAndCastVotes\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"},{\"internalType\":\"enum Ballot.VoteType\",\"name\":\"support\",\"type\":\"uint8\"}],\"name\":\"proposeProposalForCurrentNetwork\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"values\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"calldatas\",\"type\":\"bytes[]\"},{\"internalType\":\"uint256[]\",\"name\":\"gasAmounts\",\"type\":\"uint256[]\"}],\"internalType\":\"struct Proposal.ProposalDetail\",\"name\":\"_proposal\",\"type\":\"tuple\"},{\"internalType\":\"enum Ballot.VoteType[]\",\"name\":\"_supports\",\"type\":\"uint8[]\"},{\"components\":[{\"internalType\":\"uint8\",\"name\":\"v\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"r\",\"type\":\"bytes32\"},{\"internalType\":\"bytes32\",\"name\":\"s\",\"type\":\"bytes32\"}],\"internalType\":\"struct SignatureConsumer.Signature[]\",\"name\":\"_signatures\",\"type\":\"tuple[]\"}],\"name\":\"proposeProposalStructAndCastVotes\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"name\":\"registerCallbacks\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"registereds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"removeBridgeOperators\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"removeds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"}],\"name\":\"resolveTargets\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"round\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"governors\",\"type\":\"address[]\"}],\"name\":\"sumGovernorsWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"sum\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalBridgeOperator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"registers\",\"type\":\"address[]\"}],\"name\":\"unregisterCallbacks\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"unregistereds\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newBridgeOperator\",\"type\":\"address\"}],\"name\":\"updateBridgeOperator\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum GlobalProposal.TargetOption[]\",\"name\":\"targetOptions\",\"type\":\"uint8[]\"},{\"internalType\":\"address[]\",\"name\":\"targets\",\"type\":\"address[]\"}],\"name\":\"updateManyTargetOption\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"vote\",\"outputs\":[{\"internalType\":\"enum VoteStatusConsumer.VoteStatus\",\"name\":\"status\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"hash\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"againstVoteWeight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"forVoteWeight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expiryTimestamp\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrAlreadyVoted(address)\":[{\"details\":\"Error indicating that a voter has already voted.\",\"params\":{\"voter\":\"The address of the voter who has already voted.\"}}],\"ErrBridgeOperatorAlreadyExisted(address)\":[{\"details\":\"Error thrown when attempting to add a bridge operator that already exists in the contract. This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\"}],\"ErrBridgeOperatorUpdateFailed(address)\":[{\"details\":\"Error raised when a bridge operator update operation fails.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator that failed to update.\"}}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrCurrentProposalIsNotCompleted()\":[{\"details\":\"Error thrown when the current proposal is not completed.\"}],\"ErrDuplicated(bytes4)\":[{\"details\":\"Error thrown when a duplicated element is detected in an array.\",\"params\":{\"msgSig\":\"The function signature that invoke the error.\"}}],\"ErrInsufficientGas(bytes32)\":[{\"details\":\"Error thrown when there is insufficient gas to execute a function.\"}],\"ErrInvalidArguments(bytes4)\":[{\"details\":\"Error indicating that arguments are invalid.\"}],\"ErrInvalidChainId(bytes4,uint256,uint256)\":[{\"details\":\"Error indicating that the chain ID is invalid.\",\"params\":{\"actual\":\"Current chain ID that executing function.\",\"expected\":\"Expected chain ID required for the tx to success.\",\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid chain ID.\"}}],\"ErrInvalidExpiryTimestamp()\":[{\"details\":\"Error thrown when an invalid expiry timestamp is provided.\"}],\"ErrInvalidOrder(bytes4)\":[{\"details\":\"Error indicating that an order is invalid.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid order.\"}}],\"ErrInvalidProposal(bytes32,bytes32)\":[{\"details\":\"Error thrown when an invalid proposal is encountered.\",\"params\":{\"actual\":\"The actual value of the proposal.\",\"expected\":\"The expected value of the proposal.\"}}],\"ErrInvalidProposalNonce(bytes4)\":[{\"details\":\"Error indicating that the proposal nonce is invalid.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\"}}],\"ErrInvalidSignatures(bytes4)\":[{\"details\":\"Error indicating that a signature is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that encountered an invalid signature.\"}}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrInvalidVoteWeight(bytes4)\":[{\"details\":\"Error indicating that a vote weight is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that encountered an invalid vote weight.\"}}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrOnlySelfCall(bytes4)\":[{\"details\":\"Error indicating that a function can only be called by the contract itself.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that can only be called by the contract itself.\"}}],\"ErrQueryForEmptyVote()\":[{\"details\":\"Error thrown when querying for an empty vote.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnsupportedInterface(bytes4,address)\":[{\"details\":\"The error indicating an unsupported interface.\",\"params\":{\"addr\":\"The address where the unsupported interface was encountered.\",\"interfaceId\":\"The bytes4 interface identifier that is not supported.\"}}],\"ErrUnsupportedVoteType(bytes4)\":[{\"details\":\"Error indicating that a vote type is not supported.\",\"params\":{\"msgSig\":\"The function signature (bytes4) of the operation that encountered an unsupported vote type.\"}}],\"ErrVoteIsFinalized()\":[{\"details\":\"Error thrown when attempting to interact with a finalized vote.\"}],\"ErrZeroAddress(bytes4)\":[{\"details\":\"Error indicating that given address is null when it should not.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"addBridgeOperators(uint96[],address[],address[])\":{\"details\":\"Adds multiple bridge operators.\",\"params\":{\"bridgeOperators\":\"An array of addresses representing the bridge operators to add.\",\"governors\":\"An array of addresses of hot/cold wallets for bridge operator to update their node address.\"},\"returns\":{\"addeds\":\"An array of booleans indicating whether each bridge operator was added successfully. Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators( voteWeights, governors, bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]); const filteredWeights = weights.filter((_, index) => addeds[index]); const filteredGovernors = governors.filter((_, index) => addeds[index]); // ... (Process or use the information as required) ... ```\"}},\"castGlobalProposalBySignatures((uint256,uint256,uint8[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceProposal-_castGlobalProposalBySignatures`.\"},\"castProposalBySignatures((uint256,uint256,uint256,address[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceProposal-_castProposalBySignatures`.\"},\"castProposalVoteForCurrentNetwork((uint256,uint256,uint256,address[],uint256[],bytes[],uint256[]),uint8)\":{\"details\":\"Casts vote for a proposal on the current network. Requirements: - The method caller is governor.\"},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"deleteExpired(uint256,uint256)\":{\"details\":\"Deletes the expired proposal by its chainId and nonce, without creating a new proposal. Requirements: - The proposal is already created.\"},\"getBridgeOperatorOf(address[])\":{\"details\":\"Returns an array of bridge operators correspoding to governor addresses.\",\"returns\":{\"bridgeOperators\":\"An array containing the addresses of all bridge operators.\"}},\"getBridgeOperatorWeight(address)\":{\"details\":\"External function to retrieve the vote weight of a specific bridge operator.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator to get the vote weight for.\"},\"returns\":{\"weight\":\"The vote weight of the specified bridge operator.\"}},\"getBridgeOperators()\":{\"details\":\"Returns an array of all bridge operators.\",\"returns\":{\"_0\":\"An array containing the addresses of all bridge operators.\"}},\"getCallbackRegisters()\":{\"details\":\"Retrieves the addresses of registered callbacks.\",\"returns\":{\"registers\":\"An array containing the addresses of registered callbacks.\"}},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getFullBridgeOperatorInfos()\":{\"details\":\"Retrieves the full information of all registered bridge operators. This external function allows external callers to obtain the full information of all the registered bridge operators. The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\",\"returns\":{\"bridgeOperators\":\"An array of addresses representing the registered bridge operators.\",\"governors\":\"An array of addresses representing the governors of each bridge operator.\",\"weights\":\"An array of uint256 values representing the vote weights of each bridge operator. Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator. Example Usage: ``` (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos(); for (uint256 i = 0; i < bridgeOperators.length; i++) { // Access individual information for each bridge operator. address governor = governors[i]; address bridgeOperator = bridgeOperators[i]; uint256 weight = weights[i]; // ... (Process or use the information as required) ... } ```\"}},\"getGlobalProposalSignatures(uint256)\":{\"details\":\"See {CommonGovernanceProposal-_getProposalSignatures}\"},\"getGovernorWeight(address)\":{\"details\":\"External function to retrieve the vote weight of a specific governor.\",\"params\":{\"governor\":\"The address of the governor to get the vote weight for.\"},\"returns\":{\"weight\":\"voteWeight The vote weight of the specified governor.\"}},\"getGovernorWeights(address[])\":{\"details\":\"Returns the weights of a list of governor addresses.\"},\"getGovernors()\":{\"details\":\"Returns an array of all governors.\",\"returns\":{\"_0\":\"An array containing the addresses of all governors.\"}},\"getGovernorsOf(address[])\":{\"details\":\"Retrieves the governors corresponding to a given array of bridge operators. This external function allows external callers to obtain the governors associated with a given array of bridge operators. The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\",\"params\":{\"bridgeOperators\":\"An array of bridge operator addresses for which governors are to be retrieved.\"},\"returns\":{\"governors\":\"An array of addresses representing the governors corresponding to the provided bridge operators.\"}},\"getProposalExpiryDuration()\":{\"details\":\"Returns the expiry duration for a new proposal.\"},\"getProposalSignatures(uint256,uint256)\":{\"details\":\"See {CommonGovernanceProposal-_getProposalSignatures}\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"getTotalWeight()\":{\"details\":\"Returns total weights.\"},\"globalProposalVoted(uint256,address)\":{\"details\":\"See {CommonGovernanceProposal-_proposalVoted}\"},\"isBridgeOperator(address)\":{\"details\":\"Checks if the given address is a bridge operator.\",\"params\":{\"addr\":\"The address to check.\"},\"returns\":{\"_0\":\"A boolean indicating whether the address is a bridge operator.\"}},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"proposalVoted(uint256,uint256,address)\":{\"details\":\"See {CommonGovernanceProposal-_proposalVoted}\"},\"propose(uint256,uint256,address[],uint256[],bytes[],uint256[])\":{\"details\":\"See `CoreGovernance-_proposeProposal`. Requirements: - The method caller is governor.\"},\"proposeGlobal(uint256,uint8[],uint256[],bytes[],uint256[])\":{\"details\":\"See `CoreGovernance-_proposeGlobal`. Requirements: - The method caller is governor.\"},\"proposeGlobalProposalStructAndCastVotes((uint256,uint256,uint8[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`. Requirements: - The method caller is governor.\"},\"proposeProposalForCurrentNetwork(uint256,address[],uint256[],bytes[],uint256[],uint8)\":{\"details\":\"Proposes and casts vote for a proposal on the current network. Requirements: - The method caller is governor. - The proposal is for the current network.\"},\"proposeProposalStructAndCastVotes((uint256,uint256,uint256,address[],uint256[],bytes[],uint256[]),uint8[],(uint8,bytes32,bytes32)[])\":{\"details\":\"See `GovernanceProposal-_proposeProposalStructAndCastVotes`. Requirements: - The method caller is governor. - The proposal is for the current network.\"},\"registerCallbacks(address[])\":{\"details\":\"Registers multiple callbacks with the bridge.\",\"params\":{\"registers\":\"The array of callback addresses to register.\"},\"returns\":{\"registereds\":\"An array indicating the success status of each registration.\"}},\"removeBridgeOperators(address[])\":{\"details\":\"Removes multiple bridge operators.\",\"params\":{\"bridgeOperators\":\"An array of addresses representing the bridge operators to remove.\"},\"returns\":{\"removeds\":\"An array of booleans indicating whether each bridge operator was removed successfully. * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded. It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly. Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not. Example Usage: Making an `eth_call` in ethers.js ``` const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators( bridgeOperators, // overriding the caller to the contract itself since we use `onlySelfCall` guard {from: bridgeManagerContract.address} ) const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]); // ... (Process or use the information as required) ... ```\"}},\"resolveTargets(uint8[])\":{\"details\":\"Returns corresponding address of target options. Return address(0) on non-existent target.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setThreshold(uint256,uint256)\":{\"details\":\"Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event.\"},\"sumGovernorsWeight(address[])\":{\"details\":\"Returns total weights of the governor list.\"},\"totalBridgeOperator()\":{\"details\":\"Returns the total number of bridge operators.\",\"returns\":{\"_0\":\"The total number of bridge operators.\"}},\"unregisterCallbacks(address[])\":{\"details\":\"Unregisters multiple callbacks from the bridge.\",\"params\":{\"registers\":\"The array of callback addresses to unregister.\"},\"returns\":{\"unregistereds\":\"An array indicating the success status of each unregistration.\"}},\"updateBridgeOperator(address)\":{\"details\":\"Governor updates their corresponding governor and/or operator address. Requirements: - The caller must the governor of the operator that is requested changes.\",\"params\":{\"bridgeOperator\":\"The address of the bridge operator to update.\"}},\"updateManyTargetOption(uint8[],address[])\":{\"details\":\"Updates list of `targetOptions` to `targets`. Requirement: - Only allow self-call through proposal. \"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"round(uint256)\":{\"notice\":\"chain id = 0 for global proposal\"},\"updateBridgeOperator(address)\":{\"notice\":\"This method checks authorization by querying the corresponding operator of the msg.sender and then attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave their operator address blank null `address(0)`, consider add authorization check.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/RoninBridgeManager.sol\":\"RoninBridgeManager\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for managing\\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\\n * types.\\n *\\n * Sets have the following properties:\\n *\\n * - Elements are added, removed, and checked for existence in constant time\\n * (O(1)).\\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\\n *\\n * ```\\n * contract Example {\\n * // Add the library methods\\n * using EnumerableSet for EnumerableSet.AddressSet;\\n *\\n * // Declare a set state variable\\n * EnumerableSet.AddressSet private mySet;\\n * }\\n * ```\\n *\\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\\n * and `uint256` (`UintSet`) are supported.\\n *\\n * [WARNING]\\n * ====\\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\\n *\\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\\n * ====\\n */\\nlibrary EnumerableSet {\\n // To implement this library for multiple types with as little code\\n // repetition as possible, we write it in terms of a generic Set type with\\n // bytes32 values.\\n // The Set implementation uses private functions, and user-facing\\n // implementations (such as AddressSet) are just wrappers around the\\n // underlying Set.\\n // This means that we can only create new EnumerableSets for types that fit\\n // in bytes32.\\n\\n struct Set {\\n // Storage of set values\\n bytes32[] _values;\\n // Position of the value in the `values` array, plus 1 because index 0\\n // means a value is not in the set.\\n mapping(bytes32 => uint256) _indexes;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function _add(Set storage set, bytes32 value) private returns (bool) {\\n if (!_contains(set, value)) {\\n set._values.push(value);\\n // The value is stored at length-1, but we add 1 to all indexes\\n // and use 0 as a sentinel value\\n set._indexes[value] = set._values.length;\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function _remove(Set storage set, bytes32 value) private returns (bool) {\\n // We read and store the value's index to prevent multiple reads from the same storage slot\\n uint256 valueIndex = set._indexes[value];\\n\\n if (valueIndex != 0) {\\n // Equivalent to contains(set, value)\\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\\n // the array, and then remove the last element (sometimes called as 'swap and pop').\\n // This modifies the order of the array, as noted in {at}.\\n\\n uint256 toDeleteIndex = valueIndex - 1;\\n uint256 lastIndex = set._values.length - 1;\\n\\n if (lastIndex != toDeleteIndex) {\\n bytes32 lastValue = set._values[lastIndex];\\n\\n // Move the last value to the index where the value to delete is\\n set._values[toDeleteIndex] = lastValue;\\n // Update the index for the moved value\\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\\n }\\n\\n // Delete the slot where the moved value was stored\\n set._values.pop();\\n\\n // Delete the index for the deleted slot\\n delete set._indexes[value];\\n\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\\n return set._indexes[value] != 0;\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function _length(Set storage set) private view returns (uint256) {\\n return set._values.length;\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\\n return set._values[index];\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function _values(Set storage set) private view returns (bytes32[] memory) {\\n return set._values;\\n }\\n\\n // Bytes32Set\\n\\n struct Bytes32Set {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _add(set._inner, value);\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _remove(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\\n return _contains(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(Bytes32Set storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\\n return _at(set._inner, index);\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\\n return _values(set._inner);\\n }\\n\\n // AddressSet\\n\\n struct AddressSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(AddressSet storage set, address value) internal returns (bool) {\\n return _add(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(AddressSet storage set, address value) internal returns (bool) {\\n return _remove(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(AddressSet storage set, address value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(AddressSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\\n return address(uint160(uint256(_at(set._inner, index))));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(AddressSet storage set) internal view returns (address[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n address[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n\\n // UintSet\\n\\n struct UintSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(UintSet storage set, uint256 value) internal returns (bool) {\\n return _add(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\\n return _remove(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function length(UintSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\\n return uint256(_at(set._inner, index));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(UintSet storage set) internal view returns (uint256[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n uint256[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n}\\n\",\"keccak256\":\"0x5050943b32b6a8f282573d166b2e9d87ab7eb4dbba4ab6acf36ecb54fe6995e4\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \\\"./BridgeManagerCallbackRegister.sol\\\";\\nimport { IHasContracts, HasContracts } from \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { IQuorum } from \\\"../../interfaces/IQuorum.sol\\\";\\nimport { IBridgeManager } from \\\"../../interfaces/bridge/IBridgeManager.sol\\\";\\nimport { AddressArrayUtils } from \\\"../../libraries/AddressArrayUtils.sol\\\";\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\nimport { RoleAccess } from \\\"../../utils/RoleAccess.sol\\\";\\nimport { TUint256Slot } from \\\"../../types/Types.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\\n using AddressArrayUtils for address[];\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\\\") - 1\\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\\\") - 1\\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\\\") - 1\\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\\\") - 1\\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\\n\\n /**\\n * @dev The numerator value used for calculations in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\\\") - 1\\n */\\n TUint256Slot internal constant NUMERATOR_SLOT =\\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\\n\\n /**\\n * @dev The denominator value used for calculations in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\\\") - 1\\n */\\n TUint256Slot internal constant DENOMINATOR_SLOT =\\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\\n\\n /**\\n * @dev The nonce value used for tracking nonces in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\\\") - 1\\n */\\n TUint256Slot internal constant NONCE_SLOT =\\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\\n\\n /**\\n * @dev The total weight value used for storing the cumulative weight in the contract.\\n * @notice value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\\\") - 1\\n */\\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n bytes32 public immutable DOMAIN_SEPARATOR;\\n\\n modifier onlyGovernor() virtual {\\n _requireGovernor(msg.sender);\\n _;\\n }\\n\\n constructor(\\n uint256 num,\\n uint256 denom,\\n uint256 roninChainId,\\n address bridgeContract,\\n address[] memory callbackRegisters,\\n address[] memory bridgeOperators,\\n address[] memory governors,\\n uint96[] memory voteWeights\\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\\n NONCE_SLOT.store(1);\\n\\n _setThreshold(num, denom);\\n _setContract(ContractType.BRIDGE, bridgeContract);\\n\\n DOMAIN_SEPARATOR = keccak256(\\n abi.encode(\\n keccak256(\\\"EIP712Domain(string name,string version,bytes32 salt)\\\"),\\n keccak256(\\\"BridgeAdmin\\\"), // name hash\\n keccak256(\\\"2\\\"), // version hash\\n keccak256(abi.encode(\\\"BRIDGE_ADMIN\\\", roninChainId)) // salt\\n )\\n );\\n\\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external onlySelfCall returns (bool[] memory addeds) {\\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function removeBridgeOperators(\\n address[] calldata bridgeOperators\\n ) external onlySelfCall returns (bool[] memory removeds) {\\n removeds = _removeBridgeOperators(bridgeOperators);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\\n * their operator address blank null `address(0)`, consider add authorization check.\\n */\\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\\n _requireNonZeroAddress(newBridgeOperator);\\n\\n // Queries the previous bridge operator\\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\\n if (currentBridgeOperator == newBridgeOperator) {\\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\\n }\\n\\n // Tries replace the bridge operator\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\\n\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n delete _governorOf[currentBridgeOperator];\\n _governorOf[newBridgeOperator] = msg.sender;\\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\\n\\n _notifyRegisters(\\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\\n abi.encode(currentBridgeOperator, newBridgeOperator)\\n );\\n\\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(\\n uint256 numerator,\\n uint256 denominator\\n ) external override onlySelfCall returns (uint256, uint256) {\\n return _setThreshold(numerator, denominator);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getTotalWeight() public view returns (uint256) {\\n return TOTAL_WEIGHTS_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\\n weights = _getGovernorWeights(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\\n weight = _getGovernorWeight(governor);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function sumGovernorsWeight(\\n address[] calldata governors\\n ) external view nonDuplicate(governors) returns (uint256 sum) {\\n sum = _sumGovernorsWeight(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function totalBridgeOperator() external view returns (uint256) {\\n return _getBridgeOperatorSet().length();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function isBridgeOperator(address addr) external view returns (bool) {\\n return _getBridgeOperatorSet().contains(addr);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperators() external view returns (address[] memory) {\\n return _getBridgeOperators();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernors() external view returns (address[] memory) {\\n return _getGovernors();\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\\n uint256 length = governors.length;\\n bridgeOperators = new address[](length);\\n\\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\\n for (uint256 i; i < length; ) {\\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\\n uint256 length = bridgeOperators.length;\\n governors = new address[](length);\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n\\n for (uint256 i; i < length; ) {\\n governors[i] = _governorOf[bridgeOperators[i]];\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\\n {\\n governors = _getGovernors();\\n bridgeOperators = getBridgeOperatorOf(governors);\\n weights = _getGovernorWeights(governors);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManager\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() public view virtual returns (uint256) {\\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\\n }\\n\\n /**\\n * @dev Internal function to add bridge operators.\\n *\\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\\n *\\n * Requirements:\\n * - The caller must have the necessary permission to add bridge operators.\\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\\n *\\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\\n * @param governors An array of addresses representing the governors for each bridge operator.\\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\\n */\\n function _addBridgeOperators(\\n uint96[] memory voteWeights,\\n address[] memory governors,\\n address[] memory bridgeOperators\\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\\n uint256 length = bridgeOperators.length;\\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\\n addeds = new bool[](length);\\n // simply skip add operations if inputs are empty.\\n if (length == 0) return addeds;\\n\\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n address governor;\\n address bridgeOperator;\\n uint256 accumulatedWeight;\\n BridgeOperatorInfo memory bridgeOperatorInfo;\\n\\n for (uint256 i; i < length; ) {\\n governor = governors[i];\\n bridgeOperator = bridgeOperators[i];\\n\\n _requireNonZeroAddress(governor);\\n _requireNonZeroAddress(bridgeOperator);\\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\\n\\n addeds[i] = !(_governorSet.contains(governor) ||\\n _governorSet.contains(bridgeOperator) ||\\n _bridgeOperatorSet.contains(governor) ||\\n _bridgeOperatorSet.contains(bridgeOperator));\\n\\n if (addeds[i]) {\\n _governorSet.add(governor);\\n _bridgeOperatorSet.add(bridgeOperator);\\n _governorOf[bridgeOperator] = governor;\\n bridgeOperatorInfo.addr = bridgeOperator;\\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\\n\\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\\n\\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\\n }\\n\\n /**\\n * @dev Internal function to remove bridge operators.\\n *\\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\\n *\\n * Requirements:\\n * - The caller must have the necessary permission to remove bridge operators.\\n *\\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\\n */\\n function _removeBridgeOperators(\\n address[] memory bridgeOperators\\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\\n uint256 length = bridgeOperators.length;\\n removeds = new bool[](length);\\n // simply skip remove operations if inputs are empty.\\n if (length == 0) return removeds;\\n\\n mapping(address => address) storage _governorOf = _getGovernorOf();\\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n address governor;\\n address bridgeOperator;\\n uint256 accumulatedWeight;\\n BridgeOperatorInfo memory bridgeOperatorInfo;\\n\\n for (uint256 i; i < length; ) {\\n bridgeOperator = bridgeOperators[i];\\n governor = _governorOf[bridgeOperator];\\n\\n _requireNonZeroAddress(governor);\\n _requireNonZeroAddress(bridgeOperator);\\n\\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\\n\\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\\n if (removeds[i]) {\\n _governorSet.remove(governor);\\n _bridgeOperatorSet.remove(bridgeOperator);\\n\\n delete _governorOf[bridgeOperator];\\n delete _governorToBridgeOperatorInfo[governor];\\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\\n\\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\\n\\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(\\n uint256 numerator,\\n uint256 denominator\\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\\n\\n previousNum = NUMERATOR_SLOT.load();\\n previousDenom = DENOMINATOR_SLOT.load();\\n NUMERATOR_SLOT.store(numerator);\\n DENOMINATOR_SLOT.store(denominator);\\n\\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\\n }\\n\\n /**\\n * @dev Internal function to get all bridge operators.\\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\\n */\\n function _getBridgeOperators() internal view returns (address[] memory) {\\n return _getBridgeOperatorSet().values();\\n }\\n\\n /**\\n * @dev Internal function to get all governors.\\n * @return governors An array containing all the registered governor addresses.\\n */\\n function _getGovernors() internal view returns (address[] memory) {\\n return _getGovernorsSet().values();\\n }\\n\\n /**\\n * @dev Internal function to get the vote weights of a given array of governors.\\n * @param governors An array containing the addresses of governors.\\n * @return weights An array containing the vote weights of the corresponding governors.\\n */\\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\\n uint256 length = governors.length;\\n weights = new uint96[](length);\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n for (uint256 i; i < length; ) {\\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\\n * @return sum The total sum of vote weights for the provided governors.\\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\\n */\\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\\n\\n for (uint256 i; i < governors.length; ) {\\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to require that the caller has governor role access.\\n * @param addr The address to check for governor role access.\\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\\n */\\n function _requireGovernor(address addr) internal view {\\n if (_getGovernorWeight(addr) == 0) {\\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\\n }\\n }\\n\\n /**\\n * @dev Internal function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function _getGovernorWeight(address governor) internal view returns (uint96) {\\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\\n }\\n\\n /**\\n * @dev Internal function to access the address set of bridge operators.\\n * @return bridgeOperators the storage address set.\\n */\\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\\n assembly (\\\"memory-safe\\\") {\\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the address set of bridge operators.\\n * @return governors the storage address set.\\n */\\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\\n assembly (\\\"memory-safe\\\") {\\n governors.slot := GOVERNOR_SET_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\\n */\\n function _getGovernorToBridgeOperatorInfo()\\n internal\\n pure\\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\\n {\\n assembly (\\\"memory-safe\\\") {\\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to access the mapping from bridge operator => governor.\\n * @return governorOf the mapping from bridge operator => governor.\\n */\\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\\n assembly (\\\"memory-safe\\\") {\\n governorOf.slot := GOVENOR_OF_SLOT\\n }\\n }\\n}\\n\",\"keccak256\":\"0xed4094d87c13f38dc4b76b52b8b238447d99cdc2ad452f322ddc891b1217d572\",\"license\":\"MIT\"},\"contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { EnumerableSet } from \\\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\\\";\\nimport { IBridgeManagerCallbackRegister } from \\\"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\\\";\\nimport { IBridgeManagerCallback } from \\\"../../interfaces/bridge/IBridgeManagerCallback.sol\\\";\\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\n\\n/**\\n * @title BridgeManagerCallbackRegister\\n * @dev A contract that manages callback registrations and execution for a bridge.\\n */\\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n /**\\n * @dev Storage slot for the address set of callback registers.\\n * @dev Value is equal to keccak256(\\\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\\\") - 1.\\n */\\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\\n\\n constructor(address[] memory callbackRegisters) payable {\\n _registerCallbacks(callbackRegisters);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\\n registereds = _registerCallbacks(registers);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function unregisterCallbacks(\\n address[] calldata registers\\n ) external onlySelfCall returns (bool[] memory unregistereds) {\\n unregistereds = _unregisterCallbacks(registers);\\n }\\n\\n /**\\n * @inheritdoc IBridgeManagerCallbackRegister\\n */\\n function getCallbackRegisters() external view returns (address[] memory registers) {\\n registers = _getCallbackRegisters().values();\\n }\\n\\n /**\\n * @dev Internal function to register multiple callbacks with the bridge.\\n * @param registers The array of callback addresses to register.\\n * @return registereds An array indicating the success status of each registration.\\n */\\n function _registerCallbacks(\\n address[] memory registers\\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\\n uint256 length = registers.length;\\n registereds = new bool[](length);\\n if (length == 0) return registereds;\\n\\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\\n address register;\\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\\n\\n for (uint256 i; i < length; ) {\\n register = registers[i];\\n\\n _requireHasCode(register);\\n _requireSupportsInterface(register, callbackInterface);\\n\\n registereds[i] = _callbackRegisters.add(register);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to unregister multiple callbacks from the bridge.\\n * @param registers The array of callback addresses to unregister.\\n * @return unregistereds An array indicating the success status of each unregistration.\\n */\\n function _unregisterCallbacks(\\n address[] memory registers\\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\\n uint256 length = registers.length;\\n unregistereds = new bool[](length);\\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\\n\\n for (uint256 i; i < length; ) {\\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\\n * @param callbackFnSig The function signature of the callback method.\\n * @param inputs The data to pass to the callback method.\\n */\\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\\n address[] memory registers = _getCallbackRegisters().values();\\n uint256 length = registers.length;\\n if (length == 0) return;\\n\\n bool[] memory successes = new bool[](length);\\n bytes[] memory returnDatas = new bytes[](length);\\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\\n\\n for (uint256 i; i < length; ) {\\n (successes[i], returnDatas[i]) = registers[i].call(callData);\\n if (!successes[i]) {\\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\\n }\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n emit Notified(callData, registers, successes, returnDatas);\\n }\\n\\n /**\\n * @dev Internal function to retrieve the address set of callback registers.\\n * @return callbackRegisters The storage reference to the callback registers.\\n */\\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\\n assembly (\\\"memory-safe\\\") {\\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\\n }\\n }\\n}\\n\",\"keccak256\":\"0x0fd58e2e9955d95cfde1ccd8b120fbb3d5bbf7b41143c09217833bd1d01590ce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/CoreGovernance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Proposal.sol\\\";\\nimport \\\"../../libraries/GlobalProposal.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\nimport \\\"../../libraries/Ballot.sol\\\";\\nimport \\\"../../interfaces/consumers/ChainTypeConsumer.sol\\\";\\nimport \\\"../../interfaces/consumers/SignatureConsumer.sol\\\";\\nimport \\\"../../interfaces/consumers/VoteStatusConsumer.sol\\\";\\n\\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\\n using Proposal for Proposal.ProposalDetail;\\n\\n /**\\n * @dev Error thrown when attempting to interact with a finalized vote.\\n */\\n error ErrVoteIsFinalized();\\n\\n /**\\n * @dev Error thrown when the current proposal is not completed.\\n */\\n error ErrCurrentProposalIsNotCompleted();\\n\\n struct ProposalVote {\\n VoteStatus status;\\n bytes32 hash;\\n uint256 againstVoteWeight; // Total weight of against votes\\n uint256 forVoteWeight; // Total weight of for votes\\n address[] forVoteds; // Array of addresses voting for\\n address[] againstVoteds; // Array of addresses voting against\\n uint256 expiryTimestamp;\\n mapping(address => Signature) sig;\\n mapping(address => bool) voted;\\n }\\n\\n /// @dev Emitted when a proposal is created\\n event ProposalCreated(\\n uint256 indexed chainId,\\n uint256 indexed round,\\n bytes32 indexed proposalHash,\\n Proposal.ProposalDetail proposal,\\n address creator\\n );\\n /// @dev Emitted when the proposal is voted\\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\\n /// @dev Emitted when the proposal is approved\\n event ProposalApproved(bytes32 indexed proposalHash);\\n /// @dev Emitted when the vote is reject\\n event ProposalRejected(bytes32 indexed proposalHash);\\n /// @dev Emitted when the vote is expired\\n event ProposalExpired(bytes32 indexed proposalHash);\\n /// @dev Emitted when the proposal is executed\\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\\n /// @dev Emitted when the proposal expiry duration is changed.\\n event ProposalExpiryDurationChanged(uint256 indexed duration);\\n\\n /// @dev Mapping from chain id => vote round\\n /// @notice chain id = 0 for global proposal\\n mapping(uint256 => uint256) public round;\\n /// @dev Mapping from chain id => vote round => proposal vote\\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\\n\\n uint256 internal _proposalExpiryDuration;\\n\\n constructor(uint256 _expiryDuration) {\\n _setProposalExpiryDuration(_expiryDuration);\\n }\\n\\n /**\\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\\n * if it is expired and not increase the `_round`.\\n */\\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\\n _round = round[_chainId];\\n // Skip checking for the first ever round\\n if (_round == 0) {\\n _round = round[_chainId] = 1;\\n } else {\\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\\n if (!_isExpired) {\\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\\n unchecked {\\n _round = ++round[_chainId];\\n }\\n }\\n }\\n }\\n\\n /**\\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\\n */\\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\\n _vote.hash = _proposalHash;\\n _vote.expiryTimestamp = _expiryTimestamp;\\n }\\n\\n /**\\n * @dev Proposes for a new proposal.\\n *\\n * Requirements:\\n * - The chain id is not equal to 0.\\n *\\n * Emits the `ProposalCreated` event.\\n *\\n */\\n function _proposeProposal(\\n uint256 chainId,\\n uint256 expiryTimestamp,\\n address[] memory targets,\\n uint256[] memory values,\\n bytes[] memory calldatas,\\n uint256[] memory gasAmounts,\\n address creator\\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\\n uint256 round_ = _createVotingRound(chainId);\\n\\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\\n }\\n\\n /**\\n * @dev Proposes proposal struct.\\n *\\n * Requirements:\\n * - The chain id is not equal to 0.\\n * - The proposal nonce is equal to the new round.\\n *\\n * Emits the `ProposalCreated` event.\\n *\\n */\\n function _proposeProposalStruct(\\n Proposal.ProposalDetail memory proposal,\\n address creator\\n ) internal virtual returns (uint256 round_) {\\n uint256 chainId = proposal.chainId;\\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n round_ = _createVotingRound(chainId);\\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\\n }\\n\\n /**\\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\\n *\\n * Requirements:\\n * - The proposal nonce is equal to the round.\\n * - The vote is not finalized.\\n * - The voter has not voted for the round.\\n *\\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\\n * proposal is approved, executed or rejected.\\n *\\n */\\n function _castVote(\\n Proposal.ProposalDetail memory proposal,\\n Ballot.VoteType support,\\n uint256 minimumForVoteWeight,\\n uint256 minimumAgainstVoteWeight,\\n address voter,\\n Signature memory signature,\\n uint256 voterWeight\\n ) internal virtual returns (bool done) {\\n uint256 chainId = proposal.chainId;\\n uint256 round_ = proposal.nonce;\\n ProposalVote storage _vote = vote[chainId][round_];\\n\\n if (_tryDeleteExpiredVotingRound(_vote)) {\\n return true;\\n }\\n\\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\\n\\n _vote.voted[voter] = true;\\n // Stores the signature if it is not empty\\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\\n _vote.sig[voter] = signature;\\n }\\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\\n\\n uint256 _forVoteWeight;\\n uint256 _againstVoteWeight;\\n if (support == Ballot.VoteType.For) {\\n _vote.forVoteds.push(voter);\\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\\n } else if (support == Ballot.VoteType.Against) {\\n _vote.againstVoteds.push(voter);\\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\\n } else revert ErrUnsupportedVoteType(msg.sig);\\n\\n if (_forVoteWeight >= minimumForVoteWeight) {\\n done = true;\\n _vote.status = VoteStatus.Approved;\\n emit ProposalApproved(_vote.hash);\\n _tryExecute(_vote, proposal);\\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\\n done = true;\\n _vote.status = VoteStatus.Rejected;\\n emit ProposalRejected(_vote.hash);\\n }\\n }\\n\\n /**\\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\\n *\\n * Emits the event `ProposalExpired` if the vote is expired.\\n *\\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\\n * before or it will emit an unexpected event of `ProposalExpired`.\\n */\\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\\n isExpired =\\n _getChainType() == ChainType.RoninChain &&\\n proposalVote.status == VoteStatus.Pending &&\\n proposalVote.expiryTimestamp <= block.timestamp;\\n\\n if (isExpired) {\\n emit ProposalExpired(proposalVote.hash);\\n\\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n delete proposalVote.status;\\n delete proposalVote.hash;\\n delete proposalVote.againstVoteWeight;\\n delete proposalVote.forVoteWeight;\\n delete proposalVote.forVoteds;\\n delete proposalVote.againstVoteds;\\n delete proposalVote.expiryTimestamp;\\n }\\n }\\n\\n /**\\n * @dev Executes the proposal and update the vote status once the proposal is executable.\\n */\\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\\n if (proposal.executable()) {\\n vote_.status = VoteStatus.Executed;\\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\\n }\\n }\\n\\n /**\\n * @dev Sets the expiry duration for a new proposal.\\n */\\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\\n _proposalExpiryDuration = expiryDuration;\\n emit ProposalExpiryDurationChanged(expiryDuration);\\n }\\n\\n /**\\n * @dev Returns the expiry duration for a new proposal.\\n */\\n function _getProposalExpiryDuration() internal view returns (uint256) {\\n return _proposalExpiryDuration;\\n }\\n\\n /**\\n * @dev Returns whether the voter casted for the proposal.\\n */\\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\\n return vote_.voted[voter];\\n }\\n\\n /**\\n * @dev Returns total weight from validators.\\n */\\n function _getTotalWeight() internal view virtual returns (uint256);\\n\\n /**\\n * @dev Returns minimum vote to pass a proposal.\\n */\\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\\n\\n /**\\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\\n */\\n function _getChainType() internal view virtual returns (ChainType);\\n}\\n\",\"keccak256\":\"0xc6056209e8f6a0d9edced67388a4037c6fafffb68a3c7b2fe5759c487bb1d81c\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/GlobalCoreGovernance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Proposal.sol\\\";\\nimport \\\"../../libraries/GlobalProposal.sol\\\";\\nimport \\\"./CoreGovernance.sol\\\";\\n\\nabstract contract GlobalCoreGovernance is CoreGovernance {\\n using Proposal for Proposal.ProposalDetail;\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\\n\\n /// @dev Emitted when a proposal is created\\n event GlobalProposalCreated(\\n uint256 indexed round,\\n bytes32 indexed proposalHash,\\n Proposal.ProposalDetail proposal,\\n bytes32 globalProposalHash,\\n GlobalProposal.GlobalProposalDetail globalProposal,\\n address creator\\n );\\n\\n /// @dev Emitted when the target options are updated\\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\\n\\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\\n _updateManyTargetOption(targetOptions, addrs);\\n }\\n\\n /**\\n * @dev Proposes for a global proposal.\\n *\\n * Emits the `GlobalProposalCreated` event.\\n *\\n */\\n function _proposeGlobal(\\n uint256 expiryTimestamp,\\n GlobalProposal.TargetOption[] calldata targetOptions,\\n uint256[] memory values,\\n bytes[] memory calldatas,\\n uint256[] memory gasAmounts,\\n address creator\\n ) internal virtual {\\n uint256 round_ = _createVotingRound(0);\\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\\n round_,\\n expiryTimestamp,\\n targetOptions,\\n values,\\n calldatas,\\n gasAmounts\\n );\\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\\n _resolveTargets({ targetOptions: targetOptions, strict: true })\\n );\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\\n }\\n\\n /**\\n * @dev Proposes global proposal struct.\\n *\\n * Requirements:\\n * - The proposal nonce is equal to the new round.\\n *\\n * Emits the `GlobalProposalCreated` event.\\n *\\n */\\n function _proposeGlobalStruct(\\n GlobalProposal.GlobalProposalDetail memory globalProposal,\\n address creator\\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\\n proposal = globalProposal.intoProposalDetail(\\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\\n );\\n proposal.validate(_proposalExpiryDuration);\\n\\n bytes32 proposalHash = proposal.hash();\\n uint256 round_ = _createVotingRound(0);\\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\\n\\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\\n }\\n\\n /**\\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\\n */\\n function resolveTargets(\\n GlobalProposal.TargetOption[] calldata targetOptions\\n ) external view returns (address[] memory targets) {\\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\\n }\\n\\n /**\\n * @dev Internal helper of {resolveTargets}.\\n *\\n * @param strict When the param is set to `true`, revert on non-existent target.\\n */\\n function _resolveTargets(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n bool strict\\n ) internal view returns (address[] memory targets) {\\n targets = new address[](targetOptions.length);\\n\\n for (uint256 i; i < targetOptions.length; ) {\\n targets[i] = _targetOptionsMap[targetOptions[i]];\\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Updates list of `targetOptions` to `targets`.\\n *\\n * Requirement:\\n * - Only allow self-call through proposal.\\n * */\\n function updateManyTargetOption(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n ) external {\\n // HACK: Cannot reuse the existing library due to too deep stack\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n _updateManyTargetOption(targetOptions, targets);\\n }\\n\\n /**\\n * @dev Updates list of `targetOptions` to `targets`.\\n */\\n function _updateManyTargetOption(\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n ) internal {\\n for (uint256 i; i < targetOptions.length; ) {\\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\\n _updateTargetOption(targetOptions[i], targets[i]);\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Updates `targetOption` to `target`.\\n *\\n * Requirement:\\n * - Emit a `TargetOptionUpdated` event.\\n */\\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\\n _targetOptionsMap[targetOption] = target;\\n emit TargetOptionUpdated(targetOption, target);\\n }\\n}\\n\",\"keccak256\":\"0x986444cade6313dd1ce4137f3338e4fc296769f5cf669f057cd2838e5ae0e54f\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../CoreGovernance.sol\\\";\\n\\nabstract contract CommonGovernanceProposal is CoreGovernance {\\n using Proposal for Proposal.ProposalDetail;\\n\\n /**\\n * @dev Error thrown when an invalid proposal is encountered.\\n * @param actual The actual value of the proposal.\\n * @param expected The expected value of the proposal.\\n */\\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\\n\\n /**\\n * @dev Casts votes by signatures.\\n *\\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\\n *\\n */\\n function _castVotesBySignatures(\\n Proposal.ProposalDetail memory _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures,\\n bytes32 _forDigest,\\n bytes32 _againstDigest\\n ) internal {\\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\\n\\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\\n\\n address _lastSigner;\\n address _signer;\\n Signature calldata _sig;\\n bool _hasValidVotes;\\n for (uint256 _i; _i < _signatures.length; ) {\\n _sig = _signatures[_i];\\n\\n if (_supports[_i] == Ballot.VoteType.For) {\\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\\n } else if (_supports[_i] == Ballot.VoteType.Against) {\\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\\n } else revert ErrUnsupportedVoteType(msg.sig);\\n\\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\\n _lastSigner = _signer;\\n\\n uint256 _weight = _getWeight(_signer);\\n if (_weight > 0) {\\n _hasValidVotes = true;\\n if (\\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\\n ) {\\n return;\\n }\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\\n }\\n\\n /**\\n * @dev Returns the voted signatures for the proposals.\\n *\\n * Note: The signatures can be empty in case the proposal is voted on the current network.\\n *\\n */\\n function _getProposalSignatures(\\n uint256 _chainId,\\n uint256 _round\\n )\\n internal\\n view\\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\\n {\\n ProposalVote storage _vote = vote[_chainId][_round];\\n\\n uint256 _forLength = _vote.forVoteds.length;\\n uint256 _againstLength = _vote.againstVoteds.length;\\n uint256 _voterLength = _forLength + _againstLength;\\n\\n _supports = new Ballot.VoteType[](_voterLength);\\n _signatures = new Signature[](_voterLength);\\n _voters = new address[](_voterLength);\\n for (uint256 _i; _i < _forLength; ) {\\n _supports[_i] = Ballot.VoteType.For;\\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\\n _voters[_i] = _vote.forVoteds[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n for (uint256 _i; _i < _againstLength; ) {\\n _supports[_i + _forLength] = Ballot.VoteType.Against;\\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\\n */\\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\\n return _voted(vote[_chainId][_round], _voter);\\n }\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function _getWeight(address _governor) internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0x75d59a854f4b878cce49701f9f3dc7c5e5bbddebe72df40396959bf31995f321\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../../libraries/Proposal.sol\\\";\\nimport \\\"../GlobalCoreGovernance.sol\\\";\\nimport \\\"./CommonGovernanceProposal.sol\\\";\\n\\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\\n using Proposal for Proposal.ProposalDetail;\\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\\n\\n /**\\n * @dev Proposes and votes by signature.\\n */\\n function _proposeGlobalProposalStructAndCastVotes(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures,\\n bytes32 domainSeparator,\\n address creator\\n ) internal returns (Proposal.ProposalDetail memory proposal) {\\n proposal = _proposeGlobalStruct(globalProposal, creator);\\n bytes32 _globalProposalHash = globalProposal.hash();\\n _castVotesBySignatures(\\n proposal,\\n supports_,\\n signatures,\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\\n );\\n }\\n\\n /**\\n * @dev Proposes a global proposal struct and casts votes by signature.\\n */\\n function _castGlobalProposalBySignatures(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures,\\n bytes32 domainSeparator\\n ) internal {\\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\\n );\\n\\n bytes32 proposalHash = _proposal.hash();\\n if (vote[0][_proposal.nonce].hash != proposalHash)\\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\\n\\n bytes32 globalProposalHash = globalProposal.hash();\\n _castVotesBySignatures(\\n _proposal,\\n supports_,\\n signatures,\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\\n );\\n }\\n\\n /**\\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\\n */\\n function getGlobalProposalSignatures(\\n uint256 round_\\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\\n return _getProposalSignatures(0, round_);\\n }\\n\\n /**\\n * @dev See {CommonGovernanceProposal-_proposalVoted}\\n */\\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\\n return _proposalVoted(0, round_, voter);\\n }\\n}\\n\",\"keccak256\":\"0xf51a22e3494d132120453a9818cadf548b2dc779fd0ca004945ae8909bd94fbb\",\"license\":\"MIT\"},\"contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../CoreGovernance.sol\\\";\\nimport \\\"./CommonGovernanceProposal.sol\\\";\\n\\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\\n using Proposal for Proposal.ProposalDetail;\\n\\n /**\\n * @dev Proposes a proposal struct and casts votes by signature.\\n */\\n function _proposeProposalStructAndCastVotes(\\n Proposal.ProposalDetail calldata _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures,\\n bytes32 _domainSeparator,\\n address _creator\\n ) internal {\\n _proposeProposalStruct(_proposal, _creator);\\n bytes32 _proposalHash = _proposal.hash();\\n _castVotesBySignatures(\\n _proposal,\\n _supports,\\n _signatures,\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\\n );\\n }\\n\\n /**\\n * @dev Proposes a proposal struct and casts votes by signature.\\n */\\n function _castProposalBySignatures(\\n Proposal.ProposalDetail calldata _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures,\\n bytes32 _domainSeparator\\n ) internal {\\n bytes32 _proposalHash = _proposal.hash();\\n\\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\\n }\\n\\n _castVotesBySignatures(\\n _proposal,\\n _supports,\\n _signatures,\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\\n );\\n }\\n\\n /**\\n * @dev See `castProposalVoteForCurrentNetwork`.\\n */\\n function _castProposalVoteForCurrentNetwork(\\n address _voter,\\n Proposal.ProposalDetail memory _proposal,\\n Ballot.VoteType _support\\n ) internal {\\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\\n\\n bytes32 proposalHash = _proposal.hash();\\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\\n\\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\\n Signature memory _emptySignature;\\n _castVote(\\n _proposal,\\n _support,\\n _minimumForVoteWeight,\\n _minimumAgainstVoteWeight,\\n _voter,\\n _emptySignature,\\n _getWeight(_voter)\\n );\\n }\\n\\n /**\\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\\n */\\n function getProposalSignatures(\\n uint256 _chainId,\\n uint256 _round\\n )\\n external\\n view\\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\\n {\\n return _getProposalSignatures(_chainId, _round);\\n }\\n\\n /**\\n * @dev See {CommonGovernanceProposal-_proposalVoted}\\n */\\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\\n return _proposalVoted(_chainId, _round, _voter);\\n }\\n}\\n\",\"keccak256\":\"0xcd9652e50c946963dcbc80e63cf88eb927aefdb2cde63f59f385bf664871039f\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallback.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @title IBridgeManagerCallback\\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\\n */\\ninterface IBridgeManagerCallback is IERC165 {\\n /**\\n * @dev Handles the event when bridge operators are added.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsAdded(\\n address[] memory bridgeOperators,\\n bool[] memory addeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when bridge operators are removed.\\n * @param bridgeOperators The addresses of the bridge operators.\\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorsRemoved(\\n address[] memory bridgeOperators,\\n bool[] memory removeds\\n ) external returns (bytes4 selector);\\n\\n /**\\n * @dev Handles the event when a bridge operator is updated.\\n * @param currentBridgeOperator The address of the current bridge operator.\\n * @param newbridgeOperator The new address of the bridge operator.\\n * @return selector The selector of the function being called.\\n */\\n function onBridgeOperatorUpdated(\\n address currentBridgeOperator,\\n address newbridgeOperator\\n ) external returns (bytes4 selector);\\n}\\n\",\"keccak256\":\"0xfd6868a1041577a463b6c96713edcb18063dc817154d09710abfd5783e4629ee\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerCallbackRegister {\\n /**\\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\\n */\\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\\n\\n /**\\n * @dev Retrieves the addresses of registered callbacks.\\n * @return registers An array containing the addresses of registered callbacks.\\n */\\n function getCallbackRegisters() external view returns (address[] memory registers);\\n\\n /**\\n * @dev Registers multiple callbacks with the bridge.\\n * @param registers The array of callback addresses to register.\\n * @return registereds An array indicating the success status of each registration.\\n */\\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\\n\\n /**\\n * @dev Unregisters multiple callbacks from the bridge.\\n * @param registers The array of callback addresses to unregister.\\n * @return unregistereds An array indicating the success status of each unregistration.\\n */\\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\\n}\\n\",\"keccak256\":\"0xadbcf65ee9d55f4aa037216d71a279fe41855fe572a4a8734e6f69954aea98f4\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/ChainTypeConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface ChainTypeConsumer {\\n enum ChainType {\\n RoninChain,\\n Mainchain\\n }\\n}\\n\",\"keccak256\":\"0xe0d20e00c8d237f8e0fb881abf1ff1ef114173bcb428f06f689c581666a22db7\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/SignatureConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface SignatureConsumer {\\n struct Signature {\\n uint8 v;\\n bytes32 r;\\n bytes32 s;\\n }\\n}\\n\",\"keccak256\":\"0xd370e350722067097dec1a5c31bda6e47e83417fa5c3288293bb910028cd136b\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/VoteStatusConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface VoteStatusConsumer {\\n enum VoteStatus {\\n Pending,\\n Approved,\\n Executed,\\n Rejected,\\n Expired\\n }\\n}\\n\",\"keccak256\":\"0xa5045232c0c053fcf31fb3fe71942344444159c48d5f1b2063dbb06b6a1c9752\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Ballot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\n\\nlibrary Ballot {\\n using ECDSA for bytes32;\\n\\n enum VoteType {\\n For,\\n Against\\n }\\n\\n // keccak256(\\\"Ballot(bytes32 proposalHash,uint8 support)\\\");\\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\\n\\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, BALLOT_TYPEHASH)\\n mstore(add(ptr, 0x20), _proposalHash)\\n mstore(add(ptr, 0x40), _support)\\n digest := keccak256(ptr, 0x60)\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaa1e66bcd86baa6f18c7c5e9b67496535f229cbd2e2ecb4c66bcbfed2b1365de\",\"license\":\"MIT\"},\"contracts/libraries/GlobalProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./Proposal.sol\\\";\\n\\nlibrary GlobalProposal {\\n /**\\n * @dev Error thrown when attempting to interact with an unsupported target.\\n */\\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\\n\\n enum TargetOption {\\n /* 0 */ BridgeManager,\\n /* 1 */ GatewayContract,\\n /* 2 */ BridgeReward,\\n /* 3 */ BridgeSlash,\\n /* 4 */ BridgeTracking\\n }\\n\\n struct GlobalProposalDetail {\\n // Nonce to make sure proposals are executed in order\\n uint256 nonce;\\n uint256 expiryTimestamp;\\n TargetOption[] targetOptions;\\n uint256[] values;\\n bytes[] calldatas;\\n uint256[] gasAmounts;\\n }\\n\\n // keccak256(\\\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\\\");\\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\\n\\n /**\\n * @dev Returns struct hash of the proposal.\\n */\\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\\n uint256[] memory values = self.values;\\n TargetOption[] memory targets = self.targetOptions;\\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\\n uint256[] memory gasAmounts = self.gasAmounts;\\n\\n for (uint256 i; i < calldataHashList.length; ) {\\n calldataHashList[i] = keccak256(self.calldatas[i]);\\n\\n unchecked {\\n ++i;\\n }\\n }\\n\\n /*\\n * return\\n * keccak256(\\n * abi.encode(\\n * TYPE_HASH,\\n * _proposal.nonce,\\n * _proposal.expiryTimestamp,\\n * _targetsHash,\\n * _valuesHash,\\n * _calldatasHash,\\n * _gasAmountsHash\\n * )\\n * );\\n */\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\\n\\n let arrayHashed\\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\\n mstore(add(ptr, 0x60), arrayHashed)\\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\\n mstore(add(ptr, 0x80), arrayHashed)\\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\\n mstore(add(ptr, 0xa0), arrayHashed)\\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\\n mstore(add(ptr, 0xc0), arrayHashed)\\n digest_ := keccak256(ptr, 0xe0)\\n }\\n }\\n\\n /**\\n * @dev Converts into the normal proposal.\\n */\\n function intoProposalDetail(\\n GlobalProposalDetail memory self,\\n address[] memory targets\\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\\n detail_.nonce = self.nonce;\\n detail_.expiryTimestamp = self.expiryTimestamp;\\n detail_.chainId = 0;\\n detail_.targets = new address[](self.targetOptions.length);\\n detail_.values = self.values;\\n detail_.calldatas = self.calldatas;\\n detail_.gasAmounts = self.gasAmounts;\\n\\n for (uint256 i; i < self.targetOptions.length; ) {\\n detail_.targets[i] = targets[i];\\n unchecked {\\n ++i;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2716e1baf467abab71d89efa01ce0dc9164531ab4221d2758233a81b6d906474\",\"license\":\"MIT\"},\"contracts/libraries/Proposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ErrInvalidChainId, ErrLengthMismatch } from \\\"../utils/CommonErrors.sol\\\";\\n\\nlibrary Proposal {\\n /**\\n * @dev Error thrown when there is insufficient gas to execute a function.\\n */\\n error ErrInsufficientGas(bytes32 proposalHash);\\n\\n /**\\n * @dev Error thrown when an invalid expiry timestamp is provided.\\n */\\n error ErrInvalidExpiryTimestamp();\\n\\n struct ProposalDetail {\\n // Nonce to make sure proposals are executed in order\\n uint256 nonce;\\n // Value 0: all chain should run this proposal\\n // Other values: only specifc chain has to execute\\n uint256 chainId;\\n uint256 expiryTimestamp;\\n address[] targets;\\n uint256[] values;\\n bytes[] calldatas;\\n uint256[] gasAmounts;\\n }\\n\\n // keccak256(\\\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\\\");\\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\\n\\n /**\\n * @dev Validates the proposal.\\n */\\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\\n if (\\n !(_proposal.targets.length > 0 &&\\n _proposal.targets.length == _proposal.values.length &&\\n _proposal.targets.length == _proposal.calldatas.length &&\\n _proposal.targets.length == _proposal.gasAmounts.length)\\n ) {\\n revert ErrLengthMismatch(msg.sig);\\n }\\n\\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\\n revert ErrInvalidExpiryTimestamp();\\n }\\n }\\n\\n /**\\n * @dev Returns struct hash of the proposal.\\n */\\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\\n uint256[] memory _values = _proposal.values;\\n address[] memory _targets = _proposal.targets;\\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\\n\\n for (uint256 _i; _i < _calldataHashList.length; ) {\\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n // return\\n // keccak256(\\n // abi.encode(\\n // TYPE_HASH,\\n // _proposal.nonce,\\n // _proposal.chainId,\\n // _targetsHash,\\n // _valuesHash,\\n // _calldatasHash,\\n // _gasAmountsHash\\n // )\\n // );\\n // /\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\\n\\n let arrayHashed\\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\\n mstore(add(ptr, 0x80), arrayHashed)\\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\\n mstore(add(ptr, 0xa0), arrayHashed)\\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\\n mstore(add(ptr, 0xc0), arrayHashed)\\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\\n mstore(add(ptr, 0xe0), arrayHashed)\\n digest_ := keccak256(ptr, 0x100)\\n }\\n }\\n\\n /**\\n * @dev Returns whether the proposal is executable for the current chain.\\n *\\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\\n *\\n */\\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\\n }\\n\\n /**\\n * @dev Executes the proposal.\\n */\\n function execute(\\n ProposalDetail memory _proposal\\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\\n\\n _successCalls = new bool[](_proposal.targets.length);\\n _returnDatas = new bytes[](_proposal.targets.length);\\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\\n\\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\\n value: _proposal.values[_i],\\n gas: _proposal.gasAmounts[_i]\\n }(_proposal.calldatas[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xbc29aa4e69db7eef0034fdb795181124f86bcf2bc07b5e4a202100dbdce7f7a1\",\"license\":\"MIT\"},\"contracts/ronin/gateway/RoninBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \\\"../../extensions/bridge-operator-governance/BridgeManager.sol\\\";\\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \\\"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\\\";\\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \\\"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\\\";\\nimport { VoteStatusConsumer } from \\\"../../interfaces/consumers/VoteStatusConsumer.sol\\\";\\nimport { ErrQueryForEmptyVote } from \\\"../../utils/CommonErrors.sol\\\";\\n\\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\\n constructor(\\n uint256 num,\\n uint256 denom,\\n uint256 roninChainId,\\n uint256 expiryDuration,\\n address bridgeContract,\\n address[] memory callbackRegisters,\\n address[] memory bridgeOperators,\\n address[] memory governors,\\n uint96[] memory voteWeights,\\n GlobalProposal.TargetOption[] memory targetOptions,\\n address[] memory targets\\n )\\n payable\\n CoreGovernance(expiryDuration)\\n GlobalCoreGovernance(targetOptions, targets)\\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\\n {}\\n\\n /**\\n * CURRENT NETWORK\\n */\\n\\n /**\\n * @dev See `CoreGovernance-_proposeProposal`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n *\\n */\\n function propose(\\n uint256 _chainId,\\n uint256 _expiryTimestamp,\\n address[] calldata _targets,\\n uint256[] calldata _values,\\n bytes[] calldata _calldatas,\\n uint256[] calldata _gasAmounts\\n ) external onlyGovernor {\\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\\n }\\n\\n /**\\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n * - The proposal is for the current network.\\n *\\n */\\n function proposeProposalStructAndCastVotes(\\n Proposal.ProposalDetail calldata _proposal,\\n Ballot.VoteType[] calldata _supports,\\n Signature[] calldata _signatures\\n ) external onlyGovernor {\\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\\n }\\n\\n /**\\n * @dev Proposes and casts vote for a proposal on the current network.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n * - The proposal is for the current network.\\n *\\n */\\n function proposeProposalForCurrentNetwork(\\n uint256 expiryTimestamp,\\n address[] calldata targets,\\n uint256[] calldata values,\\n bytes[] calldata calldatas,\\n uint256[] calldata gasAmounts,\\n Ballot.VoteType support\\n ) external onlyGovernor {\\n address _voter = msg.sender;\\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\\n chainId: block.chainid,\\n expiryTimestamp: expiryTimestamp,\\n targets: targets,\\n values: values,\\n calldatas: calldatas,\\n gasAmounts: gasAmounts,\\n creator: _voter\\n });\\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\\n }\\n\\n /**\\n * @dev Casts vote for a proposal on the current network.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n *\\n */\\n function castProposalVoteForCurrentNetwork(\\n Proposal.ProposalDetail calldata proposal,\\n Ballot.VoteType support\\n ) external onlyGovernor {\\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\\n }\\n\\n /**\\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\\n */\\n function castProposalBySignatures(\\n Proposal.ProposalDetail calldata proposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures\\n ) external {\\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\\n }\\n\\n /**\\n * GLOBAL NETWORK\\n */\\n\\n /**\\n * @dev See `CoreGovernance-_proposeGlobal`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n *\\n */\\n function proposeGlobal(\\n uint256 expiryTimestamp,\\n GlobalProposal.TargetOption[] calldata targetOptions,\\n uint256[] calldata values,\\n bytes[] calldata calldatas,\\n uint256[] calldata gasAmounts\\n ) external onlyGovernor {\\n _proposeGlobal({\\n expiryTimestamp: expiryTimestamp,\\n targetOptions: targetOptions,\\n values: values,\\n calldatas: calldatas,\\n gasAmounts: gasAmounts,\\n creator: msg.sender\\n });\\n }\\n\\n /**\\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\\n *\\n * Requirements:\\n * - The method caller is governor.\\n *\\n */\\n function proposeGlobalProposalStructAndCastVotes(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures\\n ) external onlyGovernor {\\n _proposeGlobalProposalStructAndCastVotes({\\n globalProposal: globalProposal,\\n supports_: supports_,\\n signatures: signatures,\\n domainSeparator: DOMAIN_SEPARATOR,\\n creator: msg.sender\\n });\\n }\\n\\n /**\\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\\n */\\n function castGlobalProposalBySignatures(\\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\\n Ballot.VoteType[] calldata supports_,\\n Signature[] calldata signatures\\n ) external {\\n _castGlobalProposalBySignatures({\\n globalProposal: globalProposal,\\n supports_: supports_,\\n signatures: signatures,\\n domainSeparator: DOMAIN_SEPARATOR\\n });\\n }\\n\\n /**\\n * COMMON METHODS\\n */\\n\\n /**\\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\\n *\\n * Requirements:\\n * - The proposal is already created.\\n *\\n */\\n function deleteExpired(uint256 _chainId, uint256 _round) external {\\n ProposalVote storage _vote = vote[_chainId][_round];\\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\\n\\n _tryDeleteExpiredVotingRound(_vote);\\n }\\n\\n /**\\n * @dev Returns the expiry duration for a new proposal.\\n */\\n function getProposalExpiryDuration() external view returns (uint256) {\\n return _getProposalExpiryDuration();\\n }\\n\\n /**\\n * @dev Internal function to get the chain type of the contract.\\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\\n */\\n function _getChainType() internal pure override returns (ChainType) {\\n return ChainType.RoninChain;\\n }\\n\\n /**\\n * @dev Internal function to get the total weights of all governors.\\n * @return The total weights of all governors combined.\\n */\\n function _getTotalWeight() internal view virtual override returns (uint256) {\\n return getTotalWeight();\\n }\\n\\n /**\\n * @dev Internal function to get the minimum vote weight required for governance actions.\\n * @return The minimum vote weight required for governance actions.\\n */\\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\\n return minimumVoteWeight();\\n }\\n\\n /**\\n * @dev Internal function to get the vote weight of a specific governor.\\n * @param _governor The address of the governor to get the vote weight for.\\n * @return The vote weight of the specified governor.\\n */\\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\\n return _getGovernorWeight(_governor);\\n }\\n}\\n\",\"keccak256\":\"0x2b55ad997d2e757288a7253a0d0c20a15b6ed08439e35e423dea62351f6db35c\",\"license\":\"MIT\"},\"contracts/types/Types.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { LibTUint256Slot } from \\\"./operations/LibTUint256Slot.sol\\\";\\n\\ntype TUint256Slot is bytes32;\\n\\nusing {\\n LibTUint256Slot.add,\\n LibTUint256Slot.sub,\\n LibTUint256Slot.mul,\\n LibTUint256Slot.div,\\n LibTUint256Slot.load,\\n LibTUint256Slot.store,\\n LibTUint256Slot.addAssign,\\n LibTUint256Slot.subAssign,\\n LibTUint256Slot.preDecrement,\\n LibTUint256Slot.postDecrement,\\n LibTUint256Slot.preIncrement,\\n LibTUint256Slot.postIncrement\\n} for TUint256Slot global;\\n\",\"keccak256\":\"0x20ab58f1c9ae4936f9dd9891d064301d78ef508c1dd2ce0c19a7b5b81d530e36\",\"license\":\"MIT\"},\"contracts/types/operations/LibTUint256Slot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.17;\\n\\nimport { TUint256Slot } from \\\"../Types.sol\\\";\\n\\n/**\\n * @title LibTUint256Slot\\n * @dev Library for handling unsigned 256-bit integers.\\n */\\nlibrary LibTUint256Slot {\\n /// @dev value is equal to bytes4(keccak256(\\\"Panic(uint256)\\\"))\\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\\n /// @dev error code for {Arithmetic over/underflow} error\\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\\n /// @dev error code for {Division or modulo by 0} error\\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\\n\\n /**\\n * @dev Loads the value of the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @return val The loaded value.\\n */\\n function load(TUint256Slot self) internal view returns (uint256 val) {\\n assembly {\\n val := sload(self)\\n }\\n }\\n\\n /**\\n * @dev Stores a value into the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to be stored.\\n */\\n function store(TUint256Slot self, uint256 other) internal {\\n assembly {\\n sstore(self, other)\\n }\\n }\\n\\n /**\\n * @dev Multiplies the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to multiply by.\\n * @return res The resulting value after multiplication.\\n */\\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n if iszero(iszero(storedVal)) {\\n res := mul(storedVal, other)\\n\\n // Overflow check\\n if iszero(eq(other, div(res, storedVal))) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n }\\n\\n /**\\n * @dev Divides the TUint256Slot variable by a given value.\\n * @param self The TUint256Slot variable.\\n * @param other The value to divide by.\\n * @return res The resulting value after division.\\n */\\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n // revert if divide by zero\\n if iszero(other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, DIVISION_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n res := div(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction.\\n */\\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n\\n // Underflow check\\n if lt(storedVal, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n\\n res := sub(storedVal, other)\\n }\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition.\\n */\\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\\n assembly {\\n let storedVal := sload(self)\\n res := add(storedVal, other)\\n\\n // Overflow check\\n if lt(res, other) {\\n // Store 4 bytes the function selector of Panic(uint256)\\n // Equivalent to revert Panic(uint256)\\n mstore(0x00, PANIC_ERROR_SIGNATURE)\\n // Store 4 bytes of division error code in the next slot\\n mstore(0x20, ARITHMETIC_ERROR_CODE)\\n // Revert 36 bytes of error starting from 0x1c\\n revert(0x1c, 0x24)\\n }\\n }\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after incrementing.\\n */\\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = addAssign(self, 1);\\n }\\n\\n /**\\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\\n * @param self The TUint256Slot variable.\\n * @return res The original value before incrementing.\\n */\\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res + 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value after decrementing.\\n */\\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = subAssign(self, 1);\\n }\\n\\n /**\\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\\n * @param self The TUint256Slot variable.\\n * @return res The resulting value before decrementing.\\n */\\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\\n res = load(self);\\n store(self, res - 1);\\n }\\n\\n /**\\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to add.\\n * @return res The resulting value after addition and storage.\\n */\\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = add(self, other));\\n }\\n\\n /**\\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\\n * @param self The TUint256Slot variable.\\n * @param other The value to subtract.\\n * @return res The resulting value after subtraction and storage.\\n */\\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\\n store(self, res = sub(self, other));\\n }\\n}\\n\",\"keccak256\":\"0xe10c089459baf373494d76b00e582d49f6e43c500ab0f1657d53afc2fa472cbb\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x60a060405260405162007a2238038062007a228339810160408190526200002691620015fd565b8181898d8d8d8c8c8c8c8c836200003d81620001ba565b50506200006c600160008051602062007a0283398151915260001b620002d760201b620012641790919060201c565b620000788888620002db565b5062000088905060028662000451565b604080516020808201839052600c60608301526b212924a223a2afa0a226a4a760a11b6080808401919091528284018a905283518084038201815260a0840185528051908301207f599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf60c08501527f9d3fa1662ea89365eb7af36506f0ad5413bd7e078960d8481ff4718763aaa8e960e08501527fad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a561010085015261012080850191909152845180850390910181526101409093019093528151910120905262000173818385620004fb565b5050505050505050506200018d816200099060201b60201c565b506200019b600030620009c3565b620001a7828262000a5f565b5050505050505050505050505062001aaf565b606081620001c88162000b23565b8251806001600160401b03811115620001e557620001e56200141c565b6040519080825280602002602001820160405280156200020f578160200160208202803683370190505b50925080600003620002225750620002d1565b600080516020620079c283398151915260006314d72edb60e21b815b84811015620002cb578781815181106200025c576200025c62001769565b60200260200101519250620002778362000b6b60201b60201c565b62000283838362000ba3565b6200029d838562000d5260201b620012681790919060201c565b878281518110620002b257620002b262001769565b911515602092830291909101909101526001016200023e565b50505050505b50919050565b9055565b6000808284111562000319576000356001600160e01b0319166040516387f6f09560e01b81526004016200031091906200177f565b60405180910390fd5b62000341600080516020620079e283398151915260001b62000d7260201b6200127d1760201c565b91506200037c7fac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff60001b62000d7260201b6200127d1760201c565b9050620003aa84600080516020620079e283398151915260001b620002d760201b620012641790919060201c565b620003e7837fac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff60001b620002d760201b620012641790919060201c565b82846200041160008051602062007a0283398151915260001b62000d7660201b620012811760201c565b60408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156200048a576200048a62001794565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115620004ce57620004ce62001794565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606062000517828462000d9a60201b6200129c1790919060201c565b620005228162000b23565b8251855181148015620005355750845181145b62000563576000356001600160e01b0319166040516306b5667560e21b81526004016200031091906200177f565b806001600160401b038111156200057e576200057e6200141c565b604051908082528060200260200182016040528015620005a8578160200160208202803683370190505b50925080600003620005bb575062000988565b604080518082019091526000808252602082018190527f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c917f8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3917fd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d917f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3919081908190815b89811015620008c9578d81815181106200067e576200067e62001769565b602002602001015194508c81815181106200069d576200069d62001769565b60200260200101519350620006b88562000eb860201b60201c565b620006c38462000eb8565b8e8181518110620006d857620006d862001769565b60200260200101516001600160601b03166000036200071a576000356001600160e01b031916604051637f11b8a360e11b81526004016200031091906200177f565b62000734858a62000ef060201b620013a61790919060201c565b8062000755575062000755848a62000ef060201b620013a61790919060201c565b8062000776575062000776858862000ef060201b620013a61790919060201c565b8062000797575062000797848862000ef060201b620013a61790919060201c565b158c8281518110620007ad57620007ad62001769565b6020026020010190151590811515815250508b8181518110620007d457620007d462001769565b602002602001015115620008c057620007fc858a62000d5260201b620012681790919060201c565b5062000817848862000d5260201b620012681790919060201c565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f908290811062000860576200086062001769565b6020908102919091018101516001600160601b0316908301819052620008879084620017aa565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b60010162000660565b5062000907827f6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c60001b62000f1360201b620013bb1790919060201c565b506200093f635ebae8a060e01b8d8d6040516020016200092992919062001846565b60408051601f1981840301815291905262000f2d565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f60405162000976949392919062001878565b60405180910390a15050505050505050505b509392505050565b600281905560405181907fe5cd1c123a8cf63fa1b7229678db61fe8ae99dbbd27889370b6667c8cae97da190600090a250565b8060036000846004811115620009dd57620009dd62001794565b6004811115620009f157620009f162001794565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600481111562000a325762000a3262001794565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b60005b825181101562000b1e57306001600160a01b031682828151811062000a8b5762000a8b62001769565b60200260200101516001600160a01b03160362000acb576000356001600160e01b03191660405163053265f160e01b81526004016200031091906200177f565b62000b1583828151811062000ae45762000ae462001769565b602002602001015183838151811062000b015762000b0162001769565b6020026020010151620009c360201b60201c565b60010162000a62565b505050565b62000b39816200127360201b620013d21760201c565b1562000b68576000356001600160e01b031916604051630d697db160e11b81526004016200031091906200177f565b50565b806001600160a01b03163b60000362000b6857604051630bfc64a360e21b81526001600160a01b038216600482015260240162000310565b60008160405160240162000bb891906200177f565b60408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b0386169062000c039085906200192e565b600060405180830381855afa9150503d806000811462000c40576040519150601f19603f3d011682016040523d82523d6000602084013e62000c45565b606091505b50915091508162000d1157846001600160a01b03168360405160240162000c6d91906200197a565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b1790525162000ca491906200192e565b600060405180830381855afa9150503d806000811462000ce1576040519150601f19603f3d011682016040523d82523d6000602084013e62000ce6565b606091505b5090925090508162000d1157838560405163069d427960e11b8152600401620003109291906200198f565b8080602001905181019062000d279190620019b2565b62000d4b57838560405163069d427960e11b8152600401620003109291906200198f565b5050505050565b600062000d69836001600160a01b0384166200131e565b90505b92915050565b5490565b600062000d81825490565b905062000d9582620002d7836001620017aa565b919050565b81518151606091908082016001600160401b0381111562000dbf5762000dbf6200141c565b60405190808252806020026020018201604052801562000de9578160200160208202803683370190505b50925060005b8281101562000e4b5785818151811062000e0d5762000e0d62001769565b602002602001015184828151811062000e2a5762000e2a62001769565b6001600160a01b039092166020928302919091019091015260010162000def565b60005b8281101562000eae5785818151811062000e6c5762000e6c62001769565b602002602001015185838151811062000e895762000e8962001769565b6001600160a01b03909216602092830291909101909101526001918201910162000e4e565b5050505092915050565b6001600160a01b03811662000b68576000356001600160e01b03191660405163104c66df60e31b81526004016200031091906200177f565b6001600160a01b0381166000908152600183016020526040812054151562000d69565b600062000d6c8362000f26818562001370565b9250829055565b600062000f54600080516020620079c28339815191526200139060201b620014711760201c565b8051909150600081900362000f695750505050565b6000816001600160401b0381111562000f865762000f866200141c565b60405190808252806020026020018201604052801562000fb0578160200160208202803683370190505b5090506000826001600160401b0381111562000fd05762000fd06200141c565b6040519080825280602002602001820160405280156200100557816020015b606081526020019060019003908162000fef5790505b509050600086866040516020016200101f929190620019d6565b60405160208183030381529060405290506000816040516024016200104591906200197a565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b85811015620012295786818151811062001092576200109262001769565b60200260200101516001600160a01b031683604051620010b391906200192e565b6000604051808303816000865af19150503d8060008114620010f2576040519150601f19603f3d011682016040523d82523d6000602084013e620010f7565b606091505b508683815181106200110d576200110d62001769565b6020026020010186848151811062001129576200112962001769565b602002602001018290528215151515815250505084818151811062001152576200115262001769565b6020026020010151620012205786818151811062001174576200117462001769565b60200260200101516001600160a01b0316826040516200119591906200192e565b6000604051808303816000865af19150503d8060008114620011d4576040519150601f19603f3d011682016040523d82523d6000602084013e620011d9565b606091505b50868381518110620011ef57620011ef62001769565b602002602001018684815181106200120b576200120b62001769565b60200260200101829052821515151581525050505b60010162001074565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b638287868660405162001261949392919062001a09565b60405180910390a15050505050505050565b600081516000036200128757506000919050565b60005b60018351038110156200131557600181015b83518110156200130b57838181518110620012bb57620012bb62001769565b60200260200101516001600160a01b0316848381518110620012e157620012e162001769565b60200260200101516001600160a01b03160362001302575060019392505050565b6001016200129c565b506001016200128a565b50600092915050565b6000818152600183016020526040812054620013675750815460018181018455600084815260208082209093018490558454848252828601909352604090209190915562000d6c565b50600062000d6c565b815481018181101562000d6c57634e487b7160005260116020526024601cfd5b606060006200139f83620013a6565b9392505050565b606081600001805480602002602001604051908101604052809291908181526020018280548015620013f857602002820191906000526020600020905b815481526020019060010190808311620013e3575b50505050509050919050565b80516001600160a01b038116811462000d9557600080fd5b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b03811182821017156200145d576200145d6200141c565b604052919050565b60006001600160401b038211156200148157620014816200141c565b5060051b60200190565b600082601f8301126200149d57600080fd5b81516020620014b6620014b08362001465565b62001432565b82815260059290921b84018101918181019086841115620014d657600080fd5b8286015b84811015620014fc57620014ee8162001404565b8352918301918301620014da565b509695505050505050565b600082601f8301126200151957600080fd5b815160206200152c620014b08362001465565b82815260059290921b840181019181810190868411156200154c57600080fd5b8286015b84811015620014fc5780516001600160601b0381168114620015725760008081fd5b835291830191830162001550565b600082601f8301126200159257600080fd5b81516020620015a5620014b08362001465565b828152600592831b8501820192828201919087851115620015c557600080fd5b8387015b85811015620015f0578051828110620015e25760008081fd5b8452928401928401620015c9565b5090979650505050505050565b60008060008060008060008060008060006101608c8e0312156200162057600080fd5b8b519a5060208c0151995060408c0151985060608c015197506200164760808d0162001404565b60a08d01519097506001600160401b038111156200166457600080fd5b620016728e828f016200148b565b60c08e015190975090506001600160401b038111156200169157600080fd5b6200169f8e828f016200148b565b60e08e015190965090506001600160401b03811115620016be57600080fd5b620016cc8e828f016200148b565b6101008e015190955090506001600160401b03811115620016ec57600080fd5b620016fa8e828f0162001507565b6101208e015190945090506001600160401b038111156200171a57600080fd5b620017288e828f0162001580565b6101408e015190935090506001600160401b038111156200174857600080fd5b620017568e828f016200148b565b9150509295989b509295989b9093969950565b634e487b7160e01b600052603260045260246000fd5b6001600160e01b031991909116815260200190565b634e487b7160e01b600052602160045260246000fd5b8082018082111562000d6c57634e487b7160e01b600052601160045260246000fd5b600081518084526020808501945080840160005b83811015620018075781516001600160a01b031687529582019590820190600101620017e0565b509495945050505050565b600081518084526020808501945080840160005b838110156200180757815115158752958201959082019060010162001826565b6040815260006200185b6040830185620017cc565b82810360208401526200186f818562001812565b95945050505050565b6080815260006200188d608083018762001812565b82810360208481019190915286518083528782019282019060005b81811015620018cf5784516001600160601b031683529383019391830191600101620018a8565b50508481036040860152620018e58188620017cc565b925050508281036060840152620018fd8185620017cc565b979650505050505050565b60005b83811015620019255781810151838201526020016200190b565b50506000910152565b600082516200194281846020870162001908565b9190910192915050565b600081518084526200196681602086016020860162001908565b601f01601f19169290920160200192915050565b60208152600062000d6960208301846200194c565b6001600160e01b03199290921682526001600160a01b0316602082015260400190565b600060208284031215620019c557600080fd5b815180151581146200139f57600080fd5b6001600160e01b0319831681528151600090620019fb81600485016020870162001908565b919091016004019392505050565b60808152600062001a1e60808301876200194c565b60208382038185015262001a338288620017cc565b9150838203604085015262001a49828762001812565b915083820360608501528185518084528284019150828160051b85010183880160005b8381101562001a9e57601f1987840301855262001a8b8383516200194c565b9486019492509085019060010162001a6c565b50909b9a5050505050505050505050565b608051615edb62001ae760003960008181610355015281816105e8015281816108080152818161090201526111530152615edb6000f3fe608060405234801561001057600080fd5b50600436106101f85760003560e01c80624054b8146101fd57806301a5f43f1461021257806306aba0e11461023b57806309fcd8c7146102515780630a44fa43146102645780630b881830146102775780630f7c31891461028a5780631c905e391461029f5780631f425338146102c15780632c5e6520146102d45780632d6d7d73146102f75780632faf925d1461030a57806334d5f37b1461031d57806335da81211461033d5780633644e51514610350578063663ac011146103775780637de5dedd1461038a578063800eaab314610392578063828fc1a1146103a5578063865e6fd3146103b8578063901979d5146103cb5780639a7d3382146103f65780639b19dbfd146104095780639b2ee43714610411578063a1819f9a14610424578063a8a0e32c14610437578063b384abef1461044a578063b405aaf2146104a5578063b9c36209146104b8578063bc4e068f146104d9578063bc9182fd146104ec578063bc96180b146104ff578063c441c4a814610507578063cc7e6b3b1461051e578063d0a50db01461053e578063d78392f814610546578063dafae40814610559578063de981f1b1461056c578063e75235b81461058c578063e9c0349814610594578063f80b5352146105a7578063fb4f6371146105af578063fdc4fa47146105c2575b600080fd5b61021061020b366004614a6b565b6105d5565b005b610225610220366004614aff565b610614565b6040516102329190614bd5565b60405180910390f35b6102436106c7565b604051908152602001610232565b61021061025f366004614be8565b6106e4565b610243610272366004614cb7565b610779565b610210610285366004614a6b565b6107fe565b61029261082c565b6040516102329190614d31565b6102b26102ad366004614d44565b61083e565b60405161023293929190614d90565b6102256102cf366004614cb7565b61085a565b6102e76102e2366004614e58565b6108a7565b6040519015158152602001610232565b610292610305366004614cb7565b6108b4565b610210610318366004614e8d565b6108f8565b61024361032b366004614ee6565b60006020819052908152604090205481565b61022561034b366004614cb7565b610926565b6102437f000000000000000000000000000000000000000000000000000000000000000081565b610210610385366004614f0e565b61096c565b610243610a59565b6102106103a0366004615185565b610ad5565b6102e76103b33660046151e8565b610b1a565b6102106103c6366004615223565b610b28565b6103de6103d936600461524d565b610b43565b6040516001600160601b039091168152602001610232565b610210610404366004614d44565b610b97565b610292610be3565b61021061041f36600461524d565b610bed565b610210610432366004615268565b610d6d565b610210610445366004615341565b610e34565b610494610458366004614d44565b600160208181526000938452604080852090915291835291208054918101546002820154600383015460069093015460ff909416939192909185565b604051610232959493929190615395565b6102e76104b336600461524d565b610e50565b6104cb6104c6366004614d44565b610e64565b6040516102329291906153c3565b6102b26104e7366004614ee6565b610e85565b6102926104fa3660046153d1565b610ea2565b610243610f90565b61050f610f9b565b6040516102329392919061543e565b61053161052c366004614cb7565b610fc5565b6040516102329190615481565b610243611003565b6103de61055436600461524d565b611015565b6102e7610567366004614ee6565b611020565b61057f61057a366004615494565b61105d565b60405161023291906154af565b6104cb6110bf565b6102256105a2366004614cb7565b6110f0565b610292611136565b6102106105bd366004614e8d565b611140565b6102926105d0366004614cb7565b611180565b6105de3361147e565b61060d85858585857f0000000000000000000000000000000000000000000000000000000000000000336114c3565b5050505050565b606061061e611568565b6106bc87878080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808b0282810182019093528a82529093508a92508991829185019084908082843760009201919091525050604080516020808a0282810182019093528982529093508992508891829185019084908082843760009201919091525061159892505050565b979650505050505050565b60006106df600080516020615e868339815191525490565b905090565b6106ed3361147e565b61076e89898989898080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061073392508a91508b905061558e565b8787808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152503392506118e5915050565b505050505050505050565b60008282808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506107ba9250839150611a2f9050565b6107f6848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611a6492505050565b949350505050565b61060d85858585857f0000000000000000000000000000000000000000000000000000000000000000611ae5565b60606106df610839611b90565b611471565b606080606061084d8585611bb4565b9250925092509250925092565b6060610864611568565b6108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611f8b92505050565b9392505050565b60006107f6848484612053565b60606108a083838080602002602001604051908101604052809392919081815260200183836020028082843760009201829052509250612076915050565b92915050565b61060d85858585857f00000000000000000000000000000000000000000000000000000000000000006121d0565b6060610930611568565b6108a08383808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506122ea92505050565b6109753361147e565b60003390506000610a3e468d8d8d80806020026020016040519081016040528093929190818152602001838360200280828437600081840152601f19601f820116905080830192505050505050508c8c80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610a0392508d91508e905061558e565b8a8a808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508b92506123d9915050565b9050610a4b8282856124d5565b505050505050505050505050565b6000610a71600080516020615e268339815191525490565b6001610a89600080516020615e268339815191525490565b610ab7610aa2600080516020615e868339815191525490565b600080516020615e46833981519152906125cc565b610ac191906155b1565b610acb91906155c4565b6106df91906155d7565b333014610b0c576000356001600160e01b0319166040516307337e1960e41b8152600401610b0391906155f9565b60405180910390fd5b610b1682826125f7565b5050565b60006108a060008484612053565b610b30611568565b610b39816126a5565b610b1682826126d2565b600080610b4e61275d565b90506000610b5a612781565b6001600160a01b039485166000908152602093845260408082205490961681529252509190912054600160a01b90046001600160601b0316919050565b6000828152600160208181526040808420858552909152822090810154909103610bd45760405163713b099760e11b815260040160405180910390fd5b610bdd816127a5565b50505050565b60606106df6129ba565b610bf63361147e565b610bff816129c7565b6000610c09612781565b336000908152602082905260409020549091506001600160a01b039081169083168103610c4b5782604051630669b93360e31b8152600401610b0391906154af565b6000610c556129fc565b90506000610c638284612a20565b8015610c745750610c748286611268565b905080610c96578460405163080fab4b60e31b8152600401610b0391906154af565b6000610ca061275d565b6001600160a01b0385811660008181526020848152604080832080546001600160a01b0319908116909155948c16808452818420805433908816811790915584528b8352928190208054909516831790945583519081019290925291810191909152909150610d2a906364b18d0960e11b906060015b604051602081830303815290604052612a35565b6040516001600160a01b03808816919086169033907fcef34cd748f30a1b7a2f214fd1651779f79bc6c1be02785cad5c1f0ee877213d90600090a4505050505050565b610d763361147e565b610e278a8a8a8a8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808e0282810182019093528d82529093508d92508c918291850190849080828437600092019190915250610dec92508a91508b905061558e565b8787808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152503392506123d9915050565b5050505050505050505050565b610e3d3361147e565b610b1633610e4a84615689565b836124d5565b60006108f282610e5e6129fc565b906113a6565b600080610e6f611568565b610e798484612d31565b915091505b9250929050565b6060806060610e95600085611bb4565b9250925092509193909250565b8051606090806001600160401b03811115610ebf57610ebf614feb565b604051908082528060200260200182016040528015610ee8578160200160208202803683370190505b5091506000610ef5612781565b905060005b82811015610f8857816000868381518110610f1757610f1761575d565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160009054906101000a90046001600160a01b0316848281518110610f6857610f6861575d565b6001600160a01b0390921660209283029190910190910152600101610efa565b505050919050565b60006106df60025490565b6060806060610fa8612e26565b9250610fb383610ea2565b9150610fbe83612e33565b9050909192565b60606108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612e3392505050565b60006106df6110106129fc565b612f19565b60006108f282612f23565b600061103b610aa2600080516020615e868339815191525490565b600080516020615e26833981519152546110559084615773565b101592915050565b6000611067612f5d565b600083600f81111561107b5761107b614d66565b60ff1681526020810191909152604001600020546001600160a01b03169050806110ba578160405163409140df60e11b8152600401610b03919061578a565b919050565b6000806110d8600080516020615e468339815191525490565b600080516020615e2683398151915254915091509091565b60606110fa611568565b6108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f8192505050565b60606106df612e26565b6111493361147e565b61117885858585857f000000000000000000000000000000000000000000000000000000000000000033613237565b505050505050565b606081806001600160401b0381111561119b5761119b614feb565b6040519080825280602002602001820160405280156111c4578160200160208202803683370190505b50915060006111d161275d565b905060005b8281101561125b578160008787848181106111f3576111f361575d565b9050602002016020810190611208919061524d565b6001600160a01b039081168252602082019290925260400160002054855191169085908390811061123b5761123b61575d565b6001600160a01b03909216602092830291909101909101526001016111d6565b50505092915050565b9055565b60006108a0836001600160a01b038416613286565b5490565b600061128b825490565b90506110ba826112648360016155b1565b81518151606091908082016001600160401b038111156112be576112be614feb565b6040519080825280602002602001820160405280156112e7578160200160208202803683370190505b50925060005b82811015611341578581815181106113075761130761575d565b60200260200101518482815181106113215761132161575d565b6001600160a01b03909216602092830291909101909101526001016112ed565b60005b8281101561139c5785818151811061135e5761135e61575d565b60200260200101518583815181106113785761137861575d565b6001600160a01b039092166020928302919091019091015260019182019101611344565b5050505092915050565b60006108a0836001600160a01b0384166132d0565b60006108f2836113cb85856132e8565b9250829055565b600081516000036113e557506000919050565b60005b600183510381101561146857600181015b835181101561145f578381815181106114145761141461575d565b60200260200101516001600160a01b03168483815181106114375761143761575d565b60200260200101516001600160a01b031603611457575060019392505050565b6001016113f9565b506001016113e8565b50600092915050565b606060006108a083613307565b61148781612f23565b6001600160601b03166000036114c0576000356001600160e01b0319166003604051620f948f60ea1b8152600401610b039291906157a4565b50565b6114d56114cf88615689565b82613363565b5060006114e96114e489615689565b613450565b905061155e6114f789615689565b8888888861154a8961150a89600061358f565b60405161190160f01b6020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6115598a61150a8a600161358f565b6135c8565b5050505050505050565b333014611596576000356001600160e01b0319166040516307337e1960e41b8152600401610b0391906155f9565b565b60606115a4838361129c565b6115ad81611a2f565b82518551811480156115bf5750845181145b6115ea576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b806001600160401b0381111561160257611602614feb565b60405190808252806020026020018201604052801561162b578160200160208202803683370190505b5092508060000361163c57506118dd565b600061164661382d565b9050600061165261275d565b9050600061165e6129fc565b9050600061166a612781565b9050600080600061167961492b565b60005b8981101561185e578d81815181106116965761169661575d565b602002602001015194508c81815181106116b2576116b261575d565b602002602001015193506116c5856129c7565b6116ce846129c7565b8e81815181106116e0576116e061575d565b60200260200101516001600160601b031660000361171f576000356001600160e01b031916604051637f11b8a360e11b8152600401610b0391906155f9565b61172989866113a6565b80611739575061173989856113a6565b80611749575061174987866113a6565b80611759575061175987856113a6565b158c828151811061176c5761176c61575d565b6020026020010190151590811515815250508b81815181106117905761179061575d565b602002602001015115611856576117a78986611268565b506117b28785611268565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f90829081106117f8576117f861575d565b6020908102919091018101516001600160601b031690830181905261181d90846155b1565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b60010161167c565b50611877600080516020615e86833981519152836113bb565b50611896635ebae8a060e01b8d8d604051602001610d169291906157d2565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f6040516118cb9493929190615800565b60405180910390a15050505050505050505b509392505050565b60006118f16000613851565b905060006040518060c001604052808381526020018a8152602001898980806020026020016040519081016040528093929190818152602001838360200280828437600092018290525093855250505060208083018a905260408084018a9052606090930188905282518b820281810183019094528b815293945090926119a29261199b928d918d9182919085019084908082843760009201919091525060019250612076915050565b8390613901565b90506119b9600254826139f390919063ffffffff16565b60006119c482613450565b6000858152600080516020615de6833981519152602052604090209091506119ed90828d613a94565b8084600080516020615e6683398151915284611a0887613aa4565b878a604051611a1a9493929190615998565b60405180910390a35050505050505050505050565b611a38816113d2565b156114c0576000356001600160e01b031916604051630d697db160e11b8152600401610b0391906155f9565b600081611a7081611a2f565b6000611a7a612781565b905060005b8451811015610f8857816000868381518110611a9d57611a9d61575d565b6020908102919091018101516001600160a01b0316825281019190915260400160002054611adb90600160a01b90046001600160601b0316856155b1565b9350600101611a7f565b6000611af36114e488615689565b6020808901356000908152600180835260408083208c35845290935291902001549091508114611b59576020808801356000908152600180835260408083208b3584529093529082902001549051632bee7fdb60e21b8152610b039183916004016153c3565b611b87611b6588615689565b87878787611b788861150a89600061358f565b6115598961150a8a600161358f565b50505050505050565b7f5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd97624090565b60008281526001602090815260408083208484529091528120600481015460058201546060938493849390929091611bec82846155b1565b9050806001600160401b03811115611c0657611c06614feb565b604051908082528060200260200182016040528015611c2f578160200160208202803683370190505b509550806001600160401b03811115611c4a57611c4a614feb565b604051908082528060200260200182016040528015611c8357816020015b611c70614942565b815260200190600190039081611c685790505b509450806001600160401b03811115611c9e57611c9e614feb565b604051908082528060200260200182016040528015611cc7578160200160208202803683370190505b50965060005b83811015611e1c576000878281518110611ce957611ce961575d565b60200260200101906001811115611d0257611d02614d66565b90816001811115611d1557611d15614d66565b90525060008a81526001602090815260408083208c845290915281206004870180546007909201929184908110611d4e57611d4e61575d565b60009182526020808320909101546001600160a01b0316835282810193909352604091820190208151606081018352815460ff16815260018201549381019390935260020154908201528651879083908110611dac57611dac61575d565b6020026020010181905250846004018181548110611dcc57611dcc61575d565b9060005260206000200160009054906101000a90046001600160a01b0316888281518110611dfc57611dfc61575d565b6001600160a01b0390921660209283029190910190910152600101611ccd565b5060005b82811015611f7f57600187611e3586846155b1565b81518110611e4557611e4561575d565b60200260200101906001811115611e5e57611e5e614d66565b90816001811115611e7157611e71614d66565b90525060008a81526001602090815260408083208c845290915281206005870180546007909201929184908110611eaa57611eaa61575d565b60009182526020808320909101546001600160a01b0316835282810193909352604091820190208151606081018352815460ff168152600182015493810193909352600201549082015286611eff86846155b1565b81518110611f0f57611f0f61575d565b6020026020010181905250846005018181548110611f2f57611f2f61575d565b6000918252602090912001546001600160a01b031688611f4f86846155b1565b81518110611f5f57611f5f61575d565b6001600160a01b0390921660209283029190910190910152600101611e20565b50505050509250925092565b606081611f9781611a2f565b8251806001600160401b03811115611fb157611fb1614feb565b604051908082528060200260200182016040528015611fda578160200160208202803683370190505b5092506000611fe7611b90565b905060005b8281101561204a576120208682815181106120095761200961575d565b602002602001015183612a2090919063ffffffff16565b8582815181106120325761203261575d565b91151560209283029190910190910152600101611fec565b50505050919050565b600083815260016020908152604080832085845290915281206107f69083613bdb565b606082516001600160401b0381111561209157612091614feb565b6040519080825280602002602001820160405280156120ba578160200160208202803683370190505b50905060005b83518110156121c957600360008583815181106120df576120df61575d565b602002602001015160048111156120f8576120f8614d66565b600481111561210957612109614d66565b815260200190815260200160002060009054906101000a90046001600160a01b031682828151811061213d5761213d61575d565b60200260200101906001600160a01b031690816001600160a01b031681525050828015612195575060006001600160a01b03168282815181106121825761218261575d565b60200260200101516001600160a01b0316145b156121c1576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6001016120c0565b5092915050565b600061222e61221f6121e560408a018a615a7f565b8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525060019250612076915050565b61222889615ac8565b90613901565b9050600061223b82613450565b60008080526001602081815285518352600080516020615de683398151915290526040909120015490915081146122af5760008080526001602081815284518352600080516020615de6833981519152905260409182902001549051632bee7fdb60e21b8152610b039183916004016153c3565b60006122c26122bd8a615ac8565b613aa4565b905061076e83898989896122db8a61150a89600061358f565b6115598b61150a8a600161358f565b6060816122f681611a2f565b8251806001600160401b0381111561231057612310614feb565b604051908082528060200260200182016040528015612339578160200160208202803683370190505b5092508060000361234a57506123d3565b6000612354611b90565b905060006314d72edb60e21b815b848110156123cd5787818151811061237c5761237c61575d565b6020026020010151925061238f836126a5565b6123998383613bfd565b6123a38484611268565b8782815181106123b5576123b561575d565b91151560209283029190910190910152600101612362565b50505050505b50919050565b6123e1614962565b87600003612415576000356001600160e01b03191660004660405163092048d160e11b8152600401610b0393929190615b92565b600061242089613851565b90506040518060e001604052808281526020018a815260200189815260200188815260200187815260200186815260200185815250915061246c600254836139f390919063ffffffff16565b600061247783613450565b60008b8152600160209081526040808320868452909152902090915061249e90828b613a94565b80828b600080516020615e0683398151915286886040516124c0929190615bb4565b60405180910390a45050979650505050505050565b4682602001511461250e57602082015160405163092048d160e11b8152610b03916001600160e01b031960003516914690600401615b92565b600061251983613450565b602080850151600090815260018083526040808320885184529093529190200154909150811461257f57602080840151600090815260018083526040808320875184529093529082902001549051632bee7fdb60e21b8152610b039183916004016153c3565b6000612589613d90565b9050600081612596613d9a565b6125a091906155c4565b6125ab9060016155b1565b90506125b5614942565b61155e868685858b866125c78e613da4565b613dbe565b6000825480156121c957828102915080820483146121c957634e487b7160005260116020526024601cfd5b60005b82518110156126a057306001600160a01b031682828151811061261f5761261f61575d565b60200260200101516001600160a01b03160361265c576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6126988382815181106126715761267161575d565b602002602001015183838151811061268b5761268b61575d565b60200260200101516140ea565b6001016125fa565b505050565b806001600160a01b03163b6000036114c05780604051630bfc64a360e21b8152600401610b0391906154af565b806126db612f5d565b600084600f8111156126ef576126ef614d66565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f81111561273057612730614d66565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa390565b7f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e390565b600080825460ff1660048111156127be576127be614d66565b1480156127cf575042826006015411155b905080156110ba5760018201546040517f58f98006a7f2f253f8ae8f8b7cec9008ca05359633561cd7c22f3005682d4a5590600090a260005b60048301548110156128bb5782600801600084600401838154811061282f5761282f61575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916905560048401805460078601929190849081106128785761287861575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19168155600181810183905560029091019190915501612808565b5060005b6005830154811015612972578260080160008460050183815481106128e6576128e661575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19169055600584018054600786019291908490811061292f5761292f61575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff191681556001818101839055600290910191909155016128bf565b50815460ff1916825560006001830181905560028301819055600383018190556129a090600484019061499f565b6129ae60058301600061499f565b60006006830155919050565b60606106df6108396129fc565b6001600160a01b0381166114c0576000356001600160e01b03191660405163104c66df60e31b8152600401610b0391906155f9565b7fd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d90565b60006108a0836001600160a01b03841661417d565b6000612a42610839611b90565b80519091506000819003612a565750505050565b6000816001600160401b03811115612a7057612a70614feb565b604051908082528060200260200182016040528015612a99578160200160208202803683370190505b5090506000826001600160401b03811115612ab657612ab6614feb565b604051908082528060200260200182016040528015612ae957816020015b6060815260200190600190039081612ad45790505b50905060008686604051602001612b01929190615bde565b6040516020818303038152906040529050600081604051602401612b259190615c0f565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b85811015612ce957868181518110612b6e57612b6e61575d565b60200260200101516001600160a01b031683604051612b8d9190615c22565b6000604051808303816000865af19150503d8060008114612bca576040519150601f19603f3d011682016040523d82523d6000602084013e612bcf565b606091505b50868381518110612be257612be261575d565b60200260200101868481518110612bfb57612bfb61575d565b6020026020010182905282151515158152505050848181518110612c2157612c2161575d565b6020026020010151612ce157868181518110612c3f57612c3f61575d565b60200260200101516001600160a01b031682604051612c5e9190615c22565b6000604051808303816000865af19150503d8060008114612c9b576040519150601f19603f3d011682016040523d82523d6000602084013e612ca0565b606091505b50868381518110612cb357612cb361575d565b60200260200101868481518110612ccc57612ccc61575d565b60200260200101829052821515151581525050505b600101612b54565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b6382878686604051612d1f9493929190615c3e565b60405180910390a15050505050505050565b60008082841115612d63576000356001600160e01b0319166040516387f6f09560e01b8152600401610b0391906155f9565b600080516020615e46833981519152549150612d8b600080516020615e268339815191525490565b9050612da4600080516020615e46833981519152859055565b612dbb600080516020615e26833981519152849055565b8284612de67f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d611281565b7f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f88585604051612e179291906153c3565b60405180910390a49250929050565b60606106df61083961382d565b8051606090806001600160401b03811115612e5057612e50614feb565b604051908082528060200260200182016040528015612e79578160200160208202803683370190505b5091506000612e86612781565b905060005b82811015610f8857816000868381518110612ea857612ea861575d565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160149054906101000a90046001600160601b0316848281518110612ef957612ef961575d565b6001600160601b0390921660209283029190910190910152600101612e8b565b60006108f2825490565b6000612f2d612781565b6001600160a01b0390921660009081526020929092525060409020546001600160601b03600160a01b9091041690565b7fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb90565b606081612f8d81611a2f565b8251806001600160401b03811115612fa757612fa7614feb565b604051908082528060200260200182016040528015612fd0578160200160208202803683370190505b50925080600003612fe157506123d3565b6000612feb61275d565b90506000612ff761382d565b905060006130036129fc565b9050600061300f612781565b9050600080600061301e61492b565b60005b898110156131b7578c818151811061303b5761303b61575d565b6020908102919091018101516001600160a01b038082166000908152928c905260409092205490911695509350613071856129c7565b61307a846129c7565b6001600160a01b0385811660009081526020888152604091829020825180840190935254808416808452600160a01b9091046001600160601b031691830191909152909350908516146130ee576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6130f887856113a6565b8015613109575061310988866113a6565b8c828151811061311b5761311b61575d565b6020026020010190151590811515815250508b818151811061313f5761313f61575d565b6020026020010151156131af576131568886612a20565b506131618785612a20565b506001600160a01b03808516600090815260208b8152604080832080546001600160a01b03191690559288168252888152918120558201516131ac906001600160601b0316846155b1565b92505b600101613021565b506131d0600080516020615e8683398151915283614270565b506131ef63c48549de60e01b8d8d604051602001610d169291906157d2565b7fdf3dcd7987202f64648f3acdbf12401e3a2bb23e77e19f99826b5475cbb863698b8d604051613220929190615c8b565b60405180910390a150505050505050505050919050565b61323f614962565b61325161324b89615ac8565b83614280565b905060006132616122bd8a615ac8565b905061327a82898989896122db8a61150a89600061358f565b50979650505050505050565b600061329283836132d0565b6132c8575081546001818101845560008481526020808220909301849055845484825282860190935260409020919091556108f2565b5060006108f2565b60009081526001919091016020526040902054151590565b81548101818110156108f257634e487b7160005260116020526024601cfd5b60608160000180548060200260200160405190810160405280929190818152602001828054801561335757602002820191906000526020600020905b815481526020019060010190808311613343575b50505050509050919050565b602082015160009080820361339e576000356001600160e01b03191660004660405163092048d160e11b8152600401610b0393929190615b92565b6002546133ac9085906139f3565b60006133b785613450565b90506133c282613851565b600083815260016020908152604080832084845290915290819020908701519194506133ef918390613a94565b8451831461341e576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b808383600080516020615e068339815191528888604051613440929190615bb4565b60405180910390a4505092915050565b6080810151606082015160a083015151600092919083906001600160401b0381111561347e5761347e614feb565b6040519080825280602002602001820160405280156134a7578160200160208202803683370190505b5060c086015190915060005b8251811015613506578660a0015181815181106134d2576134d261575d565b6020026020010151805190602001208382815181106134f3576134f361575d565b60209081029190910101526001016134b3565b50604080517fd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a8152875160208083019190915280890151828401529790910151606082015283518702938701939093206080840152835186029386019390932060a0830152805185029085012060c082015281518402919093012060e083015250610100902090565b604080517fd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2815260208101939093528201526060902090565b84158015906135d657508483145b613601576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b600061360b613d90565b9050600081613618613d9a565b61362291906155c4565b61362d9060016155b1565b9050600080366000805b898110156137f1578a8a828181106136515761365161575d565b606002919091019350600090508d8d838181106136705761367061575d565b90506020020160208101906136859190615cb0565b600181111561369657613696614d66565b036136c2576136bb896136ac6020860186615cdc565b8560200135866040013561436d565b9350613739565b60018d8d838181106136d6576136d661575d565b90506020020160208101906136eb9190615cb0565b60018111156136fc576136fc614d66565b03613712576136bb886136ac6020860186615cdc565b6000356001600160e01b031916604051630612418f60e11b8152600401610b0391906155f9565b836001600160a01b0316856001600160a01b031610613779576000356001600160e01b031916604051635d3dcd3160e01b8152600401610b0391906155f9565b839450600061378785613da4565b905080156137e857600192506137d68f8f8f858181106137a9576137a961575d565b90506020020160208101906137be9190615cb0565b8a8a896137d0368b90038b018b615cf7565b87613dbe565b156137e8575050505050505050611b87565b50600101613637565b508061381e576000356001600160e01b03191660405163726b3acb60e01b8152600401610b0391906155f9565b50505050505050505050505050565b7f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c90565b600081815260208190526040812054908190036138805750600090815260208190526040902060019081905590565b60008281526001602090815260408083208484529091528120906138a3826127a5565b9050806138fa576000825460ff1660048111156138c2576138c2614d66565b036138e05760405163757a436360e01b815260040160405180910390fd5b600084815260208190526040902080546001019081905592505b5050919050565b613909614962565b82518152602080840151604080840191909152600091830191909152830151516001600160401b0381111561394057613940614feb565b604051908082528060200260200182016040528015613969578160200160208202803683370190505b5060608083019190915283015160808083019190915283015160a08083019190915283015160c082015260005b8360400151518110156121c9578281815181106139b5576139b561575d565b6020026020010151826060015182815181106139d3576139d361575d565b6001600160a01b0390921660209283029190910190910152600101613996565b6000826060015151118015613a115750816080015151826060015151145b8015613a2657508160a0015151826060015151145b8015613a3b57508160c0015151826060015151145b613a66576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b613a7081426155b1565b82604001511115610b165760405163ad89be9d60e01b815260040160405180910390fd5b6001830191909155600690910155565b60608101516040820151608083015151600092919083906001600160401b03811115613ad257613ad2614feb565b604051908082528060200260200182016040528015613afb578160200160208202803683370190505b5060a086015190915060005b8251811015613b5a5786608001518181518110613b2657613b2661575d565b602002602001015180519060200120838281518110613b4757613b4761575d565b6020908102919091010152600101613b07565b50604080517f1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee911413508152875160208083019190915297880151918101919091528351870293870193909320606084015283518602938601939093206080830152805185029085012060a082015281518402919093012060c08301525060e0902090565b6001600160a01b03166000908152600891909101602052604090205460ff1690565b600081604051602401613c1091906155f9565b60408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b03861690613c59908590615c22565b600060405180830381855afa9150503d8060008114613c94576040519150601f19603f3d011682016040523d82523d6000602084013e613c99565b606091505b509150915081613d5b57846001600160a01b031683604051602401613cbe9190615c0f565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b17905251613cf39190615c22565b600060405180830381855afa9150503d8060008114613d2e576040519150601f19603f3d011682016040523d82523d6000602084013e613d33565b606091505b50909250905081613d5b57838560405163069d427960e11b8152600401610b03929190615d57565b80806020019051810190613d6f9190615d7a565b61060d57838560405163069d427960e11b8152600401610b03929190615d57565b60006106df610a59565b60006106df6106c7565b6000613daf82612f23565b6001600160601b031692915050565b60208088015188516000828152600184526040808220838352909452928320613de6816127a5565b15613df757600193505050506106bc565b6020808c015160009081529081905260409020548214613e38576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b6000815460ff166004811115613e5057613e50614d66565b14613e6e576040516322de95ff60e21b815260040160405180910390fd5b613e788188613bdb565b15613e98578660405163025fd59560e41b8152600401610b0391906154af565b6001600160a01b03871660009081526008820160209081526040909120805460ff19166001179055860151151580613ed35750604086015115155b80613ee15750855160ff1615155b15613f28576001600160a01b03871660009081526007820160209081526040918290208851815460ff191660ff909116178155908801516001820155908701516002909101555b866001600160a01b031681600101547f1203f9e81c814a35f5f4cc24087b2a24c6fb7986a9f1406b68a9484882c93a238c88604051613f68929190615d9c565b60405180910390a3600080808c6001811115613f8657613f86614d66565b03613fdb576004830180546001810182556000918252602082200180546001600160a01b0319166001600160a01b038c16179055600384018054899290613fce9084906155b1565b9250508190559150614040565b60018c6001811115613fef57613fef614d66565b03613712576005830180546001810182556000918252602082200180546001600160a01b0319166001600160a01b038c161790556002840180548992906140379084906155b1565b92505081905590505b8a821061409457825460ff19166001908117845580840154604051919750907f5c819725ea53655a3b898f3df59b66489761935454e9212ca1e5ebd759953d0b90600090a261408f838e614395565b6140da565b8981106140da57825460ff19166003178355600180840154604051919750907f55295d4ce992922fa2e5ffbf3a3dcdb367de0a15e125ace083456017fd22060f90600090a25b5050505050979650505050505050565b806003600084600481111561410157614101614d66565b600481111561411257614112614d66565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600481111561415057614150614d66565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b600081815260018301602052604081205480156142665760006141a16001836155c4565b85549091506000906141b5906001906155c4565b905081811461421a5760008660000182815481106141d5576141d561575d565b90600052602060002001549050808760000184815481106141f8576141f861575d565b6000918252602080832090910192909255918252600188019052604090208390555b855486908061422b5761422b615daa565b6001900381819060005260206000200160009055905585600101600086815260200190815260200160002060009055600193505050506108f2565b60009150506108f2565b60006108f2836113cb8585614402565b614288614962565b6142a161429a84604001516001612076565b8490613901565b90506142b8600254826139f390919063ffffffff16565b60006142c382613450565b905060006142d16000613851565b6000818152600080516020615de68339815191526020908152604090912090870151919250614301918490613a94565b82518114614330576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b8181600080516020615e668339815191528561434b89613aa4565b898960405161435d9493929190615998565b60405180910390a3505092915050565b600080600061437e8787878761442b565b9150915061438b8161450e565b5095945050505050565b61439e816146bf565b15610b1657815460ff191660021782556000806143ba836146d9565b9150915083600101547fe134987599ae266ec90edeff1b26125b287dbb57b10822649432d1bb26537fba83836040516143f4929190615dc0565b60405180910390a250505050565b600082548281101561442157634e487b7160005260116020526024601cfd5b9190910392915050565b6000806fa2a8918ca85bafe22016d0b997e4df60600160ff1b038311156144585750600090506003614505565b8460ff16601b1415801561447057508460ff16601c14155b156144815750600090506004614505565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa1580156144d5573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166144fe57600060019250925050614505565b9150600090505b94509492505050565b600081600481111561452257614522614d66565b0361452a5750565b600181600481111561453e5761453e614d66565b036145865760405162461bcd60e51b815260206004820152601860248201527745434453413a20696e76616c6964207369676e617475726560401b6044820152606401610b03565b600281600481111561459a5761459a614d66565b036145e75760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610b03565b60038160048111156145fb576145fb614d66565b036146535760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610b03565b600481600481111561466757614667614d66565b036114c05760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610b03565b60008160200151600014806108f257505060200151461490565b6060806146e5836146bf565b61471757602083015160405163092048d160e11b8152610b03916001600160e01b031960003516914690600401615b92565b8260600151516001600160401b0381111561473457614734614feb565b60405190808252806020026020018201604052801561475d578160200160208202803683370190505b5091508260600151516001600160401b0381111561477d5761477d614feb565b6040519080825280602002602001820160405280156147b057816020015b606081526020019060019003908161479b5790505b50905060005b836060015151811015614925578360c0015181815181106147d9576147d961575d565b60200260200101515a1161480c576147f084613450565b6040516307aec4ab60e21b8152600401610b0391815260200190565b836060015181815181106148225761482261575d565b60200260200101516001600160a01b0316846080015182815181106148495761484961575d565b60200260200101518560c0015183815181106148675761486761575d565b6020026020010151908660a0015184815181106148865761488661575d565b602002602001015160405161489b9190615c22565b600060405180830381858888f193505050503d80600081146148d9576040519150601f19603f3d011682016040523d82523d6000602084013e6148de565b606091505b508483815181106148f1576148f161575d565b6020026020010184848151811061490a5761490a61575d565b602090810291909101019190915290151590526001016147b6565b50915091565b604080518082019091526000808252602082015290565b604080516060810182526000808252602082018190529181019190915290565b6040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b50805460008255906000526020600020908101906114c091905b808211156149cd57600081556001016149b9565b5090565b600060e082840312156123d357600080fd5b60008083601f8401126149f557600080fd5b5081356001600160401b03811115614a0c57600080fd5b6020830191508360208260051b8501011115610e7e57600080fd5b60008083601f840112614a3957600080fd5b5081356001600160401b03811115614a5057600080fd5b602083019150836020606083028501011115610e7e57600080fd5b600080600080600060608688031215614a8357600080fd5b85356001600160401b0380821115614a9a57600080fd5b614aa689838a016149d1565b96506020880135915080821115614abc57600080fd5b614ac889838a016149e3565b90965094506040880135915080821115614ae157600080fd5b50614aee88828901614a27565b969995985093965092949392505050565b60008060008060008060608789031215614b1857600080fd5b86356001600160401b0380821115614b2f57600080fd5b614b3b8a838b016149e3565b90985096506020890135915080821115614b5457600080fd5b614b608a838b016149e3565b90965094506040890135915080821115614b7957600080fd5b50614b8689828a016149e3565b979a9699509497509295939492505050565b600081518084526020808501945080840160005b83811015614bca578151151587529582019590820190600101614bac565b509495945050505050565b6020815260006108a06020830184614b98565b600080600080600080600080600060a08a8c031215614c0657600080fd5b8935985060208a01356001600160401b0380821115614c2457600080fd5b614c308d838e016149e3565b909a50985060408c0135915080821115614c4957600080fd5b614c558d838e016149e3565b909850965060608c0135915080821115614c6e57600080fd5b614c7a8d838e016149e3565b909650945060808c0135915080821115614c9357600080fd5b50614ca08c828d016149e3565b915080935050809150509295985092959850929598565b60008060208385031215614cca57600080fd5b82356001600160401b03811115614ce057600080fd5b614cec858286016149e3565b90969095509350505050565b600081518084526020808501945080840160005b83811015614bca5781516001600160a01b031687529582019590820190600101614d0c565b6020815260006108a06020830184614cf8565b60008060408385031215614d5757600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b60028110614d8c57614d8c614d66565b9052565b60006060808352614da381840187614cf8565b83810360208581019190915286518083528782019282019060005b81811015614de157614dd1838651614d7c565b9383019391830191600101614dbe565b505060409250858103838701528087518083528383019150838901925060005b81811015614e31578351805160ff1684528581015186850152860151868401529284019291860191600101614e01565b50909a9950505050505050505050565b80356001600160a01b03811681146110ba57600080fd5b600080600060608486031215614e6d57600080fd5b8335925060208401359150614e8460408501614e41565b90509250925092565b600080600080600060608688031215614ea557600080fd5b85356001600160401b0380821115614ebc57600080fd5b9087019060c0828a031215614ed057600080fd5b90955060208701359080821115614abc57600080fd5b600060208284031215614ef857600080fd5b5035919050565b8035600281106110ba57600080fd5b60008060008060008060008060008060c08b8d031215614f2d57600080fd5b8a35995060208b01356001600160401b0380821115614f4b57600080fd5b614f578e838f016149e3565b909b50995060408d0135915080821115614f7057600080fd5b614f7c8e838f016149e3565b909950975060608d0135915080821115614f9557600080fd5b614fa18e838f016149e3565b909750955060808d0135915080821115614fba57600080fd5b50614fc78d828e016149e3565b9094509250614fda905060a08c01614eff565b90509295989b9194979a5092959850565b634e487b7160e01b600052604160045260246000fd5b60405160e081016001600160401b038111828210171561502357615023614feb565b60405290565b60405160c081016001600160401b038111828210171561502357615023614feb565b604051601f8201601f191681016001600160401b038111828210171561507357615073614feb565b604052919050565b60006001600160401b0382111561509457615094614feb565b5060051b60200190565b600082601f8301126150af57600080fd5b813560206150c46150bf8361507b565b61504b565b828152600592831b85018201928282019190878511156150e357600080fd5b8387015b8581101561510b5780358281106150fe5760008081fd5b84529284019284016150e7565b5090979650505050505050565b600082601f83011261512957600080fd5b813560206151396150bf8361507b565b82815260059290921b8401810191818101908684111561515857600080fd5b8286015b8481101561517a5761516d81614e41565b835291830191830161515c565b509695505050505050565b6000806040838503121561519857600080fd5b82356001600160401b03808211156151af57600080fd5b6151bb8683870161509e565b935060208501359150808211156151d157600080fd5b506151de85828601615118565b9150509250929050565b600080604083850312156151fb57600080fd5b8235915061520b60208401614e41565b90509250929050565b8035601081106110ba57600080fd5b6000806040838503121561523657600080fd5b61523f83615214565b915061520b60208401614e41565b60006020828403121561525f57600080fd5b6108a082614e41565b60008060008060008060008060008060c08b8d03121561528757600080fd5b8a35995060208b0135985060408b01356001600160401b03808211156152ac57600080fd5b6152b88e838f016149e3565b909a50985060608d01359150808211156152d157600080fd5b6152dd8e838f016149e3565b909850965060808d01359150808211156152f657600080fd5b6153028e838f016149e3565b909650945060a08d013591508082111561531b57600080fd5b506153288d828e016149e3565b915080935050809150509295989b9194979a5092959850565b6000806040838503121561535457600080fd5b82356001600160401b0381111561536a57600080fd5b615376858286016149d1565b92505061520b60208401614eff565b600581106114c0576114c0614d66565b60a081016153a287615385565b95815260208101949094526040840192909252606083015260809091015290565b918252602082015260400190565b6000602082840312156153e357600080fd5b81356001600160401b038111156153f957600080fd5b6107f684828501615118565b600081518084526020808501945080840160005b83811015614bca5781516001600160601b031687529582019590820190600101615419565b6060815260006154516060830186614cf8565b82810360208401526154638186614cf8565b905082810360408401526154778185615405565b9695505050505050565b6020815260006108a06020830184615405565b6000602082840312156154a657600080fd5b6108a082615214565b6001600160a01b0391909116815260200190565b60006154d16150bf8461507b565b8381529050602080820190600585901b8401868111156154f057600080fd5b845b818110156155835780356001600160401b03808211156155125760008081fd5b8188019150601f8a818401126155285760008081fd5b82358281111561553a5761553a614feb565b61554b818301601f1916880161504b565b92508083528b8782860101111561556457600091508182fd5b80878501888501376000908301870152508552509282019282016154f2565b505050509392505050565b60006108a03684846154c3565b634e487b7160e01b600052601160045260246000fd5b808201808211156108f2576108f261559b565b818103818111156108f2576108f261559b565b6000826155f457634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b031991909116815260200190565b600082601f83011261561f57600080fd5b8135602061562f6150bf8361507b565b82815260059290921b8401810191818101908684111561564e57600080fd5b8286015b8481101561517a5780358352918301918301615652565b600082601f83011261567a57600080fd5b6108a0838335602085016154c3565b600060e0823603121561569b57600080fd5b6156a3615001565b82358152602080840135908201526040808401359082015260608301356001600160401b03808211156156d557600080fd5b6156e136838701615118565b606084015260808501359150808211156156fa57600080fd5b6157063683870161560e565b608084015260a085013591508082111561571f57600080fd5b61572b36838701615669565b60a084015260c085013591508082111561574457600080fd5b506157513682860161560e565b60c08301525092915050565b634e487b7160e01b600052603260045260246000fd5b80820281158282048414176108f2576108f261559b565b602081016010831061579e5761579e614d66565b91905290565b6001600160e01b03198316815260408101600b83106157c5576157c5614d66565b8260208301529392505050565b6040815260006157e56040830185614cf8565b82810360208401526157f78185614b98565b95945050505050565b6080815260006158136080830187614b98565b82810360208401526158258187615405565b905082810360408401526158398186614cf8565b905082810360608401526106bc8185614cf8565b600081518084526020808501945080840160005b83811015614bca57815187529582019590820190600101615861565b60005b83811015615898578181015183820152602001615880565b50506000910152565b600081518084526158b981602086016020860161587d565b601f01601f19169290920160200192915050565b600082825180855260208086019550808260051b84010181860160005b8481101561510b57601f198684030189526159068383516158a1565b988401989250908301906001016158ea565b8051825260208101516020830152604081015160408301526000606082015160e0606085015261594b60e0850182614cf8565b905060808301518482036080860152615964828261584d565b91505060a083015184820360a086015261597e82826158cd565b91505060c083015184820360c08601526157f7828261584d565b6080815260006159ab6080830187615918565b60208681850152838203604085015260c08201865183528187015182840152604087015160c0604085015281815180845260e0860191508483019350600092505b80831015615a155783516159ff81615385565b82529284019260019290920191908401906159ec565b50606089015193508481036060860152615a2f818561584d565b935050505060808601518282036080840152615a4b82826158cd565b91505060a086015182820360a0840152615a65828261584d565b93505050506157f760608301846001600160a01b03169052565b6000808335601e19843603018112615a9657600080fd5b8301803591506001600160401b03821115615ab057600080fd5b6020019150600581901b3603821315610e7e57600080fd5b600060c08236031215615ada57600080fd5b615ae2615029565b823581526020808401359082015260408301356001600160401b0380821115615b0a57600080fd5b615b163683870161509e565b60408401526060850135915080821115615b2f57600080fd5b615b3b3683870161560e565b60608401526080850135915080821115615b5457600080fd5b615b6036838701615669565b608084015260a0850135915080821115615b7957600080fd5b50615b863682860161560e565b60a08301525092915050565b6001600160e01b03199390931683526020830191909152604082015260600190565b604081526000615bc76040830185615918565b905060018060a01b03831660208301529392505050565b6001600160e01b0319831681528151600090615c0181600485016020870161587d565b919091016004019392505050565b6020815260006108a060208301846158a1565b60008251615c3481846020870161587d565b9190910192915050565b608081526000615c5160808301876158a1565b8281036020840152615c638187614cf8565b90508281036040840152615c778186614b98565b905082810360608401526106bc81856158cd565b604081526000615c9e6040830185614b98565b82810360208401526157f78185614cf8565b600060208284031215615cc257600080fd5b6108a082614eff565b803560ff811681146110ba57600080fd5b600060208284031215615cee57600080fd5b6108a082615ccb565b600060608284031215615d0957600080fd5b604051606081016001600160401b0381118282101715615d2b57615d2b614feb565b604052615d3783615ccb565b815260208301356020820152604083013560408201528091505092915050565b6001600160e01b03199290921682526001600160a01b0316602082015260400190565b600060208284031215615d8c57600080fd5b815180151581146108a057600080fd5b604081016157c58285614d7c565b634e487b7160e01b600052603160045260246000fd5b604081526000615dd36040830185614b98565b82810360208401526157f781856158cd56fea6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49a57d40f1496988cf60ab7c9d5ba4ff83647f67d3898d441a3aaf21b651678fd9ac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ffc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f771d78ae9e5fca95a532fb0971d575d0ce9b59d14823c063e08740137e0e0eca6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644ca2646970667358221220df018f67471d8972a68d3658e92c2357f3934b05a2c1b9ba9c4504aa64187f1964736f6c634300081100335da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240c55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101f85760003560e01c80624054b8146101fd57806301a5f43f1461021257806306aba0e11461023b57806309fcd8c7146102515780630a44fa43146102645780630b881830146102775780630f7c31891461028a5780631c905e391461029f5780631f425338146102c15780632c5e6520146102d45780632d6d7d73146102f75780632faf925d1461030a57806334d5f37b1461031d57806335da81211461033d5780633644e51514610350578063663ac011146103775780637de5dedd1461038a578063800eaab314610392578063828fc1a1146103a5578063865e6fd3146103b8578063901979d5146103cb5780639a7d3382146103f65780639b19dbfd146104095780639b2ee43714610411578063a1819f9a14610424578063a8a0e32c14610437578063b384abef1461044a578063b405aaf2146104a5578063b9c36209146104b8578063bc4e068f146104d9578063bc9182fd146104ec578063bc96180b146104ff578063c441c4a814610507578063cc7e6b3b1461051e578063d0a50db01461053e578063d78392f814610546578063dafae40814610559578063de981f1b1461056c578063e75235b81461058c578063e9c0349814610594578063f80b5352146105a7578063fb4f6371146105af578063fdc4fa47146105c2575b600080fd5b61021061020b366004614a6b565b6105d5565b005b610225610220366004614aff565b610614565b6040516102329190614bd5565b60405180910390f35b6102436106c7565b604051908152602001610232565b61021061025f366004614be8565b6106e4565b610243610272366004614cb7565b610779565b610210610285366004614a6b565b6107fe565b61029261082c565b6040516102329190614d31565b6102b26102ad366004614d44565b61083e565b60405161023293929190614d90565b6102256102cf366004614cb7565b61085a565b6102e76102e2366004614e58565b6108a7565b6040519015158152602001610232565b610292610305366004614cb7565b6108b4565b610210610318366004614e8d565b6108f8565b61024361032b366004614ee6565b60006020819052908152604090205481565b61022561034b366004614cb7565b610926565b6102437f000000000000000000000000000000000000000000000000000000000000000081565b610210610385366004614f0e565b61096c565b610243610a59565b6102106103a0366004615185565b610ad5565b6102e76103b33660046151e8565b610b1a565b6102106103c6366004615223565b610b28565b6103de6103d936600461524d565b610b43565b6040516001600160601b039091168152602001610232565b610210610404366004614d44565b610b97565b610292610be3565b61021061041f36600461524d565b610bed565b610210610432366004615268565b610d6d565b610210610445366004615341565b610e34565b610494610458366004614d44565b600160208181526000938452604080852090915291835291208054918101546002820154600383015460069093015460ff909416939192909185565b604051610232959493929190615395565b6102e76104b336600461524d565b610e50565b6104cb6104c6366004614d44565b610e64565b6040516102329291906153c3565b6102b26104e7366004614ee6565b610e85565b6102926104fa3660046153d1565b610ea2565b610243610f90565b61050f610f9b565b6040516102329392919061543e565b61053161052c366004614cb7565b610fc5565b6040516102329190615481565b610243611003565b6103de61055436600461524d565b611015565b6102e7610567366004614ee6565b611020565b61057f61057a366004615494565b61105d565b60405161023291906154af565b6104cb6110bf565b6102256105a2366004614cb7565b6110f0565b610292611136565b6102106105bd366004614e8d565b611140565b6102926105d0366004614cb7565b611180565b6105de3361147e565b61060d85858585857f0000000000000000000000000000000000000000000000000000000000000000336114c3565b5050505050565b606061061e611568565b6106bc87878080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808b0282810182019093528a82529093508a92508991829185019084908082843760009201919091525050604080516020808a0282810182019093528982529093508992508891829185019084908082843760009201919091525061159892505050565b979650505050505050565b60006106df600080516020615e868339815191525490565b905090565b6106ed3361147e565b61076e89898989898080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061073392508a91508b905061558e565b8787808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152503392506118e5915050565b505050505050505050565b60008282808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506107ba9250839150611a2f9050565b6107f6848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611a6492505050565b949350505050565b61060d85858585857f0000000000000000000000000000000000000000000000000000000000000000611ae5565b60606106df610839611b90565b611471565b606080606061084d8585611bb4565b9250925092509250925092565b6060610864611568565b6108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250611f8b92505050565b9392505050565b60006107f6848484612053565b60606108a083838080602002602001604051908101604052809392919081815260200183836020028082843760009201829052509250612076915050565b92915050565b61060d85858585857f00000000000000000000000000000000000000000000000000000000000000006121d0565b6060610930611568565b6108a08383808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506122ea92505050565b6109753361147e565b60003390506000610a3e468d8d8d80806020026020016040519081016040528093929190818152602001838360200280828437600081840152601f19601f820116905080830192505050505050508c8c80806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250610a0392508d91508e905061558e565b8a8a808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508b92506123d9915050565b9050610a4b8282856124d5565b505050505050505050505050565b6000610a71600080516020615e268339815191525490565b6001610a89600080516020615e268339815191525490565b610ab7610aa2600080516020615e868339815191525490565b600080516020615e46833981519152906125cc565b610ac191906155b1565b610acb91906155c4565b6106df91906155d7565b333014610b0c576000356001600160e01b0319166040516307337e1960e41b8152600401610b0391906155f9565b60405180910390fd5b610b1682826125f7565b5050565b60006108a060008484612053565b610b30611568565b610b39816126a5565b610b1682826126d2565b600080610b4e61275d565b90506000610b5a612781565b6001600160a01b039485166000908152602093845260408082205490961681529252509190912054600160a01b90046001600160601b0316919050565b6000828152600160208181526040808420858552909152822090810154909103610bd45760405163713b099760e11b815260040160405180910390fd5b610bdd816127a5565b50505050565b60606106df6129ba565b610bf63361147e565b610bff816129c7565b6000610c09612781565b336000908152602082905260409020549091506001600160a01b039081169083168103610c4b5782604051630669b93360e31b8152600401610b0391906154af565b6000610c556129fc565b90506000610c638284612a20565b8015610c745750610c748286611268565b905080610c96578460405163080fab4b60e31b8152600401610b0391906154af565b6000610ca061275d565b6001600160a01b0385811660008181526020848152604080832080546001600160a01b0319908116909155948c16808452818420805433908816811790915584528b8352928190208054909516831790945583519081019290925291810191909152909150610d2a906364b18d0960e11b906060015b604051602081830303815290604052612a35565b6040516001600160a01b03808816919086169033907fcef34cd748f30a1b7a2f214fd1651779f79bc6c1be02785cad5c1f0ee877213d90600090a4505050505050565b610d763361147e565b610e278a8a8a8a8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050604080516020808e0282810182019093528d82529093508d92508c918291850190849080828437600092019190915250610dec92508a91508b905061558e565b8787808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152503392506123d9915050565b5050505050505050505050565b610e3d3361147e565b610b1633610e4a84615689565b836124d5565b60006108f282610e5e6129fc565b906113a6565b600080610e6f611568565b610e798484612d31565b915091505b9250929050565b6060806060610e95600085611bb4565b9250925092509193909250565b8051606090806001600160401b03811115610ebf57610ebf614feb565b604051908082528060200260200182016040528015610ee8578160200160208202803683370190505b5091506000610ef5612781565b905060005b82811015610f8857816000868381518110610f1757610f1761575d565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160009054906101000a90046001600160a01b0316848281518110610f6857610f6861575d565b6001600160a01b0390921660209283029190910190910152600101610efa565b505050919050565b60006106df60025490565b6060806060610fa8612e26565b9250610fb383610ea2565b9150610fbe83612e33565b9050909192565b60606108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612e3392505050565b60006106df6110106129fc565b612f19565b60006108f282612f23565b600061103b610aa2600080516020615e868339815191525490565b600080516020615e26833981519152546110559084615773565b101592915050565b6000611067612f5d565b600083600f81111561107b5761107b614d66565b60ff1681526020810191909152604001600020546001600160a01b03169050806110ba578160405163409140df60e11b8152600401610b03919061578a565b919050565b6000806110d8600080516020615e468339815191525490565b600080516020615e2683398151915254915091509091565b60606110fa611568565b6108a0838380806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f8192505050565b60606106df612e26565b6111493361147e565b61117885858585857f000000000000000000000000000000000000000000000000000000000000000033613237565b505050505050565b606081806001600160401b0381111561119b5761119b614feb565b6040519080825280602002602001820160405280156111c4578160200160208202803683370190505b50915060006111d161275d565b905060005b8281101561125b578160008787848181106111f3576111f361575d565b9050602002016020810190611208919061524d565b6001600160a01b039081168252602082019290925260400160002054855191169085908390811061123b5761123b61575d565b6001600160a01b03909216602092830291909101909101526001016111d6565b50505092915050565b9055565b60006108a0836001600160a01b038416613286565b5490565b600061128b825490565b90506110ba826112648360016155b1565b81518151606091908082016001600160401b038111156112be576112be614feb565b6040519080825280602002602001820160405280156112e7578160200160208202803683370190505b50925060005b82811015611341578581815181106113075761130761575d565b60200260200101518482815181106113215761132161575d565b6001600160a01b03909216602092830291909101909101526001016112ed565b60005b8281101561139c5785818151811061135e5761135e61575d565b60200260200101518583815181106113785761137861575d565b6001600160a01b039092166020928302919091019091015260019182019101611344565b5050505092915050565b60006108a0836001600160a01b0384166132d0565b60006108f2836113cb85856132e8565b9250829055565b600081516000036113e557506000919050565b60005b600183510381101561146857600181015b835181101561145f578381815181106114145761141461575d565b60200260200101516001600160a01b03168483815181106114375761143761575d565b60200260200101516001600160a01b031603611457575060019392505050565b6001016113f9565b506001016113e8565b50600092915050565b606060006108a083613307565b61148781612f23565b6001600160601b03166000036114c0576000356001600160e01b0319166003604051620f948f60ea1b8152600401610b039291906157a4565b50565b6114d56114cf88615689565b82613363565b5060006114e96114e489615689565b613450565b905061155e6114f789615689565b8888888861154a8961150a89600061358f565b60405161190160f01b6020820152602281018390526042810182905260009060620160405160208183030381529060405280519060200120905092915050565b6115598a61150a8a600161358f565b6135c8565b5050505050505050565b333014611596576000356001600160e01b0319166040516307337e1960e41b8152600401610b0391906155f9565b565b60606115a4838361129c565b6115ad81611a2f565b82518551811480156115bf5750845181145b6115ea576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b806001600160401b0381111561160257611602614feb565b60405190808252806020026020018201604052801561162b578160200160208202803683370190505b5092508060000361163c57506118dd565b600061164661382d565b9050600061165261275d565b9050600061165e6129fc565b9050600061166a612781565b9050600080600061167961492b565b60005b8981101561185e578d81815181106116965761169661575d565b602002602001015194508c81815181106116b2576116b261575d565b602002602001015193506116c5856129c7565b6116ce846129c7565b8e81815181106116e0576116e061575d565b60200260200101516001600160601b031660000361171f576000356001600160e01b031916604051637f11b8a360e11b8152600401610b0391906155f9565b61172989866113a6565b80611739575061173989856113a6565b80611749575061174987866113a6565b80611759575061175987856113a6565b158c828151811061176c5761176c61575d565b6020026020010190151590811515815250508b81815181106117905761179061575d565b602002602001015115611856576117a78986611268565b506117b28785611268565b506001600160a01b03848116600081815260208b90526040902080546001600160a01b0319169288169290921790915582528e518f90829081106117f8576117f861575d565b6020908102919091018101516001600160601b031690830181905261181d90846155b1565b6001600160a01b038087166000908152602089815260409091208551918601516001600160601b0316600160a01b029190921617905592505b60010161167c565b50611877600080516020615e86833981519152836113bb565b50611896635ebae8a060e01b8d8d604051602001610d169291906157d2565b7f897810999654e525e272b5909785c4d0ceaee1bbf9c87d9091a37558b0423b788b8f8f8f6040516118cb9493929190615800565b60405180910390a15050505050505050505b509392505050565b60006118f16000613851565b905060006040518060c001604052808381526020018a8152602001898980806020026020016040519081016040528093929190818152602001838360200280828437600092018290525093855250505060208083018a905260408084018a9052606090930188905282518b820281810183019094528b815293945090926119a29261199b928d918d9182919085019084908082843760009201919091525060019250612076915050565b8390613901565b90506119b9600254826139f390919063ffffffff16565b60006119c482613450565b6000858152600080516020615de6833981519152602052604090209091506119ed90828d613a94565b8084600080516020615e6683398151915284611a0887613aa4565b878a604051611a1a9493929190615998565b60405180910390a35050505050505050505050565b611a38816113d2565b156114c0576000356001600160e01b031916604051630d697db160e11b8152600401610b0391906155f9565b600081611a7081611a2f565b6000611a7a612781565b905060005b8451811015610f8857816000868381518110611a9d57611a9d61575d565b6020908102919091018101516001600160a01b0316825281019190915260400160002054611adb90600160a01b90046001600160601b0316856155b1565b9350600101611a7f565b6000611af36114e488615689565b6020808901356000908152600180835260408083208c35845290935291902001549091508114611b59576020808801356000908152600180835260408083208b3584529093529082902001549051632bee7fdb60e21b8152610b039183916004016153c3565b611b87611b6588615689565b87878787611b788861150a89600061358f565b6115598961150a8a600161358f565b50505050505050565b7f5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd97624090565b60008281526001602090815260408083208484529091528120600481015460058201546060938493849390929091611bec82846155b1565b9050806001600160401b03811115611c0657611c06614feb565b604051908082528060200260200182016040528015611c2f578160200160208202803683370190505b509550806001600160401b03811115611c4a57611c4a614feb565b604051908082528060200260200182016040528015611c8357816020015b611c70614942565b815260200190600190039081611c685790505b509450806001600160401b03811115611c9e57611c9e614feb565b604051908082528060200260200182016040528015611cc7578160200160208202803683370190505b50965060005b83811015611e1c576000878281518110611ce957611ce961575d565b60200260200101906001811115611d0257611d02614d66565b90816001811115611d1557611d15614d66565b90525060008a81526001602090815260408083208c845290915281206004870180546007909201929184908110611d4e57611d4e61575d565b60009182526020808320909101546001600160a01b0316835282810193909352604091820190208151606081018352815460ff16815260018201549381019390935260020154908201528651879083908110611dac57611dac61575d565b6020026020010181905250846004018181548110611dcc57611dcc61575d565b9060005260206000200160009054906101000a90046001600160a01b0316888281518110611dfc57611dfc61575d565b6001600160a01b0390921660209283029190910190910152600101611ccd565b5060005b82811015611f7f57600187611e3586846155b1565b81518110611e4557611e4561575d565b60200260200101906001811115611e5e57611e5e614d66565b90816001811115611e7157611e71614d66565b90525060008a81526001602090815260408083208c845290915281206005870180546007909201929184908110611eaa57611eaa61575d565b60009182526020808320909101546001600160a01b0316835282810193909352604091820190208151606081018352815460ff168152600182015493810193909352600201549082015286611eff86846155b1565b81518110611f0f57611f0f61575d565b6020026020010181905250846005018181548110611f2f57611f2f61575d565b6000918252602090912001546001600160a01b031688611f4f86846155b1565b81518110611f5f57611f5f61575d565b6001600160a01b0390921660209283029190910190910152600101611e20565b50505050509250925092565b606081611f9781611a2f565b8251806001600160401b03811115611fb157611fb1614feb565b604051908082528060200260200182016040528015611fda578160200160208202803683370190505b5092506000611fe7611b90565b905060005b8281101561204a576120208682815181106120095761200961575d565b602002602001015183612a2090919063ffffffff16565b8582815181106120325761203261575d565b91151560209283029190910190910152600101611fec565b50505050919050565b600083815260016020908152604080832085845290915281206107f69083613bdb565b606082516001600160401b0381111561209157612091614feb565b6040519080825280602002602001820160405280156120ba578160200160208202803683370190505b50905060005b83518110156121c957600360008583815181106120df576120df61575d565b602002602001015160048111156120f8576120f8614d66565b600481111561210957612109614d66565b815260200190815260200160002060009054906101000a90046001600160a01b031682828151811061213d5761213d61575d565b60200260200101906001600160a01b031690816001600160a01b031681525050828015612195575060006001600160a01b03168282815181106121825761218261575d565b60200260200101516001600160a01b0316145b156121c1576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6001016120c0565b5092915050565b600061222e61221f6121e560408a018a615a7f565b8080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525060019250612076915050565b61222889615ac8565b90613901565b9050600061223b82613450565b60008080526001602081815285518352600080516020615de683398151915290526040909120015490915081146122af5760008080526001602081815284518352600080516020615de6833981519152905260409182902001549051632bee7fdb60e21b8152610b039183916004016153c3565b60006122c26122bd8a615ac8565b613aa4565b905061076e83898989896122db8a61150a89600061358f565b6115598b61150a8a600161358f565b6060816122f681611a2f565b8251806001600160401b0381111561231057612310614feb565b604051908082528060200260200182016040528015612339578160200160208202803683370190505b5092508060000361234a57506123d3565b6000612354611b90565b905060006314d72edb60e21b815b848110156123cd5787818151811061237c5761237c61575d565b6020026020010151925061238f836126a5565b6123998383613bfd565b6123a38484611268565b8782815181106123b5576123b561575d565b91151560209283029190910190910152600101612362565b50505050505b50919050565b6123e1614962565b87600003612415576000356001600160e01b03191660004660405163092048d160e11b8152600401610b0393929190615b92565b600061242089613851565b90506040518060e001604052808281526020018a815260200189815260200188815260200187815260200186815260200185815250915061246c600254836139f390919063ffffffff16565b600061247783613450565b60008b8152600160209081526040808320868452909152902090915061249e90828b613a94565b80828b600080516020615e0683398151915286886040516124c0929190615bb4565b60405180910390a45050979650505050505050565b4682602001511461250e57602082015160405163092048d160e11b8152610b03916001600160e01b031960003516914690600401615b92565b600061251983613450565b602080850151600090815260018083526040808320885184529093529190200154909150811461257f57602080840151600090815260018083526040808320875184529093529082902001549051632bee7fdb60e21b8152610b039183916004016153c3565b6000612589613d90565b9050600081612596613d9a565b6125a091906155c4565b6125ab9060016155b1565b90506125b5614942565b61155e868685858b866125c78e613da4565b613dbe565b6000825480156121c957828102915080820483146121c957634e487b7160005260116020526024601cfd5b60005b82518110156126a057306001600160a01b031682828151811061261f5761261f61575d565b60200260200101516001600160a01b03160361265c576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6126988382815181106126715761267161575d565b602002602001015183838151811061268b5761268b61575d565b60200260200101516140ea565b6001016125fa565b505050565b806001600160a01b03163b6000036114c05780604051630bfc64a360e21b8152600401610b0391906154af565b806126db612f5d565b600084600f8111156126ef576126ef614d66565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f81111561273057612730614d66565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa390565b7f88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e390565b600080825460ff1660048111156127be576127be614d66565b1480156127cf575042826006015411155b905080156110ba5760018201546040517f58f98006a7f2f253f8ae8f8b7cec9008ca05359633561cd7c22f3005682d4a5590600090a260005b60048301548110156128bb5782600801600084600401838154811061282f5761282f61575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff1916905560048401805460078601929190849081106128785761287861575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19168155600181810183905560029091019190915501612808565b5060005b6005830154811015612972578260080160008460050183815481106128e6576128e661575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff19169055600584018054600786019291908490811061292f5761292f61575d565b60009182526020808320909101546001600160a01b031683528201929092526040018120805460ff191681556001818101839055600290910191909155016128bf565b50815460ff1916825560006001830181905560028301819055600383018190556129a090600484019061499f565b6129ae60058301600061499f565b60006006830155919050565b60606106df6108396129fc565b6001600160a01b0381166114c0576000356001600160e01b03191660405163104c66df60e31b8152600401610b0391906155f9565b7fd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d90565b60006108a0836001600160a01b03841661417d565b6000612a42610839611b90565b80519091506000819003612a565750505050565b6000816001600160401b03811115612a7057612a70614feb565b604051908082528060200260200182016040528015612a99578160200160208202803683370190505b5090506000826001600160401b03811115612ab657612ab6614feb565b604051908082528060200260200182016040528015612ae957816020015b6060815260200190600190039081612ad45790505b50905060008686604051602001612b01929190615bde565b6040516020818303038152906040529050600081604051602401612b259190615c0f565b60408051601f198184030181529190526020810180516001600160e01b03166325da93a560e11b179052905060005b85811015612ce957868181518110612b6e57612b6e61575d565b60200260200101516001600160a01b031683604051612b8d9190615c22565b6000604051808303816000865af19150503d8060008114612bca576040519150601f19603f3d011682016040523d82523d6000602084013e612bcf565b606091505b50868381518110612be257612be261575d565b60200260200101868481518110612bfb57612bfb61575d565b6020026020010182905282151515158152505050848181518110612c2157612c2161575d565b6020026020010151612ce157868181518110612c3f57612c3f61575d565b60200260200101516001600160a01b031682604051612c5e9190615c22565b6000604051808303816000865af19150503d8060008114612c9b576040519150601f19603f3d011682016040523d82523d6000602084013e612ca0565b606091505b50868381518110612cb357612cb361575d565b60200260200101868481518110612ccc57612ccc61575d565b60200260200101829052821515151581525050505b600101612b54565b507fc0b07a27e66788f39cc91405f012f34066b16f31b4bda9438c52f2dae0cc5b6382878686604051612d1f9493929190615c3e565b60405180910390a15050505050505050565b60008082841115612d63576000356001600160e01b0319166040516387f6f09560e01b8152600401610b0391906155f9565b600080516020615e46833981519152549150612d8b600080516020615e268339815191525490565b9050612da4600080516020615e46833981519152859055565b612dbb600080516020615e26833981519152849055565b8284612de67f92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d611281565b7f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f88585604051612e179291906153c3565b60405180910390a49250929050565b60606106df61083961382d565b8051606090806001600160401b03811115612e5057612e50614feb565b604051908082528060200260200182016040528015612e79578160200160208202803683370190505b5091506000612e86612781565b905060005b82811015610f8857816000868381518110612ea857612ea861575d565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060000160149054906101000a90046001600160601b0316848281518110612ef957612ef961575d565b6001600160601b0390921660209283029190910190910152600101612e8b565b60006108f2825490565b6000612f2d612781565b6001600160a01b0390921660009081526020929092525060409020546001600160601b03600160a01b9091041690565b7fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb90565b606081612f8d81611a2f565b8251806001600160401b03811115612fa757612fa7614feb565b604051908082528060200260200182016040528015612fd0578160200160208202803683370190505b50925080600003612fe157506123d3565b6000612feb61275d565b90506000612ff761382d565b905060006130036129fc565b9050600061300f612781565b9050600080600061301e61492b565b60005b898110156131b7578c818151811061303b5761303b61575d565b6020908102919091018101516001600160a01b038082166000908152928c905260409092205490911695509350613071856129c7565b61307a846129c7565b6001600160a01b0385811660009081526020888152604091829020825180840190935254808416808452600160a01b9091046001600160601b031691830191909152909350908516146130ee576000356001600160e01b03191660405163053265f160e01b8152600401610b0391906155f9565b6130f887856113a6565b8015613109575061310988866113a6565b8c828151811061311b5761311b61575d565b6020026020010190151590811515815250508b818151811061313f5761313f61575d565b6020026020010151156131af576131568886612a20565b506131618785612a20565b506001600160a01b03808516600090815260208b8152604080832080546001600160a01b03191690559288168252888152918120558201516131ac906001600160601b0316846155b1565b92505b600101613021565b506131d0600080516020615e8683398151915283614270565b506131ef63c48549de60e01b8d8d604051602001610d169291906157d2565b7fdf3dcd7987202f64648f3acdbf12401e3a2bb23e77e19f99826b5475cbb863698b8d604051613220929190615c8b565b60405180910390a150505050505050505050919050565b61323f614962565b61325161324b89615ac8565b83614280565b905060006132616122bd8a615ac8565b905061327a82898989896122db8a61150a89600061358f565b50979650505050505050565b600061329283836132d0565b6132c8575081546001818101845560008481526020808220909301849055845484825282860190935260409020919091556108f2565b5060006108f2565b60009081526001919091016020526040902054151590565b81548101818110156108f257634e487b7160005260116020526024601cfd5b60608160000180548060200260200160405190810160405280929190818152602001828054801561335757602002820191906000526020600020905b815481526020019060010190808311613343575b50505050509050919050565b602082015160009080820361339e576000356001600160e01b03191660004660405163092048d160e11b8152600401610b0393929190615b92565b6002546133ac9085906139f3565b60006133b785613450565b90506133c282613851565b600083815260016020908152604080832084845290915290819020908701519194506133ef918390613a94565b8451831461341e576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b808383600080516020615e068339815191528888604051613440929190615bb4565b60405180910390a4505092915050565b6080810151606082015160a083015151600092919083906001600160401b0381111561347e5761347e614feb565b6040519080825280602002602001820160405280156134a7578160200160208202803683370190505b5060c086015190915060005b8251811015613506578660a0015181815181106134d2576134d261575d565b6020026020010151805190602001208382815181106134f3576134f361575d565b60209081029190910101526001016134b3565b50604080517fd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a8152875160208083019190915280890151828401529790910151606082015283518702938701939093206080840152835186029386019390932060a0830152805185029085012060c082015281518402919093012060e083015250610100902090565b604080517fd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2815260208101939093528201526060902090565b84158015906135d657508483145b613601576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b600061360b613d90565b9050600081613618613d9a565b61362291906155c4565b61362d9060016155b1565b9050600080366000805b898110156137f1578a8a828181106136515761365161575d565b606002919091019350600090508d8d838181106136705761367061575d565b90506020020160208101906136859190615cb0565b600181111561369657613696614d66565b036136c2576136bb896136ac6020860186615cdc565b8560200135866040013561436d565b9350613739565b60018d8d838181106136d6576136d661575d565b90506020020160208101906136eb9190615cb0565b60018111156136fc576136fc614d66565b03613712576136bb886136ac6020860186615cdc565b6000356001600160e01b031916604051630612418f60e11b8152600401610b0391906155f9565b836001600160a01b0316856001600160a01b031610613779576000356001600160e01b031916604051635d3dcd3160e01b8152600401610b0391906155f9565b839450600061378785613da4565b905080156137e857600192506137d68f8f8f858181106137a9576137a961575d565b90506020020160208101906137be9190615cb0565b8a8a896137d0368b90038b018b615cf7565b87613dbe565b156137e8575050505050505050611b87565b50600101613637565b508061381e576000356001600160e01b03191660405163726b3acb60e01b8152600401610b0391906155f9565b50505050505050505050505050565b7f546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c90565b600081815260208190526040812054908190036138805750600090815260208190526040902060019081905590565b60008281526001602090815260408083208484529091528120906138a3826127a5565b9050806138fa576000825460ff1660048111156138c2576138c2614d66565b036138e05760405163757a436360e01b815260040160405180910390fd5b600084815260208190526040902080546001019081905592505b5050919050565b613909614962565b82518152602080840151604080840191909152600091830191909152830151516001600160401b0381111561394057613940614feb565b604051908082528060200260200182016040528015613969578160200160208202803683370190505b5060608083019190915283015160808083019190915283015160a08083019190915283015160c082015260005b8360400151518110156121c9578281815181106139b5576139b561575d565b6020026020010151826060015182815181106139d3576139d361575d565b6001600160a01b0390921660209283029190910190910152600101613996565b6000826060015151118015613a115750816080015151826060015151145b8015613a2657508160a0015151826060015151145b8015613a3b57508160c0015151826060015151145b613a66576000356001600160e01b0319166040516306b5667560e21b8152600401610b0391906155f9565b613a7081426155b1565b82604001511115610b165760405163ad89be9d60e01b815260040160405180910390fd5b6001830191909155600690910155565b60608101516040820151608083015151600092919083906001600160401b03811115613ad257613ad2614feb565b604051908082528060200260200182016040528015613afb578160200160208202803683370190505b5060a086015190915060005b8251811015613b5a5786608001518181518110613b2657613b2661575d565b602002602001015180519060200120838281518110613b4757613b4761575d565b6020908102919091010152600101613b07565b50604080517f1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee911413508152875160208083019190915297880151918101919091528351870293870193909320606084015283518602938601939093206080830152805185029085012060a082015281518402919093012060c08301525060e0902090565b6001600160a01b03166000908152600891909101602052604090205460ff1690565b600081604051602401613c1091906155f9565b60408051601f198184030181529181526020820180516001600160e01b03166301ffc9a760e01b1790525190915060009081906001600160a01b03861690613c59908590615c22565b600060405180830381855afa9150503d8060008114613c94576040519150601f19603f3d011682016040523d82523d6000602084013e613c99565b606091505b509150915081613d5b57846001600160a01b031683604051602401613cbe9190615c0f565b60408051601f198184030181529181526020820180516001600160e01b03166325da93a560e11b17905251613cf39190615c22565b600060405180830381855afa9150503d8060008114613d2e576040519150601f19603f3d011682016040523d82523d6000602084013e613d33565b606091505b50909250905081613d5b57838560405163069d427960e11b8152600401610b03929190615d57565b80806020019051810190613d6f9190615d7a565b61060d57838560405163069d427960e11b8152600401610b03929190615d57565b60006106df610a59565b60006106df6106c7565b6000613daf82612f23565b6001600160601b031692915050565b60208088015188516000828152600184526040808220838352909452928320613de6816127a5565b15613df757600193505050506106bc565b6020808c015160009081529081905260409020548214613e38576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b6000815460ff166004811115613e5057613e50614d66565b14613e6e576040516322de95ff60e21b815260040160405180910390fd5b613e788188613bdb565b15613e98578660405163025fd59560e41b8152600401610b0391906154af565b6001600160a01b03871660009081526008820160209081526040909120805460ff19166001179055860151151580613ed35750604086015115155b80613ee15750855160ff1615155b15613f28576001600160a01b03871660009081526007820160209081526040918290208851815460ff191660ff909116178155908801516001820155908701516002909101555b866001600160a01b031681600101547f1203f9e81c814a35f5f4cc24087b2a24c6fb7986a9f1406b68a9484882c93a238c88604051613f68929190615d9c565b60405180910390a3600080808c6001811115613f8657613f86614d66565b03613fdb576004830180546001810182556000918252602082200180546001600160a01b0319166001600160a01b038c16179055600384018054899290613fce9084906155b1565b9250508190559150614040565b60018c6001811115613fef57613fef614d66565b03613712576005830180546001810182556000918252602082200180546001600160a01b0319166001600160a01b038c161790556002840180548992906140379084906155b1565b92505081905590505b8a821061409457825460ff19166001908117845580840154604051919750907f5c819725ea53655a3b898f3df59b66489761935454e9212ca1e5ebd759953d0b90600090a261408f838e614395565b6140da565b8981106140da57825460ff19166003178355600180840154604051919750907f55295d4ce992922fa2e5ffbf3a3dcdb367de0a15e125ace083456017fd22060f90600090a25b5050505050979650505050505050565b806003600084600481111561410157614101614d66565b600481111561411257614112614d66565b8152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600481111561415057614150614d66565b6040517f356c8c57e9e84b99b1cb58b13c985b2c979f78cbdf4d0fa70fe2a98bb09a099d90600090a35050565b600081815260018301602052604081205480156142665760006141a16001836155c4565b85549091506000906141b5906001906155c4565b905081811461421a5760008660000182815481106141d5576141d561575d565b90600052602060002001549050808760000184815481106141f8576141f861575d565b6000918252602080832090910192909255918252600188019052604090208390555b855486908061422b5761422b615daa565b6001900381819060005260206000200160009055905585600101600086815260200190815260200160002060009055600193505050506108f2565b60009150506108f2565b60006108f2836113cb8585614402565b614288614962565b6142a161429a84604001516001612076565b8490613901565b90506142b8600254826139f390919063ffffffff16565b60006142c382613450565b905060006142d16000613851565b6000818152600080516020615de68339815191526020908152604090912090870151919250614301918490613a94565b82518114614330576000356001600160e01b03191660405163d4cec26960e01b8152600401610b0391906155f9565b8181600080516020615e668339815191528561434b89613aa4565b898960405161435d9493929190615998565b60405180910390a3505092915050565b600080600061437e8787878761442b565b9150915061438b8161450e565b5095945050505050565b61439e816146bf565b15610b1657815460ff191660021782556000806143ba836146d9565b9150915083600101547fe134987599ae266ec90edeff1b26125b287dbb57b10822649432d1bb26537fba83836040516143f4929190615dc0565b60405180910390a250505050565b600082548281101561442157634e487b7160005260116020526024601cfd5b9190910392915050565b6000806fa2a8918ca85bafe22016d0b997e4df60600160ff1b038311156144585750600090506003614505565b8460ff16601b1415801561447057508460ff16601c14155b156144815750600090506004614505565b6040805160008082526020820180845289905260ff881692820192909252606081018690526080810185905260019060a0016020604051602081039080840390855afa1580156144d5573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b0381166144fe57600060019250925050614505565b9150600090505b94509492505050565b600081600481111561452257614522614d66565b0361452a5750565b600181600481111561453e5761453e614d66565b036145865760405162461bcd60e51b815260206004820152601860248201527745434453413a20696e76616c6964207369676e617475726560401b6044820152606401610b03565b600281600481111561459a5761459a614d66565b036145e75760405162461bcd60e51b815260206004820152601f60248201527f45434453413a20696e76616c6964207369676e6174757265206c656e677468006044820152606401610b03565b60038160048111156145fb576145fb614d66565b036146535760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202773272076616c604482015261756560f01b6064820152608401610b03565b600481600481111561466757614667614d66565b036114c05760405162461bcd60e51b815260206004820152602260248201527f45434453413a20696e76616c6964207369676e6174757265202776272076616c604482015261756560f01b6064820152608401610b03565b60008160200151600014806108f257505060200151461490565b6060806146e5836146bf565b61471757602083015160405163092048d160e11b8152610b03916001600160e01b031960003516914690600401615b92565b8260600151516001600160401b0381111561473457614734614feb565b60405190808252806020026020018201604052801561475d578160200160208202803683370190505b5091508260600151516001600160401b0381111561477d5761477d614feb565b6040519080825280602002602001820160405280156147b057816020015b606081526020019060019003908161479b5790505b50905060005b836060015151811015614925578360c0015181815181106147d9576147d961575d565b60200260200101515a1161480c576147f084613450565b6040516307aec4ab60e21b8152600401610b0391815260200190565b836060015181815181106148225761482261575d565b60200260200101516001600160a01b0316846080015182815181106148495761484961575d565b60200260200101518560c0015183815181106148675761486761575d565b6020026020010151908660a0015184815181106148865761488661575d565b602002602001015160405161489b9190615c22565b600060405180830381858888f193505050503d80600081146148d9576040519150601f19603f3d011682016040523d82523d6000602084013e6148de565b606091505b508483815181106148f1576148f161575d565b6020026020010184848151811061490a5761490a61575d565b602090810291909101019190915290151590526001016147b6565b50915091565b604080518082019091526000808252602082015290565b604080516060810182526000808252602082018190529181019190915290565b6040518060e00160405280600081526020016000815260200160008152602001606081526020016060815260200160608152602001606081525090565b50805460008255906000526020600020908101906114c091905b808211156149cd57600081556001016149b9565b5090565b600060e082840312156123d357600080fd5b60008083601f8401126149f557600080fd5b5081356001600160401b03811115614a0c57600080fd5b6020830191508360208260051b8501011115610e7e57600080fd5b60008083601f840112614a3957600080fd5b5081356001600160401b03811115614a5057600080fd5b602083019150836020606083028501011115610e7e57600080fd5b600080600080600060608688031215614a8357600080fd5b85356001600160401b0380821115614a9a57600080fd5b614aa689838a016149d1565b96506020880135915080821115614abc57600080fd5b614ac889838a016149e3565b90965094506040880135915080821115614ae157600080fd5b50614aee88828901614a27565b969995985093965092949392505050565b60008060008060008060608789031215614b1857600080fd5b86356001600160401b0380821115614b2f57600080fd5b614b3b8a838b016149e3565b90985096506020890135915080821115614b5457600080fd5b614b608a838b016149e3565b90965094506040890135915080821115614b7957600080fd5b50614b8689828a016149e3565b979a9699509497509295939492505050565b600081518084526020808501945080840160005b83811015614bca578151151587529582019590820190600101614bac565b509495945050505050565b6020815260006108a06020830184614b98565b600080600080600080600080600060a08a8c031215614c0657600080fd5b8935985060208a01356001600160401b0380821115614c2457600080fd5b614c308d838e016149e3565b909a50985060408c0135915080821115614c4957600080fd5b614c558d838e016149e3565b909850965060608c0135915080821115614c6e57600080fd5b614c7a8d838e016149e3565b909650945060808c0135915080821115614c9357600080fd5b50614ca08c828d016149e3565b915080935050809150509295985092959850929598565b60008060208385031215614cca57600080fd5b82356001600160401b03811115614ce057600080fd5b614cec858286016149e3565b90969095509350505050565b600081518084526020808501945080840160005b83811015614bca5781516001600160a01b031687529582019590820190600101614d0c565b6020815260006108a06020830184614cf8565b60008060408385031215614d5757600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b60028110614d8c57614d8c614d66565b9052565b60006060808352614da381840187614cf8565b83810360208581019190915286518083528782019282019060005b81811015614de157614dd1838651614d7c565b9383019391830191600101614dbe565b505060409250858103838701528087518083528383019150838901925060005b81811015614e31578351805160ff1684528581015186850152860151868401529284019291860191600101614e01565b50909a9950505050505050505050565b80356001600160a01b03811681146110ba57600080fd5b600080600060608486031215614e6d57600080fd5b8335925060208401359150614e8460408501614e41565b90509250925092565b600080600080600060608688031215614ea557600080fd5b85356001600160401b0380821115614ebc57600080fd5b9087019060c0828a031215614ed057600080fd5b90955060208701359080821115614abc57600080fd5b600060208284031215614ef857600080fd5b5035919050565b8035600281106110ba57600080fd5b60008060008060008060008060008060c08b8d031215614f2d57600080fd5b8a35995060208b01356001600160401b0380821115614f4b57600080fd5b614f578e838f016149e3565b909b50995060408d0135915080821115614f7057600080fd5b614f7c8e838f016149e3565b909950975060608d0135915080821115614f9557600080fd5b614fa18e838f016149e3565b909750955060808d0135915080821115614fba57600080fd5b50614fc78d828e016149e3565b9094509250614fda905060a08c01614eff565b90509295989b9194979a5092959850565b634e487b7160e01b600052604160045260246000fd5b60405160e081016001600160401b038111828210171561502357615023614feb565b60405290565b60405160c081016001600160401b038111828210171561502357615023614feb565b604051601f8201601f191681016001600160401b038111828210171561507357615073614feb565b604052919050565b60006001600160401b0382111561509457615094614feb565b5060051b60200190565b600082601f8301126150af57600080fd5b813560206150c46150bf8361507b565b61504b565b828152600592831b85018201928282019190878511156150e357600080fd5b8387015b8581101561510b5780358281106150fe5760008081fd5b84529284019284016150e7565b5090979650505050505050565b600082601f83011261512957600080fd5b813560206151396150bf8361507b565b82815260059290921b8401810191818101908684111561515857600080fd5b8286015b8481101561517a5761516d81614e41565b835291830191830161515c565b509695505050505050565b6000806040838503121561519857600080fd5b82356001600160401b03808211156151af57600080fd5b6151bb8683870161509e565b935060208501359150808211156151d157600080fd5b506151de85828601615118565b9150509250929050565b600080604083850312156151fb57600080fd5b8235915061520b60208401614e41565b90509250929050565b8035601081106110ba57600080fd5b6000806040838503121561523657600080fd5b61523f83615214565b915061520b60208401614e41565b60006020828403121561525f57600080fd5b6108a082614e41565b60008060008060008060008060008060c08b8d03121561528757600080fd5b8a35995060208b0135985060408b01356001600160401b03808211156152ac57600080fd5b6152b88e838f016149e3565b909a50985060608d01359150808211156152d157600080fd5b6152dd8e838f016149e3565b909850965060808d01359150808211156152f657600080fd5b6153028e838f016149e3565b909650945060a08d013591508082111561531b57600080fd5b506153288d828e016149e3565b915080935050809150509295989b9194979a5092959850565b6000806040838503121561535457600080fd5b82356001600160401b0381111561536a57600080fd5b615376858286016149d1565b92505061520b60208401614eff565b600581106114c0576114c0614d66565b60a081016153a287615385565b95815260208101949094526040840192909252606083015260809091015290565b918252602082015260400190565b6000602082840312156153e357600080fd5b81356001600160401b038111156153f957600080fd5b6107f684828501615118565b600081518084526020808501945080840160005b83811015614bca5781516001600160601b031687529582019590820190600101615419565b6060815260006154516060830186614cf8565b82810360208401526154638186614cf8565b905082810360408401526154778185615405565b9695505050505050565b6020815260006108a06020830184615405565b6000602082840312156154a657600080fd5b6108a082615214565b6001600160a01b0391909116815260200190565b60006154d16150bf8461507b565b8381529050602080820190600585901b8401868111156154f057600080fd5b845b818110156155835780356001600160401b03808211156155125760008081fd5b8188019150601f8a818401126155285760008081fd5b82358281111561553a5761553a614feb565b61554b818301601f1916880161504b565b92508083528b8782860101111561556457600091508182fd5b80878501888501376000908301870152508552509282019282016154f2565b505050509392505050565b60006108a03684846154c3565b634e487b7160e01b600052601160045260246000fd5b808201808211156108f2576108f261559b565b818103818111156108f2576108f261559b565b6000826155f457634e487b7160e01b600052601260045260246000fd5b500490565b6001600160e01b031991909116815260200190565b600082601f83011261561f57600080fd5b8135602061562f6150bf8361507b565b82815260059290921b8401810191818101908684111561564e57600080fd5b8286015b8481101561517a5780358352918301918301615652565b600082601f83011261567a57600080fd5b6108a0838335602085016154c3565b600060e0823603121561569b57600080fd5b6156a3615001565b82358152602080840135908201526040808401359082015260608301356001600160401b03808211156156d557600080fd5b6156e136838701615118565b606084015260808501359150808211156156fa57600080fd5b6157063683870161560e565b608084015260a085013591508082111561571f57600080fd5b61572b36838701615669565b60a084015260c085013591508082111561574457600080fd5b506157513682860161560e565b60c08301525092915050565b634e487b7160e01b600052603260045260246000fd5b80820281158282048414176108f2576108f261559b565b602081016010831061579e5761579e614d66565b91905290565b6001600160e01b03198316815260408101600b83106157c5576157c5614d66565b8260208301529392505050565b6040815260006157e56040830185614cf8565b82810360208401526157f78185614b98565b95945050505050565b6080815260006158136080830187614b98565b82810360208401526158258187615405565b905082810360408401526158398186614cf8565b905082810360608401526106bc8185614cf8565b600081518084526020808501945080840160005b83811015614bca57815187529582019590820190600101615861565b60005b83811015615898578181015183820152602001615880565b50506000910152565b600081518084526158b981602086016020860161587d565b601f01601f19169290920160200192915050565b600082825180855260208086019550808260051b84010181860160005b8481101561510b57601f198684030189526159068383516158a1565b988401989250908301906001016158ea565b8051825260208101516020830152604081015160408301526000606082015160e0606085015261594b60e0850182614cf8565b905060808301518482036080860152615964828261584d565b91505060a083015184820360a086015261597e82826158cd565b91505060c083015184820360c08601526157f7828261584d565b6080815260006159ab6080830187615918565b60208681850152838203604085015260c08201865183528187015182840152604087015160c0604085015281815180845260e0860191508483019350600092505b80831015615a155783516159ff81615385565b82529284019260019290920191908401906159ec565b50606089015193508481036060860152615a2f818561584d565b935050505060808601518282036080840152615a4b82826158cd565b91505060a086015182820360a0840152615a65828261584d565b93505050506157f760608301846001600160a01b03169052565b6000808335601e19843603018112615a9657600080fd5b8301803591506001600160401b03821115615ab057600080fd5b6020019150600581901b3603821315610e7e57600080fd5b600060c08236031215615ada57600080fd5b615ae2615029565b823581526020808401359082015260408301356001600160401b0380821115615b0a57600080fd5b615b163683870161509e565b60408401526060850135915080821115615b2f57600080fd5b615b3b3683870161560e565b60608401526080850135915080821115615b5457600080fd5b615b6036838701615669565b608084015260a0850135915080821115615b7957600080fd5b50615b863682860161560e565b60a08301525092915050565b6001600160e01b03199390931683526020830191909152604082015260600190565b604081526000615bc76040830185615918565b905060018060a01b03831660208301529392505050565b6001600160e01b0319831681528151600090615c0181600485016020870161587d565b919091016004019392505050565b6020815260006108a060208301846158a1565b60008251615c3481846020870161587d565b9190910192915050565b608081526000615c5160808301876158a1565b8281036020840152615c638187614cf8565b90508281036040840152615c778186614b98565b905082810360608401526106bc81856158cd565b604081526000615c9e6040830185614b98565b82810360208401526157f78185614cf8565b600060208284031215615cc257600080fd5b6108a082614eff565b803560ff811681146110ba57600080fd5b600060208284031215615cee57600080fd5b6108a082615ccb565b600060608284031215615d0957600080fd5b604051606081016001600160401b0381118282101715615d2b57615d2b614feb565b604052615d3783615ccb565b815260208301356020820152604083013560408201528091505092915050565b6001600160e01b03199290921682526001600160a01b0316602082015260400190565b600060208284031215615d8c57600080fd5b815180151581146108a057600080fd5b604081016157c58285614d7c565b634e487b7160e01b600052603160045260246000fd5b604081526000615dd36040830185614b98565b82810360208401526157f781856158cd56fea6eef7e35abe7026729641147f7915573c7e97b47efa546f5f6e3230263bcb49a57d40f1496988cf60ab7c9d5ba4ff83647f67d3898d441a3aaf21b651678fd9ac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ffc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f771d78ae9e5fca95a532fb0971d575d0ce9b59d14823c063e08740137e0e0eca6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644ca2646970667358221220df018f67471d8972a68d3658e92c2357f3934b05a2c1b9ba9c4504aa64187f1964736f6c63430008110033" +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/RoninGatewayV3Logic.json b/deployments/ronin-mainnet/RoninGatewayV3Logic.json new file mode 100644 index 000000000..c0df86a4d --- /dev/null +++ b/deployments/ronin-mainnet/RoninGatewayV3Logic.json @@ -0,0 +1,3113 @@ +{ + "address": "0x1477DB6bF449B0eb1191a1F4023867ddCEadc504", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "voter", + "type": "address" + } + ], + "name": "ErrAlreadyVoted", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrERC20MintingFailed", + "type": "error" + }, + { + "inputs": [], + "name": "ErrERC721MintingFailed", + "type": "error" + }, + { + "inputs": [], + "name": "ErrEmptyArray", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "actual", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "expected", + "type": "uint256" + } + ], + "name": "ErrInvalidChainId", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidInfo", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidReceipt", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidReceiptKind", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidRequest", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidTokenStandard", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidTrustedThreshold", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrLengthMismatch", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForTooSmallQuantity", + "type": "error" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "tokenInfo", + "type": "tuple" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "address", + "name": "token", + "type": "address" + } + ], + "name": "ErrTokenCouldNotTransfer", + "type": "error" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "tokenInfo", + "type": "tuple" + }, + { + "internalType": "address", + "name": "from", + "type": "address" + }, + { + "internalType": "address", + "name": "to", + "type": "address" + }, + { + "internalType": "address", + "name": "token", + "type": "address" + } + ], + "name": "ErrTokenCouldNotTransferFrom", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [], + "name": "ErrUnsupportedStandard", + "type": "error" + }, + { + "inputs": [], + "name": "ErrUnsupportedToken", + "type": "error" + }, + { + "inputs": [], + "name": "ErrWithdrawalsMigrated", + "type": "error" + }, + { + "inputs": [], + "name": "ErrWithdrawnOnMainchainAlready", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrZeroCodeContract", + "type": "error" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "bridgeOperator", + "type": "address" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + } + ], + "name": "DepositVoted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "Deposited", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "receipt", + "type": "tuple" + } + ], + "name": "MainchainWithdrew", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "tokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "threshold", + "type": "uint256[]" + } + ], + "name": "MinimumThresholdsUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "Paused", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "previousAdminRole", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "bytes32", + "name": "newAdminRole", + "type": "bytes32" + } + ], + "name": "RoleAdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "account", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + } + ], + "name": "RoleGranted", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "indexed": true, + "internalType": "address", + "name": "account", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "sender", + "type": "address" + } + ], + "name": "RoleRevoked", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "ThresholdUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address[]", + "name": "roninTokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "address[]", + "name": "mainchainTokens", + "type": "address[]" + }, + { + "indexed": false, + "internalType": "uint256[]", + "name": "chainIds", + "type": "uint256[]" + }, + { + "indexed": false, + "internalType": "enum Token.Standard[]", + "name": "standards", + "type": "uint8[]" + } + ], + "name": "TokenMapped", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "uint256", + "name": "nonce", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "numerator", + "type": "uint256" + }, + { + "indexed": true, + "internalType": "uint256", + "name": "denominator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousNumerator", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "previousDenominator", + "type": "uint256" + } + ], + "name": "TrustedThresholdUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "Unpaused", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "", + "type": "tuple" + } + ], + "name": "WithdrawalRequested", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "bytes32", + "name": "receiptHash", + "type": "bytes32" + }, + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "indexed": false, + "internalType": "struct Transfer.Receipt", + "name": "", + "type": "tuple" + } + ], + "name": "WithdrawalSignaturesRequested", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "DEFAULT_ADMIN_ROLE", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "address", + "name": "recipientAddr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Request[]", + "name": "_requests", + "type": "tuple[]" + }, + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + } + ], + "name": "bulkRequestWithdrawalFor", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256[]", + "name": "withdrawals", + "type": "uint256[]" + }, + { + "internalType": "bytes[]", + "name": "signatures", + "type": "bytes[]" + } + ], + "name": "bulkSubmitWithdrawalSignatures", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_voteWeight", + "type": "uint256" + } + ], + "name": "checkThreshold", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Receipt", + "name": "_receipt", + "type": "tuple" + } + ], + "name": "depositFor", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "depositVote", + "outputs": [ + { + "internalType": "enum VoteStatusConsumer.VoteStatus", + "name": "status", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "finalHash", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "expiredAt", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "createdAt", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_depositId", + "type": "uint256" + }, + { + "internalType": "address", + "name": "_voter", + "type": "address" + } + ], + "name": "depositVoted", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "emergencyPauser", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_roninToken", + "type": "address" + }, + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + } + ], + "name": "getMainchainToken", + "outputs": [ + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + } + ], + "internalType": "struct MappedTokenConsumer.MappedToken", + "name": "_token", + "type": "tuple" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + } + ], + "name": "getRoleAdmin", + "outputs": [ + { + "internalType": "bytes32", + "name": "", + "type": "bytes32" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "index", + "type": "uint256" + } + ], + "name": "getRoleMember", + "outputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + } + ], + "name": "getRoleMemberCount", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "num_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "denom_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "getTrustedThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "trustedNum_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "trustedDenom_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "withdrawalId", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "operators", + "type": "address[]" + } + ], + "name": "getWithdrawalSignatures", + "outputs": [ + { + "internalType": "bytes[]", + "name": "_signatures", + "type": "bytes[]" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "grantRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "hasRole", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_roleSetter", + "type": "address" + }, + { + "internalType": "uint256", + "name": "_numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_denominator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_trustedNumerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_trustedDenominator", + "type": "uint256" + }, + { + "internalType": "address[]", + "name": "", + "type": "address[]" + }, + { + "internalType": "address[][2]", + "name": "_packedAddresses", + "type": "address[][2]" + }, + { + "internalType": "uint256[][2]", + "name": "_packedNumbers", + "type": "uint256[][2]" + }, + { + "internalType": "enum Token.Standard[]", + "name": "_standards", + "type": "uint8[]" + } + ], + "name": "initialize", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "bridgeAdmin", + "type": "address" + } + ], + "name": "initializeV3", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_withdrawalId", + "type": "uint256" + } + ], + "name": "mainchainWithdrew", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "mainchainWithdrewVote", + "outputs": [ + { + "internalType": "enum VoteStatusConsumer.VoteStatus", + "name": "status", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "finalHash", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "expiredAt", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "createdAt", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_withdrawalId", + "type": "uint256" + }, + { + "internalType": "address", + "name": "_voter", + "type": "address" + } + ], + "name": "mainchainWithdrewVoted", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_roninTokens", + "type": "address[]" + }, + { + "internalType": "address[]", + "name": "_mainchainTokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_chainIds", + "type": "uint256[]" + }, + { + "internalType": "enum Token.Standard[]", + "name": "_standards", + "type": "uint8[]" + } + ], + "name": "mapTokens", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "", + "type": "address" + } + ], + "name": "minimumThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "minimumVoteWeight", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "nonce", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "pause", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "paused", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "renounceRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "address", + "name": "recipientAddr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Request", + "name": "_request", + "type": "tuple" + }, + { + "internalType": "uint256", + "name": "_chainId", + "type": "uint256" + } + ], + "name": "requestWithdrawalFor", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_withdrawalId", + "type": "uint256" + } + ], + "name": "requestWithdrawalSignatures", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes32", + "name": "role", + "type": "bytes32" + }, + { + "internalType": "address", + "name": "account", + "type": "address" + } + ], + "name": "revokeRole", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "_addr", + "type": "address" + } + ], + "name": "setEmergencyPauser", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address[]", + "name": "_tokens", + "type": "address[]" + }, + { + "internalType": "uint256[]", + "name": "_thresholds", + "type": "uint256[]" + } + ], + "name": "setMinimumThresholds", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_numerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_denominator", + "type": "uint256" + } + ], + "name": "setThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "_trustedNumerator", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "_trustedDenominator", + "type": "uint256" + } + ], + "name": "setTrustedThreshold", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "interfaceId", + "type": "bytes4" + } + ], + "name": "supportsInterface", + "outputs": [ + { + "internalType": "bool", + "name": "", + "type": "bool" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256[]", + "name": "_withdrawalIds", + "type": "uint256[]" + } + ], + "name": "tryBulkAcknowledgeMainchainWithdrew", + "outputs": [ + { + "internalType": "bool[]", + "name": "_executedReceipts", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "components": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "internalType": "struct Transfer.Receipt[]", + "name": "_receipts", + "type": "tuple[]" + } + ], + "name": "tryBulkDepositFor", + "outputs": [ + { + "internalType": "bool[]", + "name": "_executedReceipts", + "type": "bool[]" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [], + "name": "unpause", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "withdrawal", + "outputs": [ + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "enum Transfer.Kind", + "name": "kind", + "type": "uint8" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "mainchain", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + }, + { + "internalType": "address", + "name": "tokenAddr", + "type": "address" + }, + { + "internalType": "uint256", + "name": "chainId", + "type": "uint256" + } + ], + "internalType": "struct Token.Owner", + "name": "ronin", + "type": "tuple" + }, + { + "components": [ + { + "internalType": "enum Token.Standard", + "name": "erc", + "type": "uint8" + }, + { + "internalType": "uint256", + "name": "id", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "quantity", + "type": "uint256" + } + ], + "internalType": "struct Token.Info", + "name": "info", + "type": "tuple" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [], + "name": "withdrawalCount", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "name": "withdrawalStatVote", + "outputs": [ + { + "internalType": "enum VoteStatusConsumer.VoteStatus", + "name": "status", + "type": "uint8" + }, + { + "internalType": "bytes32", + "name": "finalHash", + "type": "bytes32" + }, + { + "internalType": "uint256", + "name": "expiredAt", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "createdAt", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0xbd0e0924e2b2d2a95610852713adb452357c372d48f11b865ff133a59b4d1384", + "receipt": { + "to": null, + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x1477DB6bF449B0eb1191a1F4023867ddCEadc504", + "transactionIndex": 0, + "gasUsed": "4320982", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x3cb3f6c5e6502d1f547f4c04a7f403f31b02996a38a82d34c7813339761d999d", + "transactionHash": "0xbd0e0924e2b2d2a95610852713adb452357c372d48f11b865ff133a59b4d1384", + "logs": [], + "blockNumber": 28540007, + "cumulativeGasUsed": "4320982", + "status": 1, + "byzantium": true + }, + "args": [], + "numDeployments": 1, + "solcInputHash": "8a10de68ec323e5be85b46f42143fc19", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"}],\"name\":\"ErrAlreadyVoted\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrERC20MintingFailed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrERC721MintingFailed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrEmptyArray\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"actual\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"expected\",\"type\":\"uint256\"}],\"name\":\"ErrInvalidChainId\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidInfo\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidReceipt\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidReceiptKind\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidRequest\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidTokenStandard\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidTrustedThreshold\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrLengthMismatch\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForTooSmallQuantity\",\"type\":\"error\"},{\"inputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"tokenInfo\",\"type\":\"tuple\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"token\",\"type\":\"address\"}],\"name\":\"ErrTokenCouldNotTransfer\",\"type\":\"error\"},{\"inputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"tokenInfo\",\"type\":\"tuple\"},{\"internalType\":\"address\",\"name\":\"from\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"to\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"token\",\"type\":\"address\"}],\"name\":\"ErrTokenCouldNotTransferFrom\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnsupportedStandard\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnsupportedToken\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrWithdrawalsMigrated\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrWithdrawnOnMainchainAlready\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"}],\"name\":\"DepositVoted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"Deposited\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"receipt\",\"type\":\"tuple\"}],\"name\":\"MainchainWithdrew\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"tokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"threshold\",\"type\":\"uint256[]\"}],\"name\":\"MinimumThresholdsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"Paused\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"previousAdminRole\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"newAdminRole\",\"type\":\"bytes32\"}],\"name\":\"RoleAdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"}],\"name\":\"RoleGranted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"sender\",\"type\":\"address\"}],\"name\":\"RoleRevoked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"roninTokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"mainchainTokens\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"chainIds\",\"type\":\"uint256[]\"},{\"indexed\":false,\"internalType\":\"enum Token.Standard[]\",\"name\":\"standards\",\"type\":\"uint8[]\"}],\"name\":\"TokenMapped\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"TrustedThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"Unpaused\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"\",\"type\":\"tuple\"}],\"name\":\"WithdrawalRequested\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"bytes32\",\"name\":\"receiptHash\",\"type\":\"bytes32\"},{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"indexed\":false,\"internalType\":\"struct Transfer.Receipt\",\"name\":\"\",\"type\":\"tuple\"}],\"name\":\"WithdrawalSignaturesRequested\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADMIN_ROLE\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Request[]\",\"name\":\"_requests\",\"type\":\"tuple[]\"},{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"}],\"name\":\"bulkRequestWithdrawalFor\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256[]\",\"name\":\"withdrawals\",\"type\":\"uint256[]\"},{\"internalType\":\"bytes[]\",\"name\":\"signatures\",\"type\":\"bytes[]\"}],\"name\":\"bulkSubmitWithdrawalSignatures\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Receipt\",\"name\":\"_receipt\",\"type\":\"tuple\"}],\"name\":\"depositFor\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"depositVote\",\"outputs\":[{\"internalType\":\"enum VoteStatusConsumer.VoteStatus\",\"name\":\"status\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"finalHash\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"expiredAt\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"createdAt\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_depositId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_voter\",\"type\":\"address\"}],\"name\":\"depositVoted\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyPauser\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_roninToken\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"}],\"name\":\"getMainchainToken\",\"outputs\":[{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"}],\"internalType\":\"struct MappedTokenConsumer.MappedToken\",\"name\":\"_token\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"}],\"name\":\"getRoleAdmin\",\"outputs\":[{\"internalType\":\"bytes32\",\"name\":\"\",\"type\":\"bytes32\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"index\",\"type\":\"uint256\"}],\"name\":\"getRoleMember\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"}],\"name\":\"getRoleMemberCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getTrustedThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"trustedNum_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"trustedDenom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"withdrawalId\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"operators\",\"type\":\"address[]\"}],\"name\":\"getWithdrawalSignatures\",\"outputs\":[{\"internalType\":\"bytes[]\",\"name\":\"_signatures\",\"type\":\"bytes[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"grantRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"hasRole\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_roleSetter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_trustedNumerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_trustedDenominator\",\"type\":\"uint256\"},{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"},{\"internalType\":\"address[][2]\",\"name\":\"_packedAddresses\",\"type\":\"address[][2]\"},{\"internalType\":\"uint256[][2]\",\"name\":\"_packedNumbers\",\"type\":\"uint256[][2]\"},{\"internalType\":\"enum Token.Standard[]\",\"name\":\"_standards\",\"type\":\"uint8[]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"bridgeAdmin\",\"type\":\"address\"}],\"name\":\"initializeV3\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_withdrawalId\",\"type\":\"uint256\"}],\"name\":\"mainchainWithdrew\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"mainchainWithdrewVote\",\"outputs\":[{\"internalType\":\"enum VoteStatusConsumer.VoteStatus\",\"name\":\"status\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"finalHash\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"expiredAt\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"createdAt\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_withdrawalId\",\"type\":\"uint256\"},{\"internalType\":\"address\",\"name\":\"_voter\",\"type\":\"address\"}],\"name\":\"mainchainWithdrewVoted\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_roninTokens\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_mainchainTokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_chainIds\",\"type\":\"uint256[]\"},{\"internalType\":\"enum Token.Standard[]\",\"name\":\"_standards\",\"type\":\"uint8[]\"}],\"name\":\"mapTokens\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"minimumThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"nonce\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"pause\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"paused\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"renounceRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Request\",\"name\":\"_request\",\"type\":\"tuple\"},{\"internalType\":\"uint256\",\"name\":\"_chainId\",\"type\":\"uint256\"}],\"name\":\"requestWithdrawalFor\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_withdrawalId\",\"type\":\"uint256\"}],\"name\":\"requestWithdrawalSignatures\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes32\",\"name\":\"role\",\"type\":\"bytes32\"},{\"internalType\":\"address\",\"name\":\"account\",\"type\":\"address\"}],\"name\":\"revokeRole\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setEmergencyPauser\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_tokens\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_thresholds\",\"type\":\"uint256[]\"}],\"name\":\"setMinimumThresholds\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_trustedNumerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_trustedDenominator\",\"type\":\"uint256\"}],\"name\":\"setTrustedThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"interfaceId\",\"type\":\"bytes4\"}],\"name\":\"supportsInterface\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_withdrawalIds\",\"type\":\"uint256[]\"}],\"name\":\"tryBulkAcknowledgeMainchainWithdrew\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_executedReceipts\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"internalType\":\"struct Transfer.Receipt[]\",\"name\":\"_receipts\",\"type\":\"tuple[]\"}],\"name\":\"tryBulkDepositFor\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_executedReceipts\",\"type\":\"bool[]\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"unpause\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"withdrawal\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"enum Transfer.Kind\",\"name\":\"kind\",\"type\":\"uint8\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"mainchain\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"tokenAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"chainId\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Owner\",\"name\":\"ronin\",\"type\":\"tuple\"},{\"components\":[{\"internalType\":\"enum Token.Standard\",\"name\":\"erc\",\"type\":\"uint8\"},{\"internalType\":\"uint256\",\"name\":\"id\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"quantity\",\"type\":\"uint256\"}],\"internalType\":\"struct Token.Info\",\"name\":\"info\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"withdrawalCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"withdrawalStatVote\",\"outputs\":[{\"internalType\":\"enum VoteStatusConsumer.VoteStatus\",\"name\":\"status\",\"type\":\"uint8\"},{\"internalType\":\"bytes32\",\"name\":\"finalHash\",\"type\":\"bytes32\"},{\"internalType\":\"uint256\",\"name\":\"expiredAt\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"createdAt\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrAlreadyVoted(address)\":[{\"details\":\"Error indicating that a voter has already voted.\",\"params\":{\"voter\":\"The address of the voter who has already voted.\"}}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrERC20MintingFailed()\":[{\"details\":\"Error indicating that the minting of ERC20 tokens has failed.\"}],\"ErrERC721MintingFailed()\":[{\"details\":\"Error indicating that the minting of ERC721 tokens has failed.\"}],\"ErrEmptyArray()\":[{\"details\":\"Error indicating that an array is empty when it should contain elements.\"}],\"ErrInvalidChainId(bytes4,uint256,uint256)\":[{\"details\":\"Error indicating that the chain ID is invalid.\",\"params\":{\"actual\":\"Current chain ID that executing function.\",\"expected\":\"Expected chain ID required for the tx to success.\",\"msgSig\":\"The function signature (bytes4) of the operation that encountered an invalid chain ID.\"}}],\"ErrInvalidInfo()\":[{\"details\":\"Error indicating that the provided information is invalid.\"}],\"ErrInvalidReceipt()\":[{\"details\":\"Error indicating that a receipt is invalid.\"}],\"ErrInvalidReceiptKind()\":[{\"details\":\"Error indicating that a receipt kind is invalid.\"}],\"ErrInvalidRequest()\":[{\"details\":\"Error indicating that a request is invalid.\"}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrInvalidTokenStandard()\":[{\"details\":\"Error indicating that a token standard is invalid.\"}],\"ErrInvalidTrustedThreshold()\":[{\"details\":\"Error thrown when an invalid trusted threshold is specified.\"}],\"ErrLengthMismatch(bytes4)\":[{\"details\":\"Error indicating a mismatch in the length of input parameters or arrays for a specific function.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that has a length mismatch.\"}}],\"ErrQueryForTooSmallQuantity()\":[{\"details\":\"Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\"}],\"ErrTokenCouldNotTransfer((uint8,uint256,uint256),address,address)\":[{\"details\":\"Error indicating that the `transfer` has failed.\",\"params\":{\"to\":\"Receiver of the token value.\",\"token\":\"Address of the token.\",\"tokenInfo\":\"Info of the token including ERC standard, id or quantity.\"}}],\"ErrTokenCouldNotTransferFrom((uint8,uint256,uint256),address,address,address)\":[{\"details\":\"Error indicating that the `transferFrom` has failed.\",\"params\":{\"from\":\"Owner of the token value.\",\"to\":\"Receiver of the token value.\",\"token\":\"Address of the token.\",\"tokenInfo\":\"Info of the token including ERC standard, id or quantity.\"}}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnsupportedStandard()\":[{\"details\":\"Error indicating that an unsupported standard is encountered.\"}],\"ErrUnsupportedToken()\":[{\"details\":\"Error indicating that a token is not supported.\"}],\"ErrWithdrawalsMigrated()\":[{\"details\":\"Error thrown when attempting to withdraw funds that have already been migrated.\"}],\"ErrWithdrawnOnMainchainAlready()\":[{\"details\":\"Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"bulkRequestWithdrawalFor((address,address,(uint8,uint256,uint256))[],uint256)\":{\"details\":\"Bulk requests withdrawals. Emits the `WithdrawalRequested` events.\"},\"bulkSubmitWithdrawalSignatures(uint256[],bytes[])\":{\"details\":\"Submits withdrawal signatures. Requirements: - The method caller is a validator.\"},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"depositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))\":{\"details\":\"Deposits based on the receipt. Requirements: - The method caller is a validator. Emits the `Deposited` once the assets are released.\"},\"depositVoted(uint256,uint256,address)\":{\"details\":\"Returns whether the deposit is casted by the voter.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getMainchainToken(address,uint256)\":{\"details\":\"Returns mainchain token address. Reverts for unsupported token.\"},\"getRoleAdmin(bytes32)\":{\"details\":\"Returns the admin role that controls `role`. See {grantRole} and {revokeRole}. To change a role's admin, use {_setRoleAdmin}.\"},\"getRoleMember(bytes32,uint256)\":{\"details\":\"Returns one of the accounts that have `role`. `index` must be a value between 0 and {getRoleMemberCount}, non-inclusive. Role bearers are not sorted in any particular way, and their ordering may change at any point. WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure you perform all queries on the same block. See the following https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post] for more information.\"},\"getRoleMemberCount(bytes32)\":{\"details\":\"Returns the number of accounts that have `role`. Can be used together with {getRoleMember} to enumerate all bearers of a role.\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"getTrustedThreshold()\":{\"details\":\"Returns the threshold about trusted org.\"},\"getWithdrawalSignatures(uint256,address[])\":{\"details\":\"Returns withdrawal signatures.\"},\"grantRole(bytes32,address)\":{\"details\":\"Grants `role` to `account`. If `account` had not been already granted `role`, emits a {RoleGranted} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleGranted} event.\"},\"hasRole(bytes32,address)\":{\"details\":\"Returns `true` if `account` has been granted `role`.\"},\"initialize(address,uint256,uint256,uint256,uint256,address[],address[][2],uint256[][2],uint8[])\":{\"details\":\"Initializes contract storage.\"},\"mainchainWithdrew(uint256)\":{\"details\":\"Returns whether the withdrawal is done on mainchain.\"},\"mainchainWithdrewVoted(uint256,address)\":{\"details\":\"Returns whether the mainchain withdrew is casted by the voter.\"},\"mapTokens(address[],address[],uint256[],uint8[])\":{\"details\":\"Maps Ronin tokens to mainchain networks. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event.\"},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"pause()\":{\"details\":\"Triggers paused state.\"},\"paused()\":{\"details\":\"Returns true if the contract is paused, and false otherwise.\"},\"renounceRole(bytes32,address)\":{\"details\":\"Revokes `role` from the calling account. Roles are often managed via {grantRole} and {revokeRole}: this function's purpose is to provide a mechanism for accounts to lose their privileges if they are compromised (such as when a trusted device is misplaced). If the calling account had been revoked `role`, emits a {RoleRevoked} event. Requirements: - the caller must be `account`. May emit a {RoleRevoked} event.\"},\"requestWithdrawalFor((address,address,(uint8,uint256,uint256)),uint256)\":{\"details\":\"Locks the assets and request withdrawal. Emits the `WithdrawalRequested` event.\"},\"requestWithdrawalSignatures(uint256)\":{\"details\":\"Requests withdrawal signatures for a specific withdrawal. Emits the `WithdrawalSignaturesRequested` event.\"},\"revokeRole(bytes32,address)\":{\"details\":\"Revokes `role` from `account`. If `account` had been granted `role`, emits a {RoleRevoked} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleRevoked} event.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setEmergencyPauser(address)\":{\"details\":\"Grant emergency pauser role for `_addr`.\"},\"setMinimumThresholds(address[],uint256[])\":{\"details\":\"Sets the minimum thresholds to withdraw. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `MinimumThresholdsUpdated` event.\"},\"setThreshold(uint256,uint256)\":{\"details\":\"Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event.\"},\"supportsInterface(bytes4)\":{\"details\":\"See {IERC165-supportsInterface}.\"},\"tryBulkAcknowledgeMainchainWithdrew(uint256[])\":{\"details\":\"Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal vote is already done before. Requirements: - The method caller is a validator. Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\"},\"tryBulkDepositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256))[])\":{\"details\":\"Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote is already done before. Reverts if the deposit is invalid or is voted by the validator again. Requirements: - The method caller is a validator. Emits the `Deposited` once the assets are released.\"},\"unpause()\":{\"details\":\"Triggers unpaused state.\"}},\"stateVariables\":{\"____deprecated0\":{\"custom:deprecated\":\"Previously `_validatorContract` (non-zero value)\"},\"____deprecated1\":{\"custom:deprecated\":\"Previously `_bridgeTrackingContract` (non-zero value)\"},\"____deprecated2\":{\"custom:deprecated\":\"Previously `_trustedOrgContract` (non-zero value)\"},\"___deprecated4\":{\"custom:deprecated\":\"Previously `withdrawalMigrated` (non-zero value)\"},\"_mainchainToken\":{\"details\":\"Mapping from token address => chain id => mainchain token address\"},\"_withdrawalSig\":{\"details\":\"Mapping from withdrawal id => validator address => signatures\"},\"depositVote\":{\"details\":\"Mapping from chain id => deposit id => deposit vote\"},\"mainchainWithdrewVote\":{\"details\":\"Mapping from withdrawal id => mainchain withdrew vote\"},\"withdrawal\":{\"details\":\"Mapping from withdrawal id => withdrawal receipt\"},\"withdrawalCount\":{\"details\":\"Total withdrawal\"},\"withdrawalStatVote\":{\"details\":\"Mapping from withdrawal id => vote for recording withdrawal stats\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"depositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))\":{\"notice\":\"The assets will be transferred whenever the valid call passes the quorum threshold.\"},\"tryBulkAcknowledgeMainchainWithdrew(uint256[])\":{\"notice\":\"Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\"},\"tryBulkDepositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256))[])\":{\"notice\":\"The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/gateway/RoninGatewayV3.sol\":\"RoninGatewayV3\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/access/AccessControl.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControl.sol\\\";\\nimport \\\"../utils/Context.sol\\\";\\nimport \\\"../utils/Strings.sol\\\";\\nimport \\\"../utils/introspection/ERC165.sol\\\";\\n\\n/**\\n * @dev Contract module that allows children to implement role-based access\\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\\n * members except through off-chain means by accessing the contract event logs. Some\\n * applications may benefit from on-chain enumerability, for those cases see\\n * {AccessControlEnumerable}.\\n *\\n * Roles are referred to by their `bytes32` identifier. These should be exposed\\n * in the external API and be unique. The best way to achieve this is by\\n * using `public constant` hash digests:\\n *\\n * ```\\n * bytes32 public constant MY_ROLE = keccak256(\\\"MY_ROLE\\\");\\n * ```\\n *\\n * Roles can be used to represent a set of permissions. To restrict access to a\\n * function call, use {hasRole}:\\n *\\n * ```\\n * function foo() public {\\n * require(hasRole(MY_ROLE, msg.sender));\\n * ...\\n * }\\n * ```\\n *\\n * Roles can be granted and revoked dynamically via the {grantRole} and\\n * {revokeRole} functions. Each role has an associated admin role, and only\\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\\n *\\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\\n * that only accounts with this role will be able to grant or revoke other\\n * roles. More complex role relationships can be created by using\\n * {_setRoleAdmin}.\\n *\\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\\n * grant and revoke this role. Extra precautions should be taken to secure\\n * accounts that have been granted it.\\n */\\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\\n struct RoleData {\\n mapping(address => bool) members;\\n bytes32 adminRole;\\n }\\n\\n mapping(bytes32 => RoleData) private _roles;\\n\\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\\n\\n /**\\n * @dev Modifier that checks that an account has a specific role. Reverts\\n * with a standardized message including the required role.\\n *\\n * The format of the revert reason is given by the following regular expression:\\n *\\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\\n *\\n * _Available since v4.1._\\n */\\n modifier onlyRole(bytes32 role) {\\n _checkRole(role);\\n _;\\n }\\n\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\\n }\\n\\n /**\\n * @dev Returns `true` if `account` has been granted `role`.\\n */\\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\\n return _roles[role].members[account];\\n }\\n\\n /**\\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\\n * Overriding this function changes the behavior of the {onlyRole} modifier.\\n *\\n * Format of the revert message is described in {_checkRole}.\\n *\\n * _Available since v4.6._\\n */\\n function _checkRole(bytes32 role) internal view virtual {\\n _checkRole(role, _msgSender());\\n }\\n\\n /**\\n * @dev Revert with a standard message if `account` is missing `role`.\\n *\\n * The format of the revert reason is given by the following regular expression:\\n *\\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\\n */\\n function _checkRole(bytes32 role, address account) internal view virtual {\\n if (!hasRole(role, account)) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"AccessControl: account \\\",\\n Strings.toHexString(uint160(account), 20),\\n \\\" is missing role \\\",\\n Strings.toHexString(uint256(role), 32)\\n )\\n )\\n );\\n }\\n }\\n\\n /**\\n * @dev Returns the admin role that controls `role`. See {grantRole} and\\n * {revokeRole}.\\n *\\n * To change a role's admin, use {_setRoleAdmin}.\\n */\\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\\n return _roles[role].adminRole;\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n *\\n * May emit a {RoleGranted} event.\\n */\\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\\n _grantRole(role, account);\\n }\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\\n _revokeRole(role, account);\\n }\\n\\n /**\\n * @dev Revokes `role` from the calling account.\\n *\\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\\n * purpose is to provide a mechanism for accounts to lose their privileges\\n * if they are compromised (such as when a trusted device is misplaced).\\n *\\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must be `account`.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function renounceRole(bytes32 role, address account) public virtual override {\\n require(account == _msgSender(), \\\"AccessControl: can only renounce roles for self\\\");\\n\\n _revokeRole(role, account);\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event. Note that unlike {grantRole}, this function doesn't perform any\\n * checks on the calling account.\\n *\\n * May emit a {RoleGranted} event.\\n *\\n * [WARNING]\\n * ====\\n * This function should only be called from the constructor when setting\\n * up the initial roles for the system.\\n *\\n * Using this function in any other way is effectively circumventing the admin\\n * system imposed by {AccessControl}.\\n * ====\\n *\\n * NOTE: This function is deprecated in favor of {_grantRole}.\\n */\\n function _setupRole(bytes32 role, address account) internal virtual {\\n _grantRole(role, account);\\n }\\n\\n /**\\n * @dev Sets `adminRole` as ``role``'s admin role.\\n *\\n * Emits a {RoleAdminChanged} event.\\n */\\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\\n bytes32 previousAdminRole = getRoleAdmin(role);\\n _roles[role].adminRole = adminRole;\\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\\n }\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * Internal function without access restriction.\\n *\\n * May emit a {RoleGranted} event.\\n */\\n function _grantRole(bytes32 role, address account) internal virtual {\\n if (!hasRole(role, account)) {\\n _roles[role].members[account] = true;\\n emit RoleGranted(role, account, _msgSender());\\n }\\n }\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * Internal function without access restriction.\\n *\\n * May emit a {RoleRevoked} event.\\n */\\n function _revokeRole(bytes32 role, address account) internal virtual {\\n if (hasRole(role, account)) {\\n _roles[role].members[account] = false;\\n emit RoleRevoked(role, account, _msgSender());\\n }\\n }\\n}\\n\",\"keccak256\":\"0x5b35d8e68aeaccc685239bd9dd79b9ba01a0357930f8a3307ab85511733d9724\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/AccessControlEnumerable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControlEnumerable.sol\\\";\\nimport \\\"./AccessControl.sol\\\";\\nimport \\\"../utils/structs/EnumerableSet.sol\\\";\\n\\n/**\\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\\n */\\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\\n using EnumerableSet for EnumerableSet.AddressSet;\\n\\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\\n\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\\n }\\n\\n /**\\n * @dev Returns one of the accounts that have `role`. `index` must be a\\n * value between 0 and {getRoleMemberCount}, non-inclusive.\\n *\\n * Role bearers are not sorted in any particular way, and their ordering may\\n * change at any point.\\n *\\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\\n * you perform all queries on the same block. See the following\\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\\n * for more information.\\n */\\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\\n return _roleMembers[role].at(index);\\n }\\n\\n /**\\n * @dev Returns the number of accounts that have `role`. Can be used\\n * together with {getRoleMember} to enumerate all bearers of a role.\\n */\\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\\n return _roleMembers[role].length();\\n }\\n\\n /**\\n * @dev Overload {_grantRole} to track enumerable memberships\\n */\\n function _grantRole(bytes32 role, address account) internal virtual override {\\n super._grantRole(role, account);\\n _roleMembers[role].add(account);\\n }\\n\\n /**\\n * @dev Overload {_revokeRole} to track enumerable memberships\\n */\\n function _revokeRole(bytes32 role, address account) internal virtual override {\\n super._revokeRole(role, account);\\n _roleMembers[role].remove(account);\\n }\\n}\\n\",\"keccak256\":\"0x13f5e15f2a0650c0b6aaee2ef19e89eaf4870d6e79662d572a393334c1397247\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/IAccessControl.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev External interface of AccessControl declared to support ERC165 detection.\\n */\\ninterface IAccessControl {\\n /**\\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\\n *\\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\\n * {RoleAdminChanged} not being emitted signaling this.\\n *\\n * _Available since v3.1._\\n */\\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\\n\\n /**\\n * @dev Emitted when `account` is granted `role`.\\n *\\n * `sender` is the account that originated the contract call, an admin role\\n * bearer except when using {AccessControl-_setupRole}.\\n */\\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\\n\\n /**\\n * @dev Emitted when `account` is revoked `role`.\\n *\\n * `sender` is the account that originated the contract call:\\n * - if using `revokeRole`, it is the admin role bearer\\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\\n */\\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\\n\\n /**\\n * @dev Returns `true` if `account` has been granted `role`.\\n */\\n function hasRole(bytes32 role, address account) external view returns (bool);\\n\\n /**\\n * @dev Returns the admin role that controls `role`. See {grantRole} and\\n * {revokeRole}.\\n *\\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\\n */\\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\\n\\n /**\\n * @dev Grants `role` to `account`.\\n *\\n * If `account` had not been already granted `role`, emits a {RoleGranted}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n */\\n function grantRole(bytes32 role, address account) external;\\n\\n /**\\n * @dev Revokes `role` from `account`.\\n *\\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\\n *\\n * Requirements:\\n *\\n * - the caller must have ``role``'s admin role.\\n */\\n function revokeRole(bytes32 role, address account) external;\\n\\n /**\\n * @dev Revokes `role` from the calling account.\\n *\\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\\n * purpose is to provide a mechanism for accounts to lose their privileges\\n * if they are compromised (such as when a trusted device is misplaced).\\n *\\n * If the calling account had been granted `role`, emits a {RoleRevoked}\\n * event.\\n *\\n * Requirements:\\n *\\n * - the caller must be `account`.\\n */\\n function renounceRole(bytes32 role, address account) external;\\n}\\n\",\"keccak256\":\"0x59ce320a585d7e1f163cd70390a0ef2ff9cec832e2aa544293a00692465a7a57\",\"license\":\"MIT\"},\"@openzeppelin/contracts/access/IAccessControlEnumerable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IAccessControl.sol\\\";\\n\\n/**\\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\\n */\\ninterface IAccessControlEnumerable is IAccessControl {\\n /**\\n * @dev Returns one of the accounts that have `role`. `index` must be a\\n * value between 0 and {getRoleMemberCount}, non-inclusive.\\n *\\n * Role bearers are not sorted in any particular way, and their ordering may\\n * change at any point.\\n *\\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\\n * you perform all queries on the same block. See the following\\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\\n * for more information.\\n */\\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\\n\\n /**\\n * @dev Returns the number of accounts that have `role`. Can be used\\n * together with {getRoleMember} to enumerate all bearers of a role.\\n */\\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\\n}\\n\",\"keccak256\":\"0xba4459ab871dfa300f5212c6c30178b63898c03533a1ede28436f11546626676\",\"license\":\"MIT\"},\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/security/Pausable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../utils/Context.sol\\\";\\n\\n/**\\n * @dev Contract module which allows children to implement an emergency stop\\n * mechanism that can be triggered by an authorized account.\\n *\\n * This module is used through inheritance. It will make available the\\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\\n * the functions of your contract. Note that they will not be pausable by\\n * simply including this module, only once the modifiers are put in place.\\n */\\nabstract contract Pausable is Context {\\n /**\\n * @dev Emitted when the pause is triggered by `account`.\\n */\\n event Paused(address account);\\n\\n /**\\n * @dev Emitted when the pause is lifted by `account`.\\n */\\n event Unpaused(address account);\\n\\n bool private _paused;\\n\\n /**\\n * @dev Initializes the contract in unpaused state.\\n */\\n constructor() {\\n _paused = false;\\n }\\n\\n /**\\n * @dev Modifier to make a function callable only when the contract is not paused.\\n *\\n * Requirements:\\n *\\n * - The contract must not be paused.\\n */\\n modifier whenNotPaused() {\\n _requireNotPaused();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to make a function callable only when the contract is paused.\\n *\\n * Requirements:\\n *\\n * - The contract must be paused.\\n */\\n modifier whenPaused() {\\n _requirePaused();\\n _;\\n }\\n\\n /**\\n * @dev Returns true if the contract is paused, and false otherwise.\\n */\\n function paused() public view virtual returns (bool) {\\n return _paused;\\n }\\n\\n /**\\n * @dev Throws if the contract is paused.\\n */\\n function _requireNotPaused() internal view virtual {\\n require(!paused(), \\\"Pausable: paused\\\");\\n }\\n\\n /**\\n * @dev Throws if the contract is not paused.\\n */\\n function _requirePaused() internal view virtual {\\n require(paused(), \\\"Pausable: not paused\\\");\\n }\\n\\n /**\\n * @dev Triggers stopped state.\\n *\\n * Requirements:\\n *\\n * - The contract must not be paused.\\n */\\n function _pause() internal virtual whenNotPaused {\\n _paused = true;\\n emit Paused(_msgSender());\\n }\\n\\n /**\\n * @dev Returns to normal state.\\n *\\n * Requirements:\\n *\\n * - The contract must be paused.\\n */\\n function _unpause() internal virtual whenPaused {\\n _paused = false;\\n emit Unpaused(_msgSender());\\n }\\n}\\n\",\"keccak256\":\"0x0849d93b16c9940beb286a7864ed02724b248b93e0d80ef6355af5ef15c64773\",\"license\":\"MIT\"},\"@openzeppelin/contracts/token/ERC20/IERC20.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC20 standard as defined in the EIP.\\n */\\ninterface IERC20 {\\n /**\\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\\n * another (`to`).\\n *\\n * Note that `value` may be zero.\\n */\\n event Transfer(address indexed from, address indexed to, uint256 value);\\n\\n /**\\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\\n * a call to {approve}. `value` is the new allowance.\\n */\\n event Approval(address indexed owner, address indexed spender, uint256 value);\\n\\n /**\\n * @dev Returns the amount of tokens in existence.\\n */\\n function totalSupply() external view returns (uint256);\\n\\n /**\\n * @dev Returns the amount of tokens owned by `account`.\\n */\\n function balanceOf(address account) external view returns (uint256);\\n\\n /**\\n * @dev Moves `amount` tokens from the caller's account to `to`.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transfer(address to, uint256 amount) external returns (bool);\\n\\n /**\\n * @dev Returns the remaining number of tokens that `spender` will be\\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\\n * zero by default.\\n *\\n * This value changes when {approve} or {transferFrom} are called.\\n */\\n function allowance(address owner, address spender) external view returns (uint256);\\n\\n /**\\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\\n * that someone may use both the old and the new allowance by unfortunate\\n * transaction ordering. One possible solution to mitigate this race\\n * condition is to first reduce the spender's allowance to 0 and set the\\n * desired value afterwards:\\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\\n *\\n * Emits an {Approval} event.\\n */\\n function approve(address spender, uint256 amount) external returns (bool);\\n\\n /**\\n * @dev Moves `amount` tokens from `from` to `to` using the\\n * allowance mechanism. `amount` is then deducted from the caller's\\n * allowance.\\n *\\n * Returns a boolean value indicating whether the operation succeeded.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transferFrom(\\n address from,\\n address to,\\n uint256 amount\\n ) external returns (bool);\\n}\\n\",\"keccak256\":\"0x9750c6b834f7b43000631af5cc30001c5f547b3ceb3635488f140f60e897ea6b\",\"license\":\"MIT\"},\"@openzeppelin/contracts/token/ERC721/IERC721.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../utils/introspection/IERC165.sol\\\";\\n\\n/**\\n * @dev Required interface of an ERC721 compliant contract.\\n */\\ninterface IERC721 is IERC165 {\\n /**\\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\\n */\\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\\n\\n /**\\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\\n */\\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\\n\\n /**\\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\\n */\\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\\n\\n /**\\n * @dev Returns the number of tokens in ``owner``'s account.\\n */\\n function balanceOf(address owner) external view returns (uint256 balance);\\n\\n /**\\n * @dev Returns the owner of the `tokenId` token.\\n *\\n * Requirements:\\n *\\n * - `tokenId` must exist.\\n */\\n function ownerOf(uint256 tokenId) external view returns (address owner);\\n\\n /**\\n * @dev Safely transfers `tokenId` token from `from` to `to`.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must exist and be owned by `from`.\\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\\n *\\n * Emits a {Transfer} event.\\n */\\n function safeTransferFrom(\\n address from,\\n address to,\\n uint256 tokenId,\\n bytes calldata data\\n ) external;\\n\\n /**\\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must exist and be owned by `from`.\\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\\n *\\n * Emits a {Transfer} event.\\n */\\n function safeTransferFrom(\\n address from,\\n address to,\\n uint256 tokenId\\n ) external;\\n\\n /**\\n * @dev Transfers `tokenId` token from `from` to `to`.\\n *\\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\\n *\\n * Requirements:\\n *\\n * - `from` cannot be the zero address.\\n * - `to` cannot be the zero address.\\n * - `tokenId` token must be owned by `from`.\\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\\n *\\n * Emits a {Transfer} event.\\n */\\n function transferFrom(\\n address from,\\n address to,\\n uint256 tokenId\\n ) external;\\n\\n /**\\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\\n * The approval is cleared when the token is transferred.\\n *\\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\\n *\\n * Requirements:\\n *\\n * - The caller must own the token or be an approved operator.\\n * - `tokenId` must exist.\\n *\\n * Emits an {Approval} event.\\n */\\n function approve(address to, uint256 tokenId) external;\\n\\n /**\\n * @dev Approve or remove `operator` as an operator for the caller.\\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\\n *\\n * Requirements:\\n *\\n * - The `operator` cannot be the caller.\\n *\\n * Emits an {ApprovalForAll} event.\\n */\\n function setApprovalForAll(address operator, bool _approved) external;\\n\\n /**\\n * @dev Returns the account approved for `tokenId` token.\\n *\\n * Requirements:\\n *\\n * - `tokenId` must exist.\\n */\\n function getApproved(uint256 tokenId) external view returns (address operator);\\n\\n /**\\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\\n *\\n * See {setApprovalForAll}\\n */\\n function isApprovedForAll(address owner, address operator) external view returns (bool);\\n}\\n\",\"keccak256\":\"0xed6a749c5373af398105ce6ee3ac4763aa450ea7285d268c85d9eeca809cdb1f\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Context.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Provides information about the current execution context, including the\\n * sender of the transaction and its data. While these are generally available\\n * via msg.sender and msg.data, they should not be accessed in such a direct\\n * manner, since when dealing with meta-transactions the account sending and\\n * paying for execution may not be the actual sender (as far as an application\\n * is concerned).\\n *\\n * This contract is only required for intermediate, library-like contracts.\\n */\\nabstract contract Context {\\n function _msgSender() internal view virtual returns (address) {\\n return msg.sender;\\n }\\n\\n function _msgData() internal view virtual returns (bytes calldata) {\\n return msg.data;\\n }\\n}\\n\",\"keccak256\":\"0xe2e337e6dde9ef6b680e07338c493ebea1b5fd09b43424112868e9cc1706bca7\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/ERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"./IERC165.sol\\\";\\n\\n/**\\n * @dev Implementation of the {IERC165} interface.\\n *\\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\\n * for the additional interface id that will be supported. For example:\\n *\\n * ```solidity\\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\\n * }\\n * ```\\n *\\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\\n */\\nabstract contract ERC165 is IERC165 {\\n /**\\n * @dev See {IERC165-supportsInterface}.\\n */\\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\\n return interfaceId == type(IERC165).interfaceId;\\n }\\n}\\n\",\"keccak256\":\"0xd10975de010d89fd1c78dc5e8a9a7e7f496198085c151648f20cba166b32582b\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for managing\\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\\n * types.\\n *\\n * Sets have the following properties:\\n *\\n * - Elements are added, removed, and checked for existence in constant time\\n * (O(1)).\\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\\n *\\n * ```\\n * contract Example {\\n * // Add the library methods\\n * using EnumerableSet for EnumerableSet.AddressSet;\\n *\\n * // Declare a set state variable\\n * EnumerableSet.AddressSet private mySet;\\n * }\\n * ```\\n *\\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\\n * and `uint256` (`UintSet`) are supported.\\n *\\n * [WARNING]\\n * ====\\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\\n *\\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\\n * ====\\n */\\nlibrary EnumerableSet {\\n // To implement this library for multiple types with as little code\\n // repetition as possible, we write it in terms of a generic Set type with\\n // bytes32 values.\\n // The Set implementation uses private functions, and user-facing\\n // implementations (such as AddressSet) are just wrappers around the\\n // underlying Set.\\n // This means that we can only create new EnumerableSets for types that fit\\n // in bytes32.\\n\\n struct Set {\\n // Storage of set values\\n bytes32[] _values;\\n // Position of the value in the `values` array, plus 1 because index 0\\n // means a value is not in the set.\\n mapping(bytes32 => uint256) _indexes;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function _add(Set storage set, bytes32 value) private returns (bool) {\\n if (!_contains(set, value)) {\\n set._values.push(value);\\n // The value is stored at length-1, but we add 1 to all indexes\\n // and use 0 as a sentinel value\\n set._indexes[value] = set._values.length;\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function _remove(Set storage set, bytes32 value) private returns (bool) {\\n // We read and store the value's index to prevent multiple reads from the same storage slot\\n uint256 valueIndex = set._indexes[value];\\n\\n if (valueIndex != 0) {\\n // Equivalent to contains(set, value)\\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\\n // the array, and then remove the last element (sometimes called as 'swap and pop').\\n // This modifies the order of the array, as noted in {at}.\\n\\n uint256 toDeleteIndex = valueIndex - 1;\\n uint256 lastIndex = set._values.length - 1;\\n\\n if (lastIndex != toDeleteIndex) {\\n bytes32 lastValue = set._values[lastIndex];\\n\\n // Move the last value to the index where the value to delete is\\n set._values[toDeleteIndex] = lastValue;\\n // Update the index for the moved value\\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\\n }\\n\\n // Delete the slot where the moved value was stored\\n set._values.pop();\\n\\n // Delete the index for the deleted slot\\n delete set._indexes[value];\\n\\n return true;\\n } else {\\n return false;\\n }\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\\n return set._indexes[value] != 0;\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function _length(Set storage set) private view returns (uint256) {\\n return set._values.length;\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\\n return set._values[index];\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function _values(Set storage set) private view returns (bytes32[] memory) {\\n return set._values;\\n }\\n\\n // Bytes32Set\\n\\n struct Bytes32Set {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _add(set._inner, value);\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\\n return _remove(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\\n return _contains(set._inner, value);\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(Bytes32Set storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\\n return _at(set._inner, index);\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\\n return _values(set._inner);\\n }\\n\\n // AddressSet\\n\\n struct AddressSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(AddressSet storage set, address value) internal returns (bool) {\\n return _add(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(AddressSet storage set, address value) internal returns (bool) {\\n return _remove(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(AddressSet storage set, address value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(uint256(uint160(value))));\\n }\\n\\n /**\\n * @dev Returns the number of values in the set. O(1).\\n */\\n function length(AddressSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\\n return address(uint160(uint256(_at(set._inner, index))));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(AddressSet storage set) internal view returns (address[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n address[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n\\n // UintSet\\n\\n struct UintSet {\\n Set _inner;\\n }\\n\\n /**\\n * @dev Add a value to a set. O(1).\\n *\\n * Returns true if the value was added to the set, that is if it was not\\n * already present.\\n */\\n function add(UintSet storage set, uint256 value) internal returns (bool) {\\n return _add(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Removes a value from a set. O(1).\\n *\\n * Returns true if the value was removed from the set, that is if it was\\n * present.\\n */\\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\\n return _remove(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns true if the value is in the set. O(1).\\n */\\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\\n return _contains(set._inner, bytes32(value));\\n }\\n\\n /**\\n * @dev Returns the number of values on the set. O(1).\\n */\\n function length(UintSet storage set) internal view returns (uint256) {\\n return _length(set._inner);\\n }\\n\\n /**\\n * @dev Returns the value stored at position `index` in the set. O(1).\\n *\\n * Note that there are no guarantees on the ordering of values inside the\\n * array, and it may change when more values are added or removed.\\n *\\n * Requirements:\\n *\\n * - `index` must be strictly less than {length}.\\n */\\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\\n return uint256(_at(set._inner, index));\\n }\\n\\n /**\\n * @dev Return the entire set in an array\\n *\\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\\n */\\n function values(UintSet storage set) internal view returns (uint256[] memory) {\\n bytes32[] memory store = _values(set._inner);\\n uint256[] memory result;\\n\\n /// @solidity memory-safe-assembly\\n assembly {\\n result := store\\n }\\n\\n return result;\\n }\\n}\\n\",\"keccak256\":\"0x5050943b32b6a8f282573d166b2e9d87ab7eb4dbba4ab6acf36ecb54fe6995e4\",\"license\":\"MIT\"},\"contracts/extensions/GatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/security/Pausable.sol\\\";\\nimport \\\"../interfaces/IQuorum.sol\\\";\\nimport \\\"./collections/HasProxyAdmin.sol\\\";\\n\\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\\n uint256 internal _num;\\n uint256 internal _denom;\\n\\n address private ______deprecated;\\n uint256 public nonce;\\n\\n address public emergencyPauser;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[49] private ______gap;\\n\\n /**\\n * @dev Grant emergency pauser role for `_addr`.\\n */\\n function setEmergencyPauser(address _addr) external onlyAdmin {\\n emergencyPauser = _addr;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (_num, _denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * _denom >= _num * _getTotalWeight();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external virtual onlyAdmin returns (uint256, uint256) {\\n return _setThreshold(_numerator, _denominator);\\n }\\n\\n /**\\n * @dev Triggers paused state.\\n */\\n function pause() external {\\n _requireAuth();\\n _pause();\\n }\\n\\n /**\\n * @dev Triggers unpaused state.\\n */\\n function unpause() external {\\n _requireAuth();\\n _unpause();\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() public view virtual returns (uint256) {\\n return _minimumVoteWeight(_getTotalWeight());\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\\n _previousNum = _num;\\n _previousDenom = _denom;\\n _num = _numerator;\\n _denom = _denominator;\\n unchecked {\\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\\n }\\n }\\n\\n /**\\n * @dev Returns minimum vote weight.\\n */\\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\\n return (_num * _totalWeight + _denom - 1) / _denom;\\n }\\n\\n /**\\n * @dev Internal method to check method caller.\\n *\\n * Requirements:\\n *\\n * - The method caller must be admin or pauser.\\n *\\n */\\n function _requireAuth() private view {\\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n }\\n\\n /**\\n * @dev Returns the total weight.\\n */\\n function _getTotalWeight() internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0xfcb8d4fa4358387c477a40da4d8a5108c298f23333c4161ce939c1b27a09ffde\",\"license\":\"MIT\"},\"contracts/extensions/MinimumWithdrawal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./collections/HasProxyAdmin.sol\\\";\\nimport \\\"../libraries/Transfer.sol\\\";\\n\\nabstract contract MinimumWithdrawal is HasProxyAdmin {\\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\\n error ErrQueryForTooSmallQuantity();\\n\\n /// @dev Emitted when the minimum thresholds are updated\\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\\n\\n /// @dev Mapping from token address => minimum thresholds\\n mapping(address => uint256) public minimumThreshold;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @dev Sets the minimum thresholds to withdraw.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `MinimumThresholdsUpdated` event.\\n *\\n */\\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\\n if (_tokens.length == 0) revert ErrEmptyArray();\\n _setMinimumThresholds(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Sets minimum thresholds.\\n *\\n * Requirements:\\n * - The array lengths are equal.\\n *\\n * Emits the `MinimumThresholdsUpdated` event.\\n *\\n */\\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _tokens.length; ) {\\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\\n }\\n\\n /**\\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\\n */\\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\\n revert ErrQueryForTooSmallQuantity();\\n }\\n }\\n}\\n\",\"keccak256\":\"0xbbb1db4bcefff2b7cac574410f7716e6d61d461ab40ca453d5f988e971c480dc\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IERC20Mintable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.2;\\n\\ninterface IERC20Mintable {\\n function mint(address _to, uint256 _value) external returns (bool _success);\\n}\\n\",\"keccak256\":\"0x6632cb3345e581a0b7868d6ce9a883f55d107576f9557f500a042c8285e51005\",\"license\":\"MIT\"},\"contracts/interfaces/IERC721Mintable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IERC721Mintable {\\n function mint(address _to, uint256 _tokenId) external returns (bool);\\n}\\n\",\"keccak256\":\"0x4f001516a2596c79c205a9e28de092aa866eb440040e78b8be9027451028f169\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninGatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../libraries/Transfer.sol\\\";\\nimport \\\"./consumers/MappedTokenConsumer.sol\\\";\\n\\ninterface IRoninGatewayV3 is MappedTokenConsumer {\\n /**\\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\\n */\\n error ErrWithdrawalsMigrated();\\n\\n /**\\n * @dev Error thrown when an invalid trusted threshold is specified.\\n */\\n error ErrInvalidTrustedThreshold();\\n\\n /**\\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\\n */\\n error ErrWithdrawnOnMainchainAlready();\\n\\n /// @dev Emitted when the assets are depositted\\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\\n /// @dev Emitted when the withdrawal is requested\\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\\n /// @dev Emitted when the assets are withdrawn on mainchain\\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\\n /// @dev Emitted when the withdrawal signatures is requested\\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\\n /// @dev Emitted when the tokens are mapped\\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\\n /// @dev Emitted when the threshold is updated\\n event TrustedThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n /// @dev Emitted when a deposit is voted\\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\\n\\n /**\\n * @dev Returns withdrawal count.\\n */\\n function withdrawalCount() external view returns (uint256);\\n\\n /**\\n * @dev Returns withdrawal signatures.\\n */\\n function getWithdrawalSignatures(\\n uint256 _withdrawalId,\\n address[] calldata _validators\\n ) external view returns (bytes[] memory);\\n\\n /**\\n * @dev Deposits based on the receipt.\\n *\\n * Requirements:\\n * - The method caller is a validator.\\n *\\n * Emits the `Deposited` once the assets are released.\\n *\\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\\n *\\n */\\n function depositFor(Transfer.Receipt calldata _receipt) external;\\n\\n /**\\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\\n * vote is already done before.\\n *\\n * Requirements:\\n * - The method caller is a validator.\\n *\\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\\n *\\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\\n * same time.\\n *\\n */\\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\\n\\n /**\\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\\n *\\n * Requirements:\\n * - The method caller is a validator.\\n *\\n * Emits the `Deposited` once the assets are released.\\n *\\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\\n *\\n */\\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\\n\\n /**\\n * @dev Locks the assets and request withdrawal.\\n *\\n * Emits the `WithdrawalRequested` event.\\n *\\n */\\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\\n\\n /**\\n * @dev Bulk requests withdrawals.\\n *\\n * Emits the `WithdrawalRequested` events.\\n *\\n */\\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\\n\\n /**\\n * @dev Requests withdrawal signatures for a specific withdrawal.\\n *\\n * Emits the `WithdrawalSignaturesRequested` event.\\n *\\n */\\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\\n\\n /**\\n * @dev Submits withdrawal signatures.\\n *\\n * Requirements:\\n * - The method caller is a validator.\\n *\\n */\\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\\n\\n /**\\n * @dev Maps Ronin tokens to mainchain networks.\\n *\\n * Requirement:\\n * - The method caller is admin.\\n * - The arrays have the same length and its length larger than 0.\\n *\\n * Emits the `TokenMapped` event.\\n *\\n */\\n function mapTokens(\\n address[] calldata _roninTokens,\\n address[] calldata _mainchainTokens,\\n uint256[] calldata chainIds,\\n Token.Standard[] calldata _standards\\n ) external;\\n\\n /**\\n * @dev Returns whether the deposit is casted by the voter.\\n */\\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the mainchain withdrew is casted by the voter.\\n */\\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the withdrawal is done on mainchain.\\n */\\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\\n\\n /**\\n * @dev Returns mainchain token address.\\n * Reverts for unsupported token.\\n */\\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\\n}\\n\",\"keccak256\":\"0x6434038ea1b762a0889dc6725e13ae793bec3c35a33f0edf91754b50a359f690\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n /**\\n * @dev Error indicating that a query for a duplicate entry was made.\\n */\\n error ErrQueryForDupplicated();\\n\\n /**\\n * @dev Error indicating that a query was made for a non-existent consensus address.\\n */\\n error ErrQueryForNonExistentConsensusAddress();\\n\\n /**\\n * @dev Error indicating that a bridge voter has already been added.\\n * @param voter The address of the bridge voter that is already added.\\n */\\n error ErrBridgeVoterIsAlreadyAdded(address voter);\\n\\n /**\\n * @dev Error indicating that a governor address has already been added.\\n * @param addr The address of the governor that is already added.\\n */\\n error ErrGovernorAddressIsAlreadyAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is not added.\\n * @param addr The address of the consensus contract that is not added.\\n */\\n error ErrConsensusAddressIsNotAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is already added.\\n * @param addr The address of the consensus contract that is already added.\\n */\\n error ErrConsensusAddressIsAlreadyAdded(address addr);\\n\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganization() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x2eaef3332e209474b24574aeded61091e82a145fcbcf479577535c0cd210e1e5\",\"license\":\"MIT\"},\"contracts/interfaces/IWETH.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IWETH {\\n function deposit() external payable;\\n\\n function withdraw(uint256 _wad) external;\\n\\n function balanceOf(address) external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x8acead2ae4364dee80c9bc76d52cc04d3763105e1743728e67d237f816155142\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { IBridgeManagerEvents } from \\\"./events/IBridgeManagerEvents.sol\\\";\\n\\n/**\\n * @title IBridgeManager\\n * @dev The interface for managing bridge operators.\\n */\\ninterface IBridgeManager is IBridgeManagerEvents {\\n /**\\n * @dev The domain separator used for computing hash digests in the contract.\\n */\\n function DOMAIN_SEPARATOR() external view returns (bytes32);\\n\\n /**\\n * @dev Returns the total number of bridge operators.\\n * @return The total number of bridge operators.\\n */\\n function totalBridgeOperator() external view returns (uint256);\\n\\n /**\\n * @dev Checks if the given address is a bridge operator.\\n * @param addr The address to check.\\n * @return A boolean indicating whether the address is a bridge operator.\\n */\\n function isBridgeOperator(address addr) external view returns (bool);\\n\\n /**\\n * @dev Retrieves the full information of all registered bridge operators.\\n *\\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\\n *\\n * @return governors An array of addresses representing the governors of each bridge operator.\\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\\n *\\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\\n *\\n * Example Usage:\\n * ```\\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\\n * // Access individual information for each bridge operator.\\n * address governor = governors[i];\\n * address bridgeOperator = bridgeOperators[i];\\n * uint256 weight = weights[i];\\n * // ... (Process or use the information as required) ...\\n * }\\n * ```\\n *\\n */\\n function getFullBridgeOperatorInfos()\\n external\\n view\\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function getTotalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns an array of all bridge operators.\\n * @return An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns an array of bridge operators correspoding to governor addresses.\\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\\n */\\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\\n\\n /**\\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\\n */\\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific governor.\\n * @param governor The address of the governor to get the vote weight for.\\n * @return voteWeight The vote weight of the specified governor.\\n */\\n function getGovernorWeight(address governor) external view returns (uint96);\\n\\n /**\\n * @dev External function to retrieve the vote weight of a specific bridge operator.\\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\\n * @return weight The vote weight of the specified bridge operator.\\n */\\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\\n\\n /**\\n * @dev Returns an array of all governors.\\n * @return An array containing the addresses of all governors.\\n */\\n function getGovernors() external view returns (address[] memory);\\n\\n /**\\n * @dev Adds multiple bridge operators.\\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\\n *\\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\\n * voteWeights,\\n * governors,\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function addBridgeOperators(\\n uint96[] calldata voteWeights,\\n address[] calldata governors,\\n address[] calldata bridgeOperators\\n ) external returns (bool[] memory addeds);\\n\\n /**\\n * @dev Removes multiple bridge operators.\\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\\n *\\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\\n *\\n * Example Usage:\\n * Making an `eth_call` in ethers.js\\n * ```\\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\\n * bridgeOperators,\\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\\n * {from: bridgeManagerContract.address}\\n * )\\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\\n * // ... (Process or use the information as required) ...\\n * ```\\n */\\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\\n\\n /**\\n * @dev Governor updates their corresponding governor and/or operator address.\\n * Requirements:\\n * - The caller must the governor of the operator that is requested changes.\\n * @param bridgeOperator The address of the bridge operator to update.\\n */\\n function updateBridgeOperator(address bridgeOperator) external;\\n}\\n\",\"keccak256\":\"0x9339ce2f14bc1e4d0e368a351506ff5735bcbc0a2e41aa633149198bbed76a60\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\\n\\n /**\\n * @dev Returns the block that allow incomming mutable call.\\n */\\n function startedAtBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVote(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallot(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(\\n uint256 _period,\\n address[] calldata _bridgeOperators\\n ) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\\n}\\n\",\"keccak256\":\"0x092841025351341cf7ff9cbf0eb6ef78752ffd2b1af329cb6048996d20c789a9\",\"license\":\"MIT\"},\"contracts/interfaces/bridge/events/IBridgeManagerEvents.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeManagerEvents {\\n /**\\n * @dev The structure representing information about a bridge operator.\\n * @param addr The address of the bridge operator.\\n * @param voteWeight The vote weight assigned to the bridge operator.\\n */\\n struct BridgeOperatorInfo {\\n address addr;\\n uint96 voteWeight;\\n }\\n\\n /**\\n * @dev Emitted when new bridge operators are added.\\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\\n * @param bridgeOperators The array of addresses representing the added bridge operators.\\n */\\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when bridge operators are removed.\\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\\n */\\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\\n\\n /**\\n * @dev Emitted when a bridge operator is updated.\\n * @param governor The address of the governor initiating the update.\\n * @param fromBridgeOperator The address of the bridge operator being updated.\\n * @param toBridgeOperator The updated address of the bridge operator.\\n */\\n event BridgeOperatorUpdated(\\n address indexed governor,\\n address indexed fromBridgeOperator,\\n address indexed toBridgeOperator\\n );\\n}\\n\",\"keccak256\":\"0x217fff41c4a9ca72d142c5a2120bb1b5e67bf5bf5aa0f6128450116aebc07b8d\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/MappedTokenConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../../libraries/Token.sol\\\";\\n\\ninterface MappedTokenConsumer {\\n struct MappedToken {\\n Token.Standard erc;\\n address tokenAddr;\\n }\\n}\\n\",\"keccak256\":\"0xfa220e968221af9b789e6c1dc4133631e90600c4a2bd63b7f01e96cb01f13e9b\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/VoteStatusConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface VoteStatusConsumer {\\n enum VoteStatus {\\n Pending,\\n Approved,\\n Executed,\\n Rejected,\\n Expired\\n }\\n}\\n\",\"keccak256\":\"0xa5045232c0c053fcf31fb3fe71942344444159c48d5f1b2063dbb06b6a1c9752\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/IsolatedGovernance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../interfaces/consumers/VoteStatusConsumer.sol\\\";\\nimport \\\"../utils/CommonErrors.sol\\\";\\n\\nlibrary IsolatedGovernance {\\n struct Vote {\\n VoteStatusConsumer.VoteStatus status;\\n bytes32 finalHash;\\n /// @dev Mapping from voter => receipt hash\\n mapping(address => bytes32) voteHashOf;\\n /// @dev The timestamp that voting is expired (no expiration=0)\\n uint256 expiredAt;\\n /// @dev The timestamp that voting is created\\n uint256 createdAt;\\n /// @dev The list of voters\\n address[] voters;\\n }\\n\\n /**\\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\\n *\\n * Requirements:\\n * - The voter has not voted for the round.\\n *\\n */\\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\\n }\\n\\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\\n\\n _v.voteHashOf[_voter] = _hash;\\n _v.voters.push(_voter);\\n }\\n\\n /**\\n * @dev Updates vote with the requirement of minimum vote weight.\\n */\\n function syncVoteStatus(\\n Vote storage _v,\\n uint256 _minimumVoteWeight,\\n uint256 _votedWeightForHash,\\n bytes32 _hash\\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\\n _v.finalHash = _hash;\\n }\\n\\n return _v.status;\\n }\\n\\n /**\\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\\n */\\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\\n uint256 _count;\\n _voters = new address[](_v.voters.length);\\n\\n unchecked {\\n for (uint _i; _i < _voters.length; ++_i) {\\n address _voter = _v.voters[_i];\\n if (_v.voteHashOf[_voter] == _hash) {\\n _voters[_count++] = _voter;\\n }\\n }\\n }\\n\\n assembly {\\n mstore(_voters, _count)\\n }\\n }\\n\\n /**\\n * @dev Returns whether the voter casted for the proposal.\\n */\\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\\n return _v.voteHashOf[_voter] != bytes32(0);\\n }\\n}\\n\",\"keccak256\":\"0xa6a1e04b914580c099ac87f65ec24c35445eee34809e3decf1c57b6c52942d36\",\"license\":\"MIT\"},\"contracts/libraries/Token.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/token/ERC20/IERC20.sol\\\";\\nimport \\\"@openzeppelin/contracts/token/ERC721/IERC721.sol\\\";\\nimport \\\"../interfaces/IWETH.sol\\\";\\n\\nlibrary Token {\\n /// @dev Error indicating that the provided information is invalid.\\n error ErrInvalidInfo();\\n\\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\\n error ErrERC20MintingFailed();\\n\\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\\n error ErrERC721MintingFailed();\\n\\n /// @dev Error indicating that an unsupported standard is encountered.\\n error ErrUnsupportedStandard();\\n\\n /**\\n * @dev Error indicating that the `transfer` has failed.\\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\\n * @param to Receiver of the token value.\\n * @param token Address of the token.\\n */\\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\\n\\n /**\\n * @dev Error indicating that the `transferFrom` has failed.\\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\\n * @param from Owner of the token value.\\n * @param to Receiver of the token value.\\n * @param token Address of the token.\\n */\\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\\n\\n enum Standard {\\n ERC20,\\n ERC721\\n }\\n\\n struct Info {\\n Standard erc;\\n // For ERC20: the id must be 0 and the quantity is larger than 0.\\n // For ERC721: the quantity must be 0.\\n uint256 id;\\n uint256 quantity;\\n }\\n\\n // keccak256(\\\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\\\");\\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\\n\\n /**\\n * @dev Returns token info struct hash.\\n */\\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, INFO_TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\\n digest := keccak256(ptr, 0x80)\\n }\\n }\\n\\n /**\\n * @dev Validates the token info.\\n */\\n function validate(Info memory _info) internal pure {\\n if (\\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\\n ) revert ErrInvalidInfo();\\n }\\n\\n /**\\n * @dev Transfer asset from.\\n *\\n * Requirements:\\n * - The `_from` address must approve for the contract using this library.\\n *\\n */\\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\\n bool _success;\\n bytes memory _data;\\n if (_info.erc == Standard.ERC20) {\\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\\n } else if (_info.erc == Standard.ERC721) {\\n // bytes4(keccak256(\\\"transferFrom(address,address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\\n } else revert ErrUnsupportedStandard();\\n\\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\\n }\\n\\n /**\\n * @dev Transfers ERC721 token and returns the result.\\n */\\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\\n }\\n\\n /**\\n * @dev Transfers ERC20 token and returns the result.\\n */\\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\\n bytes memory _data;\\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\\n }\\n\\n /**\\n * @dev Transfer assets from current address to `_to` address.\\n */\\n function transfer(Info memory _info, address _to, address _token) internal {\\n bool _success;\\n if (_info.erc == Standard.ERC20) {\\n _success = tryTransferERC20(_token, _to, _info.quantity);\\n } else if (_info.erc == Standard.ERC721) {\\n _success = tryTransferERC721(_token, _to, _info.id);\\n } else revert ErrUnsupportedStandard();\\n\\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\\n }\\n\\n /**\\n * @dev Tries minting and transfering assets.\\n *\\n * @notice Prioritizes transfer native token if the token is wrapped.\\n *\\n */\\n function handleAssetTransfer(\\n Info memory _info,\\n address payable _to,\\n address _token,\\n IWETH _wrappedNativeToken\\n ) internal {\\n bool _success;\\n if (_token == address(_wrappedNativeToken)) {\\n // Try sending the native token before transferring the wrapped token\\n if (!_to.send(_info.quantity)) {\\n _wrappedNativeToken.deposit{ value: _info.quantity }();\\n transfer(_info, _to, _token);\\n }\\n } else if (_info.erc == Token.Standard.ERC20) {\\n uint256 _balance = IERC20(_token).balanceOf(address(this));\\n\\n if (_balance < _info.quantity) {\\n // bytes4(keccak256(\\\"mint(address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\\n if (!_success) revert ErrERC20MintingFailed();\\n }\\n\\n transfer(_info, _to, _token);\\n } else if (_info.erc == Token.Standard.ERC721) {\\n if (!tryTransferERC721(_token, _to, _info.id)) {\\n // bytes4(keccak256(\\\"mint(address,uint256)\\\"))\\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\\n if (!_success) revert ErrERC721MintingFailed();\\n }\\n } else revert ErrUnsupportedStandard();\\n }\\n\\n struct Owner {\\n address addr;\\n address tokenAddr;\\n uint256 chainId;\\n }\\n\\n // keccak256(\\\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\\\");\\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\\n\\n /**\\n * @dev Returns ownership struct hash.\\n */\\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, OWNER_TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\\n digest := keccak256(ptr, 0x80)\\n }\\n }\\n}\\n\",\"keccak256\":\"0x8d11e48d878ba37ea2ca7395dceaa5591bb9ba2d4e5fdac1565760456e104991\",\"license\":\"MIT\"},\"contracts/libraries/Transfer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\nimport \\\"@openzeppelin/contracts/token/ERC20/IERC20.sol\\\";\\nimport \\\"./Token.sol\\\";\\n\\nlibrary Transfer {\\n using ECDSA for bytes32;\\n\\n enum Kind {\\n Deposit,\\n Withdrawal\\n }\\n\\n struct Request {\\n // For deposit request: Recipient address on Ronin network\\n // For withdrawal request: Recipient address on mainchain network\\n address recipientAddr;\\n // Token address to deposit/withdraw\\n // Value 0: native token\\n address tokenAddr;\\n Token.Info info;\\n }\\n\\n /**\\n * @dev Converts the transfer request into the deposit receipt.\\n */\\n function into_deposit_receipt(\\n Request memory _request,\\n address _requester,\\n uint256 _id,\\n address _roninTokenAddr,\\n uint256 _roninChainId\\n ) internal view returns (Receipt memory _receipt) {\\n _receipt.id = _id;\\n _receipt.kind = Kind.Deposit;\\n _receipt.mainchain.addr = _requester;\\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\\n _receipt.mainchain.chainId = block.chainid;\\n _receipt.ronin.addr = _request.recipientAddr;\\n _receipt.ronin.tokenAddr = _roninTokenAddr;\\n _receipt.ronin.chainId = _roninChainId;\\n _receipt.info = _request.info;\\n }\\n\\n /**\\n * @dev Converts the transfer request into the withdrawal receipt.\\n */\\n function into_withdrawal_receipt(\\n Request memory _request,\\n address _requester,\\n uint256 _id,\\n address _mainchainTokenAddr,\\n uint256 _mainchainId\\n ) internal view returns (Receipt memory _receipt) {\\n _receipt.id = _id;\\n _receipt.kind = Kind.Withdrawal;\\n _receipt.ronin.addr = _requester;\\n _receipt.ronin.tokenAddr = _request.tokenAddr;\\n _receipt.ronin.chainId = block.chainid;\\n _receipt.mainchain.addr = _request.recipientAddr;\\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\\n _receipt.mainchain.chainId = _mainchainId;\\n _receipt.info = _request.info;\\n }\\n\\n struct Receipt {\\n uint256 id;\\n Kind kind;\\n Token.Owner mainchain;\\n Token.Owner ronin;\\n Token.Info info;\\n }\\n\\n // keccak256(\\\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\\\");\\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\\n\\n /**\\n * @dev Returns token info struct hash.\\n */\\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\\n\\n /*\\n * return\\n * keccak256(\\n * abi.encode(\\n * TYPE_HASH,\\n * _receipt.id,\\n * _receipt.kind,\\n * Token.hash(_receipt.mainchain),\\n * Token.hash(_receipt.ronin),\\n * Token.hash(_receipt.info)\\n * )\\n * );\\n */\\n assembly {\\n let ptr := mload(0x40)\\n mstore(ptr, TYPE_HASH)\\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\\n mstore(add(ptr, 0x80), hashedReceiptRonin)\\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\\n digest := keccak256(ptr, 0xc0)\\n }\\n }\\n\\n /**\\n * @dev Returns the receipt digest.\\n */\\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\\n return _domainSeparator.toTypedDataHash(_receiptHash);\\n }\\n}\\n\",\"keccak256\":\"0xe73e11942bcae9034abc2058e9976a583e3518bdfeefa863e97cb6e51edf4522\",\"license\":\"MIT\"},\"contracts/ronin/gateway/RoninGatewayV3.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/access/AccessControlEnumerable.sol\\\";\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../extensions/GatewayV3.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../extensions/MinimumWithdrawal.sol\\\";\\nimport \\\"../../interfaces/IERC20Mintable.sol\\\";\\nimport \\\"../../interfaces/IERC721Mintable.sol\\\";\\nimport \\\"../../interfaces/bridge/IBridgeTracking.sol\\\";\\nimport \\\"../../interfaces/IRoninGatewayV3.sol\\\";\\nimport \\\"../../interfaces/IRoninTrustedOrganization.sol\\\";\\nimport \\\"../../interfaces/consumers/VoteStatusConsumer.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../libraries/IsolatedGovernance.sol\\\";\\nimport \\\"../../interfaces/bridge/IBridgeManager.sol\\\";\\n\\ncontract RoninGatewayV3 is\\n GatewayV3,\\n Initializable,\\n MinimumWithdrawal,\\n AccessControlEnumerable,\\n VoteStatusConsumer,\\n IRoninGatewayV3,\\n HasContracts\\n{\\n using Token for Token.Info;\\n using Transfer for Transfer.Request;\\n using Transfer for Transfer.Receipt;\\n using IsolatedGovernance for IsolatedGovernance.Vote;\\n\\n /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value)\\n bool private ___deprecated4;\\n /// @dev Total withdrawal\\n uint256 public withdrawalCount;\\n /// @dev Mapping from chain id => deposit id => deposit vote\\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\\n /// @dev Mapping from withdrawal id => withdrawal receipt\\n mapping(uint256 => Transfer.Receipt) public withdrawal;\\n /// @dev Mapping from withdrawal id => validator address => signatures\\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\\n /// @dev Mapping from token address => chain id => mainchain token address\\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\\n\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address private ____deprecated0;\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address private ____deprecated1;\\n\\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\\n\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address private ____deprecated2;\\n\\n uint256 internal _trustedNum;\\n uint256 internal _trustedDenom;\\n\\n fallback() external payable {\\n _fallback();\\n }\\n\\n receive() external payable {\\n _fallback();\\n }\\n\\n modifier onlyBridgeOperator() {\\n _requireBridgeOperator();\\n _;\\n }\\n\\n /**\\n * @dev Reverts if the method caller is not bridge operator.\\n */\\n function _requireBridgeOperator() internal view {\\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\\n }\\n\\n /**\\n * @dev Initializes contract storage.\\n */\\n function initialize(\\n address _roleSetter,\\n uint256 _numerator,\\n uint256 _denominator,\\n uint256 _trustedNumerator,\\n uint256 _trustedDenominator,\\n address[] calldata /* _withdrawalMigrators */,\\n // _packedAddresses[0]: roninTokens\\n // _packedAddresses[1]: mainchainTokens\\n address[][2] calldata _packedAddresses,\\n // _packedNumbers[0]: chainIds\\n // _packedNumbers[1]: minimumThresholds\\n uint256[][2] calldata _packedNumbers,\\n Token.Standard[] calldata _standards\\n ) external virtual initializer {\\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\\n _setThreshold(_numerator, _denominator);\\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\\n if (_packedAddresses[0].length > 0) {\\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\\n }\\n }\\n\\n function initializeV2() external reinitializer(2) {\\n _setContract(ContractType.VALIDATOR, ____deprecated0);\\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\\n delete ____deprecated0;\\n delete ____deprecated1;\\n delete ____deprecated2;\\n }\\n\\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function getWithdrawalSignatures(\\n uint256 withdrawalId,\\n address[] calldata operators\\n ) external view returns (bytes[] memory _signatures) {\\n _signatures = new bytes[](operators.length);\\n for (uint256 _i = 0; _i < operators.length; ) {\\n _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\\n address _sender = msg.sender;\\n _depositFor(_receipt, _sender, minimumVoteWeight());\\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\\n IBridgeTracking.VoteKind.Deposit,\\n _receipt.id,\\n _sender\\n );\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function tryBulkAcknowledgeMainchainWithdrew(\\n uint256[] calldata _withdrawalIds\\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\\n address _governor = msg.sender;\\n uint256 _minVoteWeight = minimumVoteWeight();\\n\\n uint256 _withdrawalId;\\n _executedReceipts = new bool[](_withdrawalIds.length);\\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\\n for (uint256 _i; _i < _withdrawalIds.length; ) {\\n _withdrawalId = _withdrawalIds[_i];\\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\\n if (mainchainWithdrew(_withdrawalId)) {\\n _executedReceipts[_i] = true;\\n } else {\\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\\n bytes32 _hash = _withdrawal.hash();\\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\\n if (_status == VoteStatus.Approved) {\\n _vote.status = VoteStatus.Executed;\\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\\n emit MainchainWithdrew(_hash, _withdrawal);\\n }\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function tryBulkDepositFor(\\n Transfer.Receipt[] calldata _receipts\\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\\n address _sender = msg.sender;\\n\\n Transfer.Receipt memory _receipt;\\n _executedReceipts = new bool[](_receipts.length);\\n uint256 _minVoteWeight = minimumVoteWeight();\\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\\n for (uint256 _i; _i < _receipts.length; ) {\\n _receipt = _receipts[_i];\\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\\n _executedReceipts[_i] = true;\\n } else {\\n _depositFor(_receipt, _sender, _minVoteWeight);\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\\n _requestWithdrawalFor(_request, msg.sender, _chainId);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\\n if (_requests.length == 0) revert ErrEmptyArray();\\n\\n for (uint256 _i; _i < _requests.length; ) {\\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\\n\\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\\n if (_receipt.ronin.chainId != block.chainid) {\\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\\n }\\n\\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function bulkSubmitWithdrawalSignatures(\\n uint256[] calldata withdrawals,\\n bytes[] calldata signatures\\n ) external whenNotPaused onlyBridgeOperator {\\n address operator = msg.sender;\\n\\n if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) {\\n revert ErrLengthMismatch(msg.sig);\\n }\\n\\n uint256 _minVoteWeight = minimumVoteWeight();\\n\\n uint256 id;\\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\\n for (uint256 _i; _i < withdrawals.length; ) {\\n id = withdrawals[_i];\\n _withdrawalSig[id][operator] = signatures[_i];\\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator);\\n\\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id];\\n VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id));\\n if (_status == VoteStatus.Approved) {\\n _proposal.status = VoteStatus.Executed;\\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id);\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function mapTokens(\\n address[] calldata _roninTokens,\\n address[] calldata _mainchainTokens,\\n uint256[] calldata _chainIds,\\n Token.Standard[] calldata _standards\\n ) external onlyAdmin {\\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\\n return depositVote[_chainId][_depositId].voted(_voter);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\\n }\\n\\n /**\\n * @inheritdoc IRoninGatewayV3\\n */\\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\\n _token = _mainchainToken[_roninToken][_chainId];\\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\\n }\\n\\n /**\\n * @dev Maps Ronin tokens to mainchain networks.\\n *\\n * Requirement:\\n * - The arrays have the same length.\\n *\\n * Emits the `TokenMapped` event.\\n *\\n */\\n function _mapTokens(\\n address[] calldata _roninTokens,\\n address[] calldata _mainchainTokens,\\n uint256[] calldata _chainIds,\\n Token.Standard[] calldata _standards\\n ) internal {\\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\\n revert ErrLengthMismatch(msg.sig);\\n\\n for (uint256 _i; _i < _roninTokens.length; ) {\\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\\n }\\n\\n /**\\n * @dev Deposits based on the receipt.\\n *\\n * Emits the `Deposited` once the assets are released.\\n *\\n */\\n function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal {\\n uint256 id = receipt.id;\\n receipt.info.validate();\\n if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\\n\\n if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid);\\n\\n MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId);\\n\\n if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr))\\n revert ErrInvalidReceipt();\\n\\n IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id];\\n bytes32 _receiptHash = receipt.hash();\\n VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash);\\n emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash);\\n if (_status == VoteStatus.Approved) {\\n _proposal.status = VoteStatus.Executed;\\n receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0)));\\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\\n IBridgeTracking.VoteKind.Deposit,\\n receipt.id\\n );\\n emit Deposited(_receiptHash, receipt);\\n }\\n }\\n\\n /**\\n * @dev Locks the assets and request withdrawal.\\n *\\n * Requirements:\\n * - The token info is valid.\\n *\\n * Emits the `WithdrawalRequested` event.\\n *\\n */\\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\\n _request.info.validate();\\n _checkWithdrawal(_request);\\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\\n\\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\\n }\\n\\n /**\\n * @dev Stores the withdrawal request as a receipt.\\n *\\n * Emits the `WithdrawalRequested` event.\\n *\\n */\\n function _storeAsReceipt(\\n Transfer.Request calldata _request,\\n uint256 _chainId,\\n address _requester,\\n address _mainchainTokenAddr\\n ) internal returns (uint256 _withdrawalId) {\\n _withdrawalId = withdrawalCount++;\\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\\n _requester,\\n _withdrawalId,\\n _mainchainTokenAddr,\\n _chainId\\n );\\n withdrawal[_withdrawalId] = _receipt;\\n emit WithdrawalRequested(_receipt.hash(), _receipt);\\n }\\n\\n /**\\n * @dev Don't send me RON.\\n */\\n function _fallback() internal virtual {\\n revert ErrInvalidRequest();\\n }\\n\\n /**\\n * @inheritdoc GatewayV3\\n */\\n function _getTotalWeight() internal view virtual override returns (uint256) {\\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\\n }\\n\\n /**\\n * @dev Casts and updates the vote result.\\n *\\n * Requirements:\\n * - The vote is not finalized.\\n * - The voter has not voted for the round.\\n *\\n */\\n function _castIsolatedVote(\\n IsolatedGovernance.Vote storage _v,\\n address _voter,\\n uint256 _minVoteWeight,\\n bytes32 _hash\\n ) internal virtual returns (VoteStatus _status) {\\n _v.castVote(_voter, _hash);\\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\\n }\\n\\n /**\\n * @dev Returns the vote weight for a specified hash.\\n */\\n function _getVoteWeight(\\n IsolatedGovernance.Vote storage _v,\\n bytes32 _hash\\n ) internal view returns (uint256 _totalWeight) {\\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\\n getContract(ContractType.BRIDGE_MANAGER)\\n ).getFullBridgeOperatorInfos();\\n uint256 length = bridgeOperators.length;\\n unchecked {\\n for (uint _i; _i < length; ++_i) {\\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\\n _totalWeight += weights[_i];\\n }\\n }\\n }\\n }\\n\\n function setTrustedThreshold(\\n uint256 _trustedNumerator,\\n uint256 _trustedDenominator\\n ) external virtual onlyAdmin returns (uint256, uint256) {\\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\\n }\\n\\n /**\\n * @dev Returns the threshold about trusted org.\\n */\\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\\n return (_trustedNum, _trustedDenom);\\n }\\n\\n /**\\n * @dev Sets trusted threshold and returns the old one.\\n *\\n * Emits the `TrustedThresholdUpdated` event.\\n *\\n */\\n function _setTrustedThreshold(\\n uint256 _trustedNumerator,\\n uint256 _trustedDenominator\\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\\n\\n _previousTrustedNum = _num;\\n _previousTrustedDenom = _denom;\\n _trustedNum = _trustedNumerator;\\n _trustedDenom = _trustedDenominator;\\n unchecked {\\n emit TrustedThresholdUpdated(\\n nonce++,\\n _trustedNumerator,\\n _trustedDenominator,\\n _previousTrustedNum,\\n _previousTrustedDenom\\n );\\n }\\n }\\n\\n /**\\n * @dev Returns minimum trusted vote weight.\\n */\\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\\n }\\n}\\n\",\"keccak256\":\"0xad743e1947dbbf5f258e86858d0a0a2722f0de3987fb2a89f0de6779124494df\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b506000805460ff19169055614d2b8061002a6000396000f3fe6080604052600436106102815760003560e01c8063835fc6ca1161014f578063c28f7894116100c1578063e75235b81161007a578063e75235b814610838578063ecc8364914610850578063f0ce418e1461087d578063f668214a146108c3578063fa389659146108e3578063fc6574bc1461090357610290565b8063c28f789414610752578063ca15c87314610798578063d547741f146107b8578063dafae408146107d8578063dbd2ef6c146107f8578063de981f1b1461081857610290565b80639584a592116101135780639584a5921461069a578063a217fddf146106ba578063affed0e0146106cf578063b9afa177146106e5578063b9c3620914610705578063bc7f03861461072557610290565b8063835fc6ca146105f45780638456cb5914610625578063865e6fd31461063a5780639010d07c1461065a57806391d148541461067a57610290565b80633e70838b116101f35780635cd8a76b116101ac5780635cd8a76b146105475780635d6a9a901461055c57806364363f781461058957806371706cbe146105a957806375535f86146105bf5780637de5dedd146105df57610290565b80633e70838b146104595780633f4ba83a1461047957806347b56b2c1461048e5780634d92c4f0146104ae5780635a7dd06a1461050f5780635c975abb1461052f57610290565b806317fa2ea11161024557806317fa2ea11461036e578063248a9ca31461039b5780632f2ff15d146103d95780633101cfcb146103f957806336568abe146104195780633e4574ec1461043957610290565b806301ffc9a714610298578063065b3adf146102cd5780630b1ff17f14610305578063109679ef1461032557806317892f961461034557610290565b366102905761028e610955565b005b61028e610955565b3480156102a457600080fd5b506102b86102b3366004613afa565b61096e565b60405190151581526020015b60405180910390f35b3480156102d957600080fd5b506005546102ed906001600160a01b031681565b6040516001600160a01b0390911681526020016102c4565b34801561031157600080fd5b5061028e610320366004613b24565b610999565b34801561033157600080fd5b5061028e610340366004613b55565b6109b0565b34801561035157600080fd5b506078546079545b604080519283526020830191909152016102c4565b34801561037a57600080fd5b5061038e610389366004613bb2565b610a55565b6040516102c49190613bf3565b3480156103a757600080fd5b506103cb6103b6366004613c39565b6000908152606b602052604090206001015490565b6040519081526020016102c4565b3480156103e557600080fd5b5061028e6103f4366004613c72565b610d92565b34801561040557600080fd5b5061028e610414366004613ca2565b610dbc565b34801561042557600080fd5b5061028e610434366004613c72565b610e68565b34801561044557600080fd5b506102b8610454366004613c72565b610ee2565b34801561046557600080fd5b5061028e610474366004613ca2565b610f12565b34801561048557600080fd5b5061028e610f3c565b34801561049a57600080fd5b5061028e6104a9366004613c39565b610f4e565b3480156104ba57600080fd5b506104ff6104c9366004613cbf565b606f602090815260009283526040808420909152908252902080546001820154600383015460049093015460ff90921692909184565b6040516102c49493929190613cf7565b34801561051b57600080fd5b5061028e61052a366004613d27565b611119565b34801561053b57600080fd5b5060005460ff166102b8565b34801561055357600080fd5b5061028e61117e565b34801561056857600080fd5b5061057c610577366004613da1565b611280565b6040516102c49190613ddd565b34801561059557600080fd5b5061028e6105a4366004613e09565b611324565b3480156105b557600080fd5b506103cb606e5481565b3480156105cb57600080fd5b506103596105da366004613cbf565b61135a565b3480156105eb57600080fd5b506103cb61137b565b34801561060057600080fd5b5061061461060f366004613c39565b611392565b6040516102c4959493929190613ebd565b34801561063157600080fd5b5061028e611464565b34801561064657600080fd5b5061028e610655366004613f0b565b611474565b34801561066657600080fd5b506102ed610675366004613cbf565b61148f565b34801561068657600080fd5b506102b8610695366004613c72565b6114a7565b3480156106a657600080fd5b5061028e6106b5366004613f48565b6114d2565b3480156106c657600080fd5b506103cb600081565b3480156106db57600080fd5b506103cb60045481565b3480156106f157600080fd5b5061038e610700366004614041565b611621565b34801561071157600080fd5b50610359610720366004613cbf565b6117b3565b34801561073157600080fd5b506103cb610740366004613ca2565b60386020526000908152604090205481565b34801561075e57600080fd5b506104ff61076d366004613c39565b607660205260009081526040902080546001820154600383015460049093015460ff90921692909184565b3480156107a457600080fd5b506103cb6107b3366004613c39565b6117c8565b3480156107c457600080fd5b5061028e6107d3366004613c72565b6117df565b3480156107e457600080fd5b506102b86107f3366004613c39565b611804565b34801561080457600080fd5b5061028e6108133660046140b6565b611830565b34801561082457600080fd5b506102ed610833366004614179565b611882565b34801561084457600080fd5b50600154600254610359565b34801561085c57600080fd5b5061087061086b366004614194565b6118fd565b6040516102c4919061422f565b34801561088957600080fd5b506104ff610898366004613c39565b607060205260009081526040902080546001820154600383015460049093015460ff90921692909184565b3480156108cf57600080fd5b506102b86108de366004613c39565b611a64565b3480156108ef57600080fd5b5061028e6108fe366004613e09565b611a92565b34801561090f57600080fd5b506102b861091e366004614291565b6000928352606f602090815260408085209385529281528284206001600160a01b0392909216845260029091019052902054151590565b60405163129c2ce160e31b815260040160405180910390fd5b60006001600160e01b03198216635a05180f60e01b1480610993575061099382611c8b565b92915050565b6109a1611cc0565b6109ac823383611d06565b5050565b6109b8611cc0565b6109c0611dde565b336109e16109d3368490038401846143d8565b826109dc61137b565b611e7f565b6109eb6003611882565b60405163c7c4fea960e01b81526001600160a01b03919091169063c7c4fea990610a1f906000908635908690600401614479565b600060405180830381600087803b158015610a3957600080fd5b505af1158015610a4d573d6000803e3d6000fd5b505050505050565b6060610a5f611dde565b336000610a6a61137b565b90506000846001600160401b03811115610a8657610a866142ca565b604051908082528060200260200182016040528015610aaf578160200160208202803683370190505b5093506000610abe6003611882565b905060005b86811015610d8757878782818110610add57610add6144a6565b905060200201359250816001600160a01b031663c7c4fea9600285886040518463ffffffff1660e01b8152600401610b1793929190614479565b600060405180830381600087803b158015610b3157600080fd5b505af1158015610b45573d6000803e3d6000fd5b50505050610b5283611a64565b15610b80576001868281518110610b6b57610b6b6144a6565b91151560209283029190910190910152610d7f565b600083815260706020908152604080832060718352818420825160a081019093528054835260018082015492959491929184019160ff1690811115610bc757610bc7613ce1565b6001811115610bd857610bd8613ce1565b8152604080516060808201835260028501546001600160a01b039081168352600386015481166020848101919091526004870154848601528086019390935283518083018552600587015482168152600687015490911692810192909252600785015482840152828401919091528151808201909252600884018054919093019290829060ff166001811115610c7057610c70613ce1565b6001811115610c8157610c81613ce1565b81526001820154602082015260029091015460409091015290525090506000610ca982612120565b90506000610cb9848a8a856121ea565b90506001816004811115610ccf57610ccf613ce1565b03610d7a57835460ff19166002908117855560405163114fc47560e11b81526001600160a01b0388169163229f88ea91610d0e91908b906004016144bc565b600060405180830381600087803b158015610d2857600080fd5b505af1158015610d3c573d6000803e3d6000fd5b505050507f62520d049932cdee872e9b3c59c0f6073637147e5e9bc8b050b062430eaf5c9f8284604051610d719291906144d7565b60405180910390a15b505050505b600101610ac3565b505050505092915050565b6000828152606b6020526040902060010154610dad8161221b565b610db78383612228565b505050565b603754600390610100900460ff16158015610dde575060375460ff8083169116105b610e035760405162461bcd60e51b8152600401610dfa90614538565b60405180910390fd5b6037805461ffff191660ff831617610100179055610e22600b8361224a565b6037805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b0381163314610ed85760405162461bcd60e51b815260206004820152602f60248201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560448201526e103937b632b9903337b91039b2b63360891b6064820152608401610dfa565b6109ac82826122ee565b60008281526070602090815260408083206001600160a01b038516845260020190915281205415155b9392505050565b610f1a612310565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b610f4461236a565b610f4c6123d9565b565b610f56611cc0565b610f5f81611a64565b15610f7d576040516327ddf84960e11b815260040160405180910390fd5b6000818152607160209081526040808320815160a0810190925280548252600180820154929391929184019160ff1690811115610fbc57610fbc613ce1565b6001811115610fcd57610fcd613ce1565b8152604080516060808201835260028501546001600160a01b039081168352600386015481166020848101919091526004870154848601528086019390935283518083018552600587015482168152600687015490911692810192909252600785015482840152828401919091528151808201909252600884018054919093019290829060ff16600181111561106557611065613ce1565b600181111561107657611076613ce1565b8152600182015460208201526002909101546040918201529152606083015101519192505046146110e0576060810151604090810151905163092048d160e11b81526001600160e01b03196000351660048201526024810191909152466044820152606401610dfa565b7f04e8cbd836dea43a2dc7eb19de345cca3a8e6978a2ef5225d924775500f67c7c61110a82612120565b82604051610e5c9291906144d7565b611121611cc0565b6000829003611143576040516316ee9d3b60e11b815260040160405180910390fd5b60005b8281101561117857611170848483818110611163576111636144a6565b905060a002013384611d06565b600101611146565b50505050565b603754600290610100900460ff161580156111a0575060375460ff8083169116105b6111bc5760405162461bcd60e51b8152600401610dfa90614538565b6037805461ffff191660ff8316176101001790556074546111e8906008906001600160a01b031661224a565b607554611200906003906001600160a01b031661224a565b60775461121890600a906001600160a01b031661224a565b607480546001600160a01b031990811690915560758054821690556077805490911690556037805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b604080518082018252600080825260208083018290526001600160a01b038616825260738152838220858352905282902082518084019093528054919291829060ff1660018111156112d4576112d4613ce1565b60018111156112e5576112e5613ce1565b815290546001600160a01b036101009091048116602092830152908201519192501661099357604051631b79f53b60e21b815260040160405180910390fd5b61132c612310565b600083900361134e576040516316ee9d3b60e11b815260040160405180910390fd5b6111788484848461242b565b600080611365612310565b61136f848461250e565b915091505b9250929050565b600061138d611388612599565b612606565b905090565b607160209081526000918252604091829020805460018083015485516060808201885260028601546001600160a01b03908116835260038701548116838901526004870154838a015288518083018a526005880154821681526006880154909116978101979097526007860154878901528751908101909752600885018054949760ff93841697929692959294909391928492169081111561143657611436613ce1565b600181111561144757611447613ce1565b815260200160018201548152602001600282015481525050905085565b61146c61236a565b610f4c61263c565b61147c612310565b61148581612679565b6109ac828261224a565b6000828152606c60205260408120610f0b90836126af565b6000918252606b602090815260408084206001600160a01b0393909316845291905290205460ff1690565b603754610100900460ff16158080156114f25750603754600160ff909116105b8061150c5750303b15801561150c575060375460ff166001145b6115285760405162461bcd60e51b8152600401610dfa90614538565b6037805460ff19166001179055801561154b576037805461ff0019166101001790555b61155660008d6126bb565b6115608b8b6126c5565b505061156c898961250e565b506000905061157b8680614586565b905011156115cd576115ae6115908680614586565b61159d6020890189614586565b6115a78980614586565b8989612751565b6115cd6115bb8680614586565b6115c86020880188614586565b61242b565b8015611613576037805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b505050505050505050505050565b606061162b611cc0565b611633611dde565b3361163c613a8d565b836001600160401b03811115611654576116546142ca565b60405190808252806020026020018201604052801561167d578160200160208202803683370190505b509250600061168a61137b565b905060006116986003611882565b905060005b86811015610d87578787828181106116b7576116b76144a6565b905061016002018036038101906116ce91906143d8565b805160405163c7c4fea960e01b81529195506001600160a01b0384169163c7c4fea99161170391600091908a90600401614479565b600060405180830381600087803b15801561171d57600080fd5b505af1158015611731573d6000803e3d6000fd5b506002925061173e915050565b6040808601518101516000908152606f6020908152828220885183529052205460ff16600481111561177257611772613ce1565b036117a057600186828151811061178b5761178b6144a6565b911515602092830291909101909101526117ab565b6117ab848685611e7f565b60010161169d565b6000806117be612310565b61136f84846126c5565b6000818152606c602052604081206109939061295a565b6000828152606b60205260409020600101546117fa8161221b565b610db783836122ee565b600061180e612599565b60015461181b91906145e5565b60025461182890846145e5565b101592915050565b611838612310565b6000879003611868576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b6118788888888888888888612751565b5050505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156118b9576118b9613ce1565b60ff1681526020810191909152604001600020546001600160a01b03169050806118f8578160405163409140df60e11b8152600401610dfa9190614611565b919050565b6060816001600160401b03811115611917576119176142ca565b60405190808252806020026020018201604052801561194a57816020015b60608152602001906001900390816119355790505b50905060005b82811015611a5c57600085815260726020526040812090858584818110611979576119796144a6565b905060200201602081019061198e9190613ca2565b6001600160a01b03166001600160a01b0316815260200190815260200160002080546119b99061462b565b80601f01602080910402602001604051908101604052809291908181526020018280546119e59061462b565b8015611a325780601f10611a0757610100808354040283529160200191611a32565b820191906000526020600020905b815481529060010190602001808311611a1557829003601f168201915b5050505050828281518110611a4957611a496144a6565b6020908102919091010152600101611950565b509392505050565b6000600260008381526070602052604090205460ff166004811115611a8b57611a8b613ce1565b1492915050565b611a9a611cc0565b611aa2611dde565b338315801590611ab157508382145b611adc576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b6000611ae661137b565b9050600080611af56003611882565b905060005b87811015611c8057888882818110611b1457611b146144a6565b905060200201359250868682818110611b2f57611b2f6144a6565b9050602002810190611b41919061465f565b60008581526072602090815260408083206001600160a01b038b168452909152902091611b6f9190836146eb565b5060405163c7c4fea960e01b81526001600160a01b0383169063c7c4fea990611ba19060019087908a90600401614479565b600060405180830381600087803b158015611bbb57600080fd5b505af1158015611bcf573d6000803e3d6000fd5b50505060008481526076602052604081209150611bee828888886121ea565b90506001816004811115611c0457611c04613ce1565b03611c7657815460ff1916600217825560405163114fc47560e11b81526001600160a01b0385169063229f88ea90611c439060019089906004016144bc565b600060405180830381600087803b158015611c5d57600080fd5b505af1158015611c71573d6000803e3d6000fd5b505050505b5050600101611afa565b505050505050505050565b60006001600160e01b03198216637965db0b60e01b148061099357506301ffc9a760e01b6001600160e01b0319831614610993565b60005460ff1615610f4c5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610dfa565b611d20611d1b368590038501604086016147aa565b612964565b611d29836129df565b6000611d44611d3e6040860160208701613ca2565b83611280565b80519091506001811115611d5a57611d5a613ce1565b611d6a60608601604087016147c6565b6001811115611d7b57611d7b613ce1565b14611d985760405162035e2b60ea1b815260040160405180910390fd5b611dc78330611dad6040880160208901613ca2565b611dbf36899003890160408a016147aa565b929190612a5d565b611dd78483858460200151612c5c565b5050505050565b611de8600b611882565b604051635a02d57960e11b81523360048201526001600160a01b03919091169063b405aaf290602401602060405180830381865afa158015611e2e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e5291906147e3565b610f4c576000356001600160e01b0319166006604051620f948f60ea1b8152600401610dfa929190614805565b82516080840151611e8f90612964565b600084602001516001811115611ea757611ea7613ce1565b14611ec55760405163182f3d8760e11b815260040160405180910390fd5b4684606001516040015114611f13576060840151604090810151905163092048d160e11b81526001600160e01b03196000351660048201526024810191909152466044820152606401610dfa565b6000611f2f856060015160200151866040015160400151611280565b6080860151519091506001811115611f4957611f49613ce1565b81516001811115611f5c57611f5c613ce1565b148015611f8657508460400151602001516001600160a01b031681602001516001600160a01b0316145b611fa35760405163f4b8742f60e01b815260040160405180910390fd5b6040808601518101516000908152606f6020908152828220858352905290812090611fcd87612120565b90506000611fdd838888856121ea565b905087604001516040015185886001600160a01b03167f48c4262ed68beb92fe5d7d48d70772e49cd50c317937dea60a99f15f794b64598560405161202491815260200190565b60405180910390a4600181600481111561204057612040613ce1565b0361187857825460ff191660021783556060880151805160209091015160808a015161206f9290916000612de6565b6120796003611882565b885160405163114fc47560e11b81526001600160a01b03929092169163229f88ea916120ab91600091906004016144bc565b600060405180830381600087803b1580156120c557600080fd5b505af11580156120d9573d6000803e3d6000fd5b505050507f8d20d8121a34dded9035ff5b43e901c142824f7a22126392992c353c37890524828960405161210e9291906144d7565b60405180910390a15050505050505050565b6000806121308360400151613102565b905060006121418460600151613102565b905060006121958560800151604080517f1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d815282516020808301919091528301518183015291015160608201526080902090565b604080517fb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea815287516020808301919091529097015190870152606086019390935250608084015260a08301525060c0902090565b60006121f785858461314a565b60006122038684613200565b90506122118685838661330e565b9695505050505050565b612225813361335a565b50565b61223282826133be565b6000828152606c60205260409020610db79082613444565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561228057612280613ce1565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156122c1576122c1613ce1565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6122f88282613459565b6000828152606c60205260409020610db790826134c0565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610f4c576000356001600160e01b0319166001604051620f948f60ea1b8152600401610dfa929190614805565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314806123ac57506005546001600160a01b031633145b610f4c576000356001600160e01b0319166001604051620f948f60ea1b8152600401610dfa929190614805565b6123e16134d5565b6000805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b828114612459576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b60005b838110156124ca57828282818110612476576124766144a6565b9050602002013560386000878785818110612493576124936144a6565b90506020020160208101906124a89190613ca2565b6001600160a01b0316815260208101919091526040016000205560010161245c565b507f6f52f53a938df83439fa4c6055c7df0a6906d621aa6dfa4708187037fdfc41da8484848460405161250094939291906148a1565b60405180910390a150505050565b600080828411156125325760405163964a4d2760e01b815260040160405180910390fd5b505060018054600254607885905560798490556004805493840190556040805183815260208101839052929391928592879290917feac82d4d949d2d4f77f96aa68ab6b1bb750da73f14e55d41a1b93f387471ecba91015b60405180910390a49250929050565b60006125a5600b611882565b6001600160a01b03166306aba0e16040518163ffffffff1660e01b8152600401602060405180830381865afa1580156125e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061138d91906148d3565b600060025460016002548460015461261e91906145e5565b61262891906148ec565b61263291906148ff565b6109939190614912565b612644611cc0565b6000805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25861240e3390565b806001600160a01b03163b60000361222557604051630bfc64a360e21b81526001600160a01b0382166004820152602401610dfa565b6000610f0b838361351e565b6109ac8282612228565b600080828411156126f7576000356001600160e01b0319166040516387f6f09560e01b8152600401610dfa91906145fc565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910161258a565b868514801561275f57508683145b61278a576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b60005b8781101561291c578686828181106127a7576127a76144a6565b90506020020160208101906127bc9190613ca2565b607360008b8b858181106127d2576127d26144a6565b90506020020160208101906127e79190613ca2565b6001600160a01b03166001600160a01b03168152602001908152602001600020600087878581811061281b5761281b6144a6565b90506020020135815260200190815260200160002060000160016101000a8154816001600160a01b0302191690836001600160a01b03160217905550828282818110612869576128696144a6565b905060200201602081019061287e91906147c6565b607360008b8b85818110612894576128946144a6565b90506020020160208101906128a99190613ca2565b6001600160a01b03166001600160a01b0316815260200190815260200160002060008787858181106128dd576128dd6144a6565b60209081029290920135835250810191909152604001600020805460ff19166001838181111561290f5761290f613ce1565b021790555060010161278d565b507f2544bff60c6d5b84946e06804af9f84e150bbee85238dbdee79efca4e0adf401888888888888888860405161210e989796959493929190614934565b6000610993825490565b60008151600181111561297957612979613ce1565b14801561298a575060008160400151115b801561299857506020810151155b806129c257506001815160018111156129b3576129b3613ce1565b1480156129c257506040810151155b6122255760405163034992a760e51b815260040160405180910390fd5b60006129f160608301604084016147c6565b6001811115612a0257612a02613ce1565b148015612a3f575060386000612a1e6040840160208501613ca2565b6001600160a01b031681526020810191909152604001600020546080820135105b1561222557604051636eff4a8560e11b815260040160405180910390fd5b600060608186516001811115612a7557612a75613ce1565b03612b525760408681015181516001600160a01b038881166024830152878116604483015260648083019390935283518083039093018352608490910183526020820180516001600160e01b03166323b872dd60e01b179052915191851691612ade91906149c3565b6000604051808303816000865af19150503d8060008114612b1b576040519150601f19603f3d011682016040523d82523d6000602084013e612b20565b606091505b509092509050818015612b4b575080511580612b4b575080806020019051810190612b4b91906147e3565b9150612c36565b600186516001811115612b6757612b67613ce1565b03612c1d57602086810151604080516001600160a01b0389811660248301528881166044830152606480830194909452825180830390940184526084909101825292820180516001600160e01b03166323b872dd60e01b1790525191851691612bd091906149c3565b6000604051808303816000865af19150503d8060008114612c0d576040519150601f19603f3d011682016040523d82523d6000602084013e612c12565b606091505b505080925050612c36565b6040516361e411a760e11b815260040160405180910390fd5b81610a4d5785858585604051639d2e4c6760e01b8152600401610dfa94939291906149df565b606e805460009182612c6d83614a15565b9091555090506000612c9484838588612c8b368c90038c018c614a2e565b93929190613548565b60008381526071602090815260409091208251815590820151600180830180549495508594909160ff19909116908381811115612cd357612cd3613ce1565b021790555060408281015180516002840180546001600160a01b039283166001600160a01b03199182161790915560208084015160038701805491851691841691909117905592840151600486015560608601518051600587018054918516918416919091179055928301516006860180549190931691161790550151600782015560808201518051600883018054909190829060ff191660018381811115612d7e57612d7e613ce1565b0217905550602082015181600101556040820151816002015550509050507ff313c253a5be72c29d0deb2c8768a9543744ac03d6b3cafd50cc976f1c2632fc612dc682612120565b82604051612dd59291906144d7565b60405180910390a150949350505050565b6000816001600160a01b0316836001600160a01b031603612e955760408086015190516001600160a01b0386169180156108fc02916000818181858888f19350505050612e9057816001600160a01b031663d0e30db086604001516040518263ffffffff1660e01b81526004016000604051808303818588803b158015612e6c57600080fd5b505af1158015612e80573d6000803e3d6000fd5b5050505050612e908585856135b4565b611dd7565b600085516001811115612eaa57612eaa613ce1565b03613013576040516370a0823160e01b81523060048201526000906001600160a01b038516906370a0823190602401602060405180830381865afa158015612ef6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612f1a91906148d3565b9050856040015181101561300257836001600160a01b03166340c10f1930838960400151612f4891906148ff565b6040516001600160a01b03909216602483015260448201526064016040516020818303038152906040529060e01b6020820180516001600160e01b038381831617835250505050604051612f9c91906149c3565b6000604051808303816000865af19150503d8060008114612fd9576040519150601f19603f3d011682016040523d82523d6000602084013e612fde565b606091505b5050809250508161300257604051632f739fff60e11b815260040160405180910390fd5b61300d8686866135b4565b50611dd7565b60018551600181111561302857613028613ce1565b03612c1d5761303c83858760200151613632565b612e9057602085810151604080516001600160a01b038881166024830152604480830194909452825180830390940184526064909101825292820180516001600160e01b03166340c10f1960e01b179052519185169161309c91906149c3565b6000604051808303816000865af19150503d80600081146130d9576040519150601f19603f3d011682016040523d82523d6000602084013e6130de565b606091505b50508091505080612e905760405163c8e3a09f60e01b815260040160405180910390fd5b604080517f353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764815282516020808301919091528301518183015291015160608201526080902090565b60008360030154118015613162575042836003015411155b1561317357825460ff191660041783555b6001600160a01b0382166000908152600284016020526040902054156131b75760405163025fd59560e41b81526001600160a01b0383166004820152602401610dfa565b6001600160a01b039091166000818152600284016020908152604082209390935560059093018054600181018255908452919092200180546001600160a01b0319169091179055565b600080600061320f600b611882565b6001600160a01b031663c441c4a86040518163ffffffff1660e01b8152600401600060405180830381865afa15801561324c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526132749190810190614b18565b81519194509250905060005b8181101561330457858760020160008684815181106132a1576132a16144a6565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002054036132fc578281815181106132e1576132e16144a6565b60200260200101516bffffffffffffffffffffffff16850194505b600101613280565b5050505092915050565b600083831015801561333557506000855460ff16600481111561333357613333613ce1565b145b1561334d57845460ff19166001908117865585018290555b5050915460ff1692915050565b61336482826114a7565b6109ac5761337c816001600160a01b031660146136dd565b6133878360206136dd565b604051602001613398929190614c10565b60408051601f198184030181529082905262461bcd60e51b8252610dfa91600401614c85565b6133c882826114a7565b6109ac576000828152606b602090815260408083206001600160a01b03851684529091529020805460ff191660011790556134003390565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b6000610f0b836001600160a01b038416613878565b61346382826114a7565b156109ac576000828152606b602090815260408083206001600160a01b0385168085529252808320805460ff1916905551339285917ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b9190a45050565b6000610f0b836001600160a01b0384166138c7565b60005460ff16610f4c5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610dfa565b6000826000018281548110613535576135356144a6565b9060005260206000200154905092915050565b613550613a8d565b92835260016020808501919091526060840180516001600160a01b0396871690528682015181519087169083015251466040918201528651818601805191881690915280519490961693909101929092529251810192909252910151608082015290565b600080845160018111156135ca576135ca613ce1565b036135e5576135de828486604001516139ba565b905061360e565b6001845160018111156135fa576135fa613ce1565b03612c1d576135de82848660200151613632565b80611178578383836040516341bd7d9160e11b8152600401610dfa93929190614c98565b604080513060248201526001600160a01b038481166044830152606480830185905283518084039091018152608490920183526020820180516001600160e01b03166323b872dd60e01b1790529151600092861691613690916149c3565b6000604051808303816000865af19150503d80600081146136cd576040519150601f19603f3d011682016040523d82523d6000602084013e6136d2565b606091505b509095945050505050565b606060006136ec8360026145e5565b6136f79060026148ec565b6001600160401b0381111561370e5761370e6142ca565b6040519080825280601f01601f191660200182016040528015613738576020820181803683370190505b509050600360fc1b81600081518110613753576137536144a6565b60200101906001600160f81b031916908160001a905350600f60fb1b81600181518110613782576137826144a6565b60200101906001600160f81b031916908160001a90535060006137a68460026145e5565b6137b19060016148ec565b90505b6001811115613829576f181899199a1a9b1b9c1cb0b131b232b360811b85600f16601081106137e5576137e56144a6565b1a60f81b8282815181106137fb576137fb6144a6565b60200101906001600160f81b031916908160001a90535060049490941c9361382281614cc8565b90506137b4565b508315610f0b5760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610dfa565b60008181526001830160205260408120546138bf57508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610993565b506000610993565b600081815260018301602052604081205480156139b05760006138eb6001836148ff565b85549091506000906138ff906001906148ff565b905081811461396457600086600001828154811061391f5761391f6144a6565b9060005260206000200154905080876000018481548110613942576139426144a6565b6000918252602080832090910192909255918252600188019052604090208390555b855486908061397557613975614cdf565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610993565b6000915050610993565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663a9059cbb60e01b179052915160009260609290871691613a1791906149c3565b6000604051808303816000865af19150503d8060008114613a54576040519150601f19603f3d011682016040523d82523d6000602084013e613a59565b606091505b509092509050818015613a84575080511580613a84575080806020019051810190613a8491906147e3565b95945050505050565b6040805160a08101825260008082526020808301829052835160608082018652838252818301849052818601849052848601919091528451808201865283815280830184905280860184905281850152845190810185528281529081018290529283015290608082015290565b600060208284031215613b0c57600080fd5b81356001600160e01b031981168114610f0b57600080fd5b60008082840360c0811215613b3857600080fd5b60a0811215613b4657600080fd5b50919360a08501359350915050565b60006101608284031215613b6857600080fd5b50919050565b60008083601f840112613b8057600080fd5b5081356001600160401b03811115613b9757600080fd5b6020830191508360208260051b850101111561137457600080fd5b60008060208385031215613bc557600080fd5b82356001600160401b03811115613bdb57600080fd5b613be785828601613b6e565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b81811015613c2d578351151583529284019291840191600101613c0f565b50909695505050505050565b600060208284031215613c4b57600080fd5b5035919050565b6001600160a01b038116811461222557600080fd5b80356118f881613c52565b60008060408385031215613c8557600080fd5b823591506020830135613c9781613c52565b809150509250929050565b600060208284031215613cb457600080fd5b8135610f0b81613c52565b60008060408385031215613cd257600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b6080810160058610613d0b57613d0b613ce1565b9481526020810193909352604083019190915260609091015290565b600080600060408486031215613d3c57600080fd5b83356001600160401b0380821115613d5357600080fd5b818601915086601f830112613d6757600080fd5b813581811115613d7657600080fd5b87602060a083028501011115613d8b57600080fd5b6020928301989097509590910135949350505050565b60008060408385031215613db457600080fd5b8235613dbf81613c52565b946020939093013593505050565b6002811061222557612225613ce1565b81516040820190613ded81613dcd565b82526020928301516001600160a01b0316929091019190915290565b60008060008060408587031215613e1f57600080fd5b84356001600160401b0380821115613e3657600080fd5b613e4288838901613b6e565b90965094506020870135915080821115613e5b57600080fd5b50613e6887828801613b6e565b95989497509550505050565b80516001600160a01b03908116835260208083015190911690830152604090810151910152565b8051613ea681613dcd565b825260208181015190830152604090810151910152565b8581526101608101613ece86613dcd565b856020830152613ee16040830186613e74565b613eee60a0830185613e74565b612211610100830184613e9b565b8035601081106118f857600080fd5b60008060408385031215613f1e57600080fd5b613f2783613efc565b91506020830135613c9781613c52565b806040810183101561099357600080fd5b60008060008060008060008060008060006101208c8e031215613f6a57600080fd5b613f738c613c67565b9a5060208c0135995060408c0135985060608c0135975060808c013596506001600160401b038060a08e01351115613faa57600080fd5b613fba8e60a08f01358f01613b6e565b909750955060c08d0135811015613fd057600080fd5b613fe08e60c08f01358f01613f37565b94508060e08e01351115613ff357600080fd5b6140038e60e08f01358f01613f37565b9350806101008e0135111561401757600080fd5b506140298d6101008e01358e01613b6e565b81935080925050509295989b509295989b9093969950565b6000806020838503121561405457600080fd5b82356001600160401b038082111561406b57600080fd5b818501915085601f83011261407f57600080fd5b81358181111561408e57600080fd5b866020610160830285010111156140a457600080fd5b60209290920196919550909350505050565b6000806000806000806000806080898b0312156140d257600080fd5b88356001600160401b03808211156140e957600080fd5b6140f58c838d01613b6e565b909a50985060208b013591508082111561410e57600080fd5b61411a8c838d01613b6e565b909850965060408b013591508082111561413357600080fd5b61413f8c838d01613b6e565b909650945060608b013591508082111561415857600080fd5b506141658b828c01613b6e565b999c989b5096995094979396929594505050565b60006020828403121561418b57600080fd5b610f0b82613efc565b6000806000604084860312156141a957600080fd5b8335925060208401356001600160401b038111156141c657600080fd5b6141d286828701613b6e565b9497909650939450505050565b60005b838110156141fa5781810151838201526020016141e2565b50506000910152565b6000815180845261421b8160208601602086016141df565b601f01601f19169290920160200192915050565b6000602080830181845280855180835260408601915060408160051b870101925083870160005b8281101561428457603f19888603018452614272858351614203565b94509285019290850190600101614256565b5092979650505050505050565b6000806000606084860312156142a657600080fd5b833592506020840135915060408401356142bf81613c52565b809150509250925092565b634e487b7160e01b600052604160045260246000fd5b604051606081016001600160401b0381118282101715614302576143026142ca565b60405290565b604051601f8201601f191681016001600160401b0381118282101715614330576143306142ca565b604052919050565b6002811061222557600080fd5b60006060828403121561435757600080fd5b61435f6142e0565b9050813561436c81613c52565b8152602082013561437c81613c52565b806020830152506040820135604082015292915050565b6000606082840312156143a557600080fd5b6143ad6142e0565b905081356143ba81614338565b80825250602082013560208201526040820135604082015292915050565b600061016082840312156143eb57600080fd5b60405160a081018181106001600160401b038211171561440d5761440d6142ca565b60405282358152602083013561442281614338565b60208201526144348460408501614345565b60408201526144468460a08501614345565b6060820152614459846101008501614393565b60808201529392505050565b6003811061447557614475613ce1565b9052565b606081016144878286614465565b60208201939093526001600160a01b0391909116604090910152919050565b634e487b7160e01b600052603260045260246000fd5b604081016144ca8285614465565b8260208301529392505050565b6000610180820190508382528251602083015260208301516144f881613dcd565b8060408401525060408301516145116060840182613e74565b50606083015161452460c0840182613e74565b506080830151611a5c610120840182613e9b565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b6000808335601e1984360301811261459d57600080fd5b8301803591506001600160401b038211156145b757600080fd5b6020019150600581901b360382131561137457600080fd5b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417610993576109936145cf565b6001600160e01b031991909116815260200190565b602081016010831061462557614625613ce1565b91905290565b600181811c9082168061463f57607f821691505b602082108103613b6857634e487b7160e01b600052602260045260246000fd5b6000808335601e1984360301811261467657600080fd5b8301803591506001600160401b0382111561469057600080fd5b60200191503681900382131561137457600080fd5b601f821115610db757600081815260208120601f850160051c810160208610156146cc5750805b601f850160051c820191505b81811015610a4d578281556001016146d8565b6001600160401b03831115614702576147026142ca565b61471683614710835461462b565b836146a5565b6000601f84116001811461474a57600085156147325750838201355b600019600387901b1c1916600186901b178355611dd7565b600083815260209020601f19861690835b8281101561477b578685013582556020948501946001909201910161475b565b50868210156147985760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b6000606082840312156147bc57600080fd5b610f0b8383614393565b6000602082840312156147d857600080fd5b8135610f0b81614338565b6000602082840312156147f557600080fd5b81518015158114610f0b57600080fd5b6001600160e01b03198316815260408101600b83106144ca576144ca613ce1565b8183526000602080850194508260005b8581101561486457813561484981613c52565b6001600160a01b031687529582019590820190600101614836565b509495945050505050565b81835260006001600160fb1b0383111561488857600080fd5b8260051b80836020870137939093016020019392505050565b6040815260006148b5604083018688614826565b82810360208401526148c881858761486f565b979650505050505050565b6000602082840312156148e557600080fd5b5051919050565b80820180821115610993576109936145cf565b81810381811115610993576109936145cf565b60008261492f57634e487b7160e01b600052601260045260246000fd5b500490565b608081526000614948608083018a8c614826565b60208382038185015261495c828a8c614826565b9150838203604085015261497182888a61486f565b8481036060860152858152869250810160005b868110156149b257833561499781614338565b6149a081613dcd565b82529282019290820190600101614984565b509c9b505050505050505050505050565b600082516149d58184602087016141df565b9190910192915050565b60c081016149ed8287613e9b565b6001600160a01b0394851660608301529284166080820152921660a090920191909152919050565b600060018201614a2757614a276145cf565b5060010190565b600060a08284031215614a4057600080fd5b614a486142e0565b8235614a5381613c52565b81526020830135614a6381613c52565b6020820152614a758460408501614393565b60408201529392505050565b60006001600160401b03821115614a9a57614a9a6142ca565b5060051b60200190565b600082601f830112614ab557600080fd5b81516020614aca614ac583614a81565b614308565b82815260059290921b84018101918181019086841115614ae957600080fd5b8286015b84811015614b0d578051614b0081613c52565b8352918301918301614aed565b509695505050505050565b600080600060608486031215614b2d57600080fd5b83516001600160401b0380821115614b4457600080fd5b614b5087838801614aa4565b9450602091508186015181811115614b6757600080fd5b614b7388828901614aa4565b945050604086015181811115614b8857600080fd5b86019050601f81018713614b9b57600080fd5b8051614ba9614ac582614a81565b81815260059190911b82018301908381019089831115614bc857600080fd5b928401925b82841015614c015783516bffffffffffffffffffffffff81168114614bf25760008081fd5b82529284019290840190614bcd565b80955050505050509250925092565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000815260008351614c488160178501602088016141df565b7001034b99036b4b9b9b4b733903937b6329607d1b6017918401918201528351614c798160288401602088016141df565b01602801949350505050565b602081526000610f0b6020830184614203565b60a08101614ca68286613e9b565b6001600160a01b03938416606083015291909216608090920191909152919050565b600081614cd757614cd76145cf565b506000190190565b634e487b7160e01b600052603160045260246000fdfea2646970667358221220ec5e4d67a54601fd535977c8db3ac6acad4decf9c225f2e4583ebaf312358ccc64736f6c63430008110033", + "deployedBytecode": "0x6080604052600436106102815760003560e01c8063835fc6ca1161014f578063c28f7894116100c1578063e75235b81161007a578063e75235b814610838578063ecc8364914610850578063f0ce418e1461087d578063f668214a146108c3578063fa389659146108e3578063fc6574bc1461090357610290565b8063c28f789414610752578063ca15c87314610798578063d547741f146107b8578063dafae408146107d8578063dbd2ef6c146107f8578063de981f1b1461081857610290565b80639584a592116101135780639584a5921461069a578063a217fddf146106ba578063affed0e0146106cf578063b9afa177146106e5578063b9c3620914610705578063bc7f03861461072557610290565b8063835fc6ca146105f45780638456cb5914610625578063865e6fd31461063a5780639010d07c1461065a57806391d148541461067a57610290565b80633e70838b116101f35780635cd8a76b116101ac5780635cd8a76b146105475780635d6a9a901461055c57806364363f781461058957806371706cbe146105a957806375535f86146105bf5780637de5dedd146105df57610290565b80633e70838b146104595780633f4ba83a1461047957806347b56b2c1461048e5780634d92c4f0146104ae5780635a7dd06a1461050f5780635c975abb1461052f57610290565b806317fa2ea11161024557806317fa2ea11461036e578063248a9ca31461039b5780632f2ff15d146103d95780633101cfcb146103f957806336568abe146104195780633e4574ec1461043957610290565b806301ffc9a714610298578063065b3adf146102cd5780630b1ff17f14610305578063109679ef1461032557806317892f961461034557610290565b366102905761028e610955565b005b61028e610955565b3480156102a457600080fd5b506102b86102b3366004613afa565b61096e565b60405190151581526020015b60405180910390f35b3480156102d957600080fd5b506005546102ed906001600160a01b031681565b6040516001600160a01b0390911681526020016102c4565b34801561031157600080fd5b5061028e610320366004613b24565b610999565b34801561033157600080fd5b5061028e610340366004613b55565b6109b0565b34801561035157600080fd5b506078546079545b604080519283526020830191909152016102c4565b34801561037a57600080fd5b5061038e610389366004613bb2565b610a55565b6040516102c49190613bf3565b3480156103a757600080fd5b506103cb6103b6366004613c39565b6000908152606b602052604090206001015490565b6040519081526020016102c4565b3480156103e557600080fd5b5061028e6103f4366004613c72565b610d92565b34801561040557600080fd5b5061028e610414366004613ca2565b610dbc565b34801561042557600080fd5b5061028e610434366004613c72565b610e68565b34801561044557600080fd5b506102b8610454366004613c72565b610ee2565b34801561046557600080fd5b5061028e610474366004613ca2565b610f12565b34801561048557600080fd5b5061028e610f3c565b34801561049a57600080fd5b5061028e6104a9366004613c39565b610f4e565b3480156104ba57600080fd5b506104ff6104c9366004613cbf565b606f602090815260009283526040808420909152908252902080546001820154600383015460049093015460ff90921692909184565b6040516102c49493929190613cf7565b34801561051b57600080fd5b5061028e61052a366004613d27565b611119565b34801561053b57600080fd5b5060005460ff166102b8565b34801561055357600080fd5b5061028e61117e565b34801561056857600080fd5b5061057c610577366004613da1565b611280565b6040516102c49190613ddd565b34801561059557600080fd5b5061028e6105a4366004613e09565b611324565b3480156105b557600080fd5b506103cb606e5481565b3480156105cb57600080fd5b506103596105da366004613cbf565b61135a565b3480156105eb57600080fd5b506103cb61137b565b34801561060057600080fd5b5061061461060f366004613c39565b611392565b6040516102c4959493929190613ebd565b34801561063157600080fd5b5061028e611464565b34801561064657600080fd5b5061028e610655366004613f0b565b611474565b34801561066657600080fd5b506102ed610675366004613cbf565b61148f565b34801561068657600080fd5b506102b8610695366004613c72565b6114a7565b3480156106a657600080fd5b5061028e6106b5366004613f48565b6114d2565b3480156106c657600080fd5b506103cb600081565b3480156106db57600080fd5b506103cb60045481565b3480156106f157600080fd5b5061038e610700366004614041565b611621565b34801561071157600080fd5b50610359610720366004613cbf565b6117b3565b34801561073157600080fd5b506103cb610740366004613ca2565b60386020526000908152604090205481565b34801561075e57600080fd5b506104ff61076d366004613c39565b607660205260009081526040902080546001820154600383015460049093015460ff90921692909184565b3480156107a457600080fd5b506103cb6107b3366004613c39565b6117c8565b3480156107c457600080fd5b5061028e6107d3366004613c72565b6117df565b3480156107e457600080fd5b506102b86107f3366004613c39565b611804565b34801561080457600080fd5b5061028e6108133660046140b6565b611830565b34801561082457600080fd5b506102ed610833366004614179565b611882565b34801561084457600080fd5b50600154600254610359565b34801561085c57600080fd5b5061087061086b366004614194565b6118fd565b6040516102c4919061422f565b34801561088957600080fd5b506104ff610898366004613c39565b607060205260009081526040902080546001820154600383015460049093015460ff90921692909184565b3480156108cf57600080fd5b506102b86108de366004613c39565b611a64565b3480156108ef57600080fd5b5061028e6108fe366004613e09565b611a92565b34801561090f57600080fd5b506102b861091e366004614291565b6000928352606f602090815260408085209385529281528284206001600160a01b0392909216845260029091019052902054151590565b60405163129c2ce160e31b815260040160405180910390fd5b60006001600160e01b03198216635a05180f60e01b1480610993575061099382611c8b565b92915050565b6109a1611cc0565b6109ac823383611d06565b5050565b6109b8611cc0565b6109c0611dde565b336109e16109d3368490038401846143d8565b826109dc61137b565b611e7f565b6109eb6003611882565b60405163c7c4fea960e01b81526001600160a01b03919091169063c7c4fea990610a1f906000908635908690600401614479565b600060405180830381600087803b158015610a3957600080fd5b505af1158015610a4d573d6000803e3d6000fd5b505050505050565b6060610a5f611dde565b336000610a6a61137b565b90506000846001600160401b03811115610a8657610a866142ca565b604051908082528060200260200182016040528015610aaf578160200160208202803683370190505b5093506000610abe6003611882565b905060005b86811015610d8757878782818110610add57610add6144a6565b905060200201359250816001600160a01b031663c7c4fea9600285886040518463ffffffff1660e01b8152600401610b1793929190614479565b600060405180830381600087803b158015610b3157600080fd5b505af1158015610b45573d6000803e3d6000fd5b50505050610b5283611a64565b15610b80576001868281518110610b6b57610b6b6144a6565b91151560209283029190910190910152610d7f565b600083815260706020908152604080832060718352818420825160a081019093528054835260018082015492959491929184019160ff1690811115610bc757610bc7613ce1565b6001811115610bd857610bd8613ce1565b8152604080516060808201835260028501546001600160a01b039081168352600386015481166020848101919091526004870154848601528086019390935283518083018552600587015482168152600687015490911692810192909252600785015482840152828401919091528151808201909252600884018054919093019290829060ff166001811115610c7057610c70613ce1565b6001811115610c8157610c81613ce1565b81526001820154602082015260029091015460409091015290525090506000610ca982612120565b90506000610cb9848a8a856121ea565b90506001816004811115610ccf57610ccf613ce1565b03610d7a57835460ff19166002908117855560405163114fc47560e11b81526001600160a01b0388169163229f88ea91610d0e91908b906004016144bc565b600060405180830381600087803b158015610d2857600080fd5b505af1158015610d3c573d6000803e3d6000fd5b505050507f62520d049932cdee872e9b3c59c0f6073637147e5e9bc8b050b062430eaf5c9f8284604051610d719291906144d7565b60405180910390a15b505050505b600101610ac3565b505050505092915050565b6000828152606b6020526040902060010154610dad8161221b565b610db78383612228565b505050565b603754600390610100900460ff16158015610dde575060375460ff8083169116105b610e035760405162461bcd60e51b8152600401610dfa90614538565b60405180910390fd5b6037805461ffff191660ff831617610100179055610e22600b8361224a565b6037805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b0381163314610ed85760405162461bcd60e51b815260206004820152602f60248201527f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560448201526e103937b632b9903337b91039b2b63360891b6064820152608401610dfa565b6109ac82826122ee565b60008281526070602090815260408083206001600160a01b038516845260020190915281205415155b9392505050565b610f1a612310565b600580546001600160a01b0319166001600160a01b0392909216919091179055565b610f4461236a565b610f4c6123d9565b565b610f56611cc0565b610f5f81611a64565b15610f7d576040516327ddf84960e11b815260040160405180910390fd5b6000818152607160209081526040808320815160a0810190925280548252600180820154929391929184019160ff1690811115610fbc57610fbc613ce1565b6001811115610fcd57610fcd613ce1565b8152604080516060808201835260028501546001600160a01b039081168352600386015481166020848101919091526004870154848601528086019390935283518083018552600587015482168152600687015490911692810192909252600785015482840152828401919091528151808201909252600884018054919093019290829060ff16600181111561106557611065613ce1565b600181111561107657611076613ce1565b8152600182015460208201526002909101546040918201529152606083015101519192505046146110e0576060810151604090810151905163092048d160e11b81526001600160e01b03196000351660048201526024810191909152466044820152606401610dfa565b7f04e8cbd836dea43a2dc7eb19de345cca3a8e6978a2ef5225d924775500f67c7c61110a82612120565b82604051610e5c9291906144d7565b611121611cc0565b6000829003611143576040516316ee9d3b60e11b815260040160405180910390fd5b60005b8281101561117857611170848483818110611163576111636144a6565b905060a002013384611d06565b600101611146565b50505050565b603754600290610100900460ff161580156111a0575060375460ff8083169116105b6111bc5760405162461bcd60e51b8152600401610dfa90614538565b6037805461ffff191660ff8316176101001790556074546111e8906008906001600160a01b031661224a565b607554611200906003906001600160a01b031661224a565b60775461121890600a906001600160a01b031661224a565b607480546001600160a01b031990811690915560758054821690556077805490911690556037805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b604080518082018252600080825260208083018290526001600160a01b038616825260738152838220858352905282902082518084019093528054919291829060ff1660018111156112d4576112d4613ce1565b60018111156112e5576112e5613ce1565b815290546001600160a01b036101009091048116602092830152908201519192501661099357604051631b79f53b60e21b815260040160405180910390fd5b61132c612310565b600083900361134e576040516316ee9d3b60e11b815260040160405180910390fd5b6111788484848461242b565b600080611365612310565b61136f848461250e565b915091505b9250929050565b600061138d611388612599565b612606565b905090565b607160209081526000918252604091829020805460018083015485516060808201885260028601546001600160a01b03908116835260038701548116838901526004870154838a015288518083018a526005880154821681526006880154909116978101979097526007860154878901528751908101909752600885018054949760ff93841697929692959294909391928492169081111561143657611436613ce1565b600181111561144757611447613ce1565b815260200160018201548152602001600282015481525050905085565b61146c61236a565b610f4c61263c565b61147c612310565b61148581612679565b6109ac828261224a565b6000828152606c60205260408120610f0b90836126af565b6000918252606b602090815260408084206001600160a01b0393909316845291905290205460ff1690565b603754610100900460ff16158080156114f25750603754600160ff909116105b8061150c5750303b15801561150c575060375460ff166001145b6115285760405162461bcd60e51b8152600401610dfa90614538565b6037805460ff19166001179055801561154b576037805461ff0019166101001790555b61155660008d6126bb565b6115608b8b6126c5565b505061156c898961250e565b506000905061157b8680614586565b905011156115cd576115ae6115908680614586565b61159d6020890189614586565b6115a78980614586565b8989612751565b6115cd6115bb8680614586565b6115c86020880188614586565b61242b565b8015611613576037805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b505050505050505050505050565b606061162b611cc0565b611633611dde565b3361163c613a8d565b836001600160401b03811115611654576116546142ca565b60405190808252806020026020018201604052801561167d578160200160208202803683370190505b509250600061168a61137b565b905060006116986003611882565b905060005b86811015610d87578787828181106116b7576116b76144a6565b905061016002018036038101906116ce91906143d8565b805160405163c7c4fea960e01b81529195506001600160a01b0384169163c7c4fea99161170391600091908a90600401614479565b600060405180830381600087803b15801561171d57600080fd5b505af1158015611731573d6000803e3d6000fd5b506002925061173e915050565b6040808601518101516000908152606f6020908152828220885183529052205460ff16600481111561177257611772613ce1565b036117a057600186828151811061178b5761178b6144a6565b911515602092830291909101909101526117ab565b6117ab848685611e7f565b60010161169d565b6000806117be612310565b61136f84846126c5565b6000818152606c602052604081206109939061295a565b6000828152606b60205260409020600101546117fa8161221b565b610db783836122ee565b600061180e612599565b60015461181b91906145e5565b60025461182890846145e5565b101592915050565b611838612310565b6000879003611868576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b6118788888888888888888612751565b5050505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156118b9576118b9613ce1565b60ff1681526020810191909152604001600020546001600160a01b03169050806118f8578160405163409140df60e11b8152600401610dfa9190614611565b919050565b6060816001600160401b03811115611917576119176142ca565b60405190808252806020026020018201604052801561194a57816020015b60608152602001906001900390816119355790505b50905060005b82811015611a5c57600085815260726020526040812090858584818110611979576119796144a6565b905060200201602081019061198e9190613ca2565b6001600160a01b03166001600160a01b0316815260200190815260200160002080546119b99061462b565b80601f01602080910402602001604051908101604052809291908181526020018280546119e59061462b565b8015611a325780601f10611a0757610100808354040283529160200191611a32565b820191906000526020600020905b815481529060010190602001808311611a1557829003601f168201915b5050505050828281518110611a4957611a496144a6565b6020908102919091010152600101611950565b509392505050565b6000600260008381526070602052604090205460ff166004811115611a8b57611a8b613ce1565b1492915050565b611a9a611cc0565b611aa2611dde565b338315801590611ab157508382145b611adc576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b6000611ae661137b565b9050600080611af56003611882565b905060005b87811015611c8057888882818110611b1457611b146144a6565b905060200201359250868682818110611b2f57611b2f6144a6565b9050602002810190611b41919061465f565b60008581526072602090815260408083206001600160a01b038b168452909152902091611b6f9190836146eb565b5060405163c7c4fea960e01b81526001600160a01b0383169063c7c4fea990611ba19060019087908a90600401614479565b600060405180830381600087803b158015611bbb57600080fd5b505af1158015611bcf573d6000803e3d6000fd5b50505060008481526076602052604081209150611bee828888886121ea565b90506001816004811115611c0457611c04613ce1565b03611c7657815460ff1916600217825560405163114fc47560e11b81526001600160a01b0385169063229f88ea90611c439060019089906004016144bc565b600060405180830381600087803b158015611c5d57600080fd5b505af1158015611c71573d6000803e3d6000fd5b505050505b5050600101611afa565b505050505050505050565b60006001600160e01b03198216637965db0b60e01b148061099357506301ffc9a760e01b6001600160e01b0319831614610993565b60005460ff1615610f4c5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610dfa565b611d20611d1b368590038501604086016147aa565b612964565b611d29836129df565b6000611d44611d3e6040860160208701613ca2565b83611280565b80519091506001811115611d5a57611d5a613ce1565b611d6a60608601604087016147c6565b6001811115611d7b57611d7b613ce1565b14611d985760405162035e2b60ea1b815260040160405180910390fd5b611dc78330611dad6040880160208901613ca2565b611dbf36899003890160408a016147aa565b929190612a5d565b611dd78483858460200151612c5c565b5050505050565b611de8600b611882565b604051635a02d57960e11b81523360048201526001600160a01b03919091169063b405aaf290602401602060405180830381865afa158015611e2e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e5291906147e3565b610f4c576000356001600160e01b0319166006604051620f948f60ea1b8152600401610dfa929190614805565b82516080840151611e8f90612964565b600084602001516001811115611ea757611ea7613ce1565b14611ec55760405163182f3d8760e11b815260040160405180910390fd5b4684606001516040015114611f13576060840151604090810151905163092048d160e11b81526001600160e01b03196000351660048201526024810191909152466044820152606401610dfa565b6000611f2f856060015160200151866040015160400151611280565b6080860151519091506001811115611f4957611f49613ce1565b81516001811115611f5c57611f5c613ce1565b148015611f8657508460400151602001516001600160a01b031681602001516001600160a01b0316145b611fa35760405163f4b8742f60e01b815260040160405180910390fd5b6040808601518101516000908152606f6020908152828220858352905290812090611fcd87612120565b90506000611fdd838888856121ea565b905087604001516040015185886001600160a01b03167f48c4262ed68beb92fe5d7d48d70772e49cd50c317937dea60a99f15f794b64598560405161202491815260200190565b60405180910390a4600181600481111561204057612040613ce1565b0361187857825460ff191660021783556060880151805160209091015160808a015161206f9290916000612de6565b6120796003611882565b885160405163114fc47560e11b81526001600160a01b03929092169163229f88ea916120ab91600091906004016144bc565b600060405180830381600087803b1580156120c557600080fd5b505af11580156120d9573d6000803e3d6000fd5b505050507f8d20d8121a34dded9035ff5b43e901c142824f7a22126392992c353c37890524828960405161210e9291906144d7565b60405180910390a15050505050505050565b6000806121308360400151613102565b905060006121418460600151613102565b905060006121958560800151604080517f1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d815282516020808301919091528301518183015291015160608201526080902090565b604080517fb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea815287516020808301919091529097015190870152606086019390935250608084015260a08301525060c0902090565b60006121f785858461314a565b60006122038684613200565b90506122118685838661330e565b9695505050505050565b612225813361335a565b50565b61223282826133be565b6000828152606c60205260409020610db79082613444565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561228057612280613ce1565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156122c1576122c1613ce1565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6122f88282613459565b6000828152606c60205260409020610db790826134c0565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610f4c576000356001600160e01b0319166001604051620f948f60ea1b8152600401610dfa929190614805565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314806123ac57506005546001600160a01b031633145b610f4c576000356001600160e01b0319166001604051620f948f60ea1b8152600401610dfa929190614805565b6123e16134d5565b6000805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b828114612459576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b60005b838110156124ca57828282818110612476576124766144a6565b9050602002013560386000878785818110612493576124936144a6565b90506020020160208101906124a89190613ca2565b6001600160a01b0316815260208101919091526040016000205560010161245c565b507f6f52f53a938df83439fa4c6055c7df0a6906d621aa6dfa4708187037fdfc41da8484848460405161250094939291906148a1565b60405180910390a150505050565b600080828411156125325760405163964a4d2760e01b815260040160405180910390fd5b505060018054600254607885905560798490556004805493840190556040805183815260208101839052929391928592879290917feac82d4d949d2d4f77f96aa68ab6b1bb750da73f14e55d41a1b93f387471ecba91015b60405180910390a49250929050565b60006125a5600b611882565b6001600160a01b03166306aba0e16040518163ffffffff1660e01b8152600401602060405180830381865afa1580156125e2573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061138d91906148d3565b600060025460016002548460015461261e91906145e5565b61262891906148ec565b61263291906148ff565b6109939190614912565b612644611cc0565b6000805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25861240e3390565b806001600160a01b03163b60000361222557604051630bfc64a360e21b81526001600160a01b0382166004820152602401610dfa565b6000610f0b838361351e565b6109ac8282612228565b600080828411156126f7576000356001600160e01b0319166040516387f6f09560e01b8152600401610dfa91906145fc565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910161258a565b868514801561275f57508683145b61278a576000356001600160e01b0319166040516306b5667560e21b8152600401610dfa91906145fc565b60005b8781101561291c578686828181106127a7576127a76144a6565b90506020020160208101906127bc9190613ca2565b607360008b8b858181106127d2576127d26144a6565b90506020020160208101906127e79190613ca2565b6001600160a01b03166001600160a01b03168152602001908152602001600020600087878581811061281b5761281b6144a6565b90506020020135815260200190815260200160002060000160016101000a8154816001600160a01b0302191690836001600160a01b03160217905550828282818110612869576128696144a6565b905060200201602081019061287e91906147c6565b607360008b8b85818110612894576128946144a6565b90506020020160208101906128a99190613ca2565b6001600160a01b03166001600160a01b0316815260200190815260200160002060008787858181106128dd576128dd6144a6565b60209081029290920135835250810191909152604001600020805460ff19166001838181111561290f5761290f613ce1565b021790555060010161278d565b507f2544bff60c6d5b84946e06804af9f84e150bbee85238dbdee79efca4e0adf401888888888888888860405161210e989796959493929190614934565b6000610993825490565b60008151600181111561297957612979613ce1565b14801561298a575060008160400151115b801561299857506020810151155b806129c257506001815160018111156129b3576129b3613ce1565b1480156129c257506040810151155b6122255760405163034992a760e51b815260040160405180910390fd5b60006129f160608301604084016147c6565b6001811115612a0257612a02613ce1565b148015612a3f575060386000612a1e6040840160208501613ca2565b6001600160a01b031681526020810191909152604001600020546080820135105b1561222557604051636eff4a8560e11b815260040160405180910390fd5b600060608186516001811115612a7557612a75613ce1565b03612b525760408681015181516001600160a01b038881166024830152878116604483015260648083019390935283518083039093018352608490910183526020820180516001600160e01b03166323b872dd60e01b179052915191851691612ade91906149c3565b6000604051808303816000865af19150503d8060008114612b1b576040519150601f19603f3d011682016040523d82523d6000602084013e612b20565b606091505b509092509050818015612b4b575080511580612b4b575080806020019051810190612b4b91906147e3565b9150612c36565b600186516001811115612b6757612b67613ce1565b03612c1d57602086810151604080516001600160a01b0389811660248301528881166044830152606480830194909452825180830390940184526084909101825292820180516001600160e01b03166323b872dd60e01b1790525191851691612bd091906149c3565b6000604051808303816000865af19150503d8060008114612c0d576040519150601f19603f3d011682016040523d82523d6000602084013e612c12565b606091505b505080925050612c36565b6040516361e411a760e11b815260040160405180910390fd5b81610a4d5785858585604051639d2e4c6760e01b8152600401610dfa94939291906149df565b606e805460009182612c6d83614a15565b9091555090506000612c9484838588612c8b368c90038c018c614a2e565b93929190613548565b60008381526071602090815260409091208251815590820151600180830180549495508594909160ff19909116908381811115612cd357612cd3613ce1565b021790555060408281015180516002840180546001600160a01b039283166001600160a01b03199182161790915560208084015160038701805491851691841691909117905592840151600486015560608601518051600587018054918516918416919091179055928301516006860180549190931691161790550151600782015560808201518051600883018054909190829060ff191660018381811115612d7e57612d7e613ce1565b0217905550602082015181600101556040820151816002015550509050507ff313c253a5be72c29d0deb2c8768a9543744ac03d6b3cafd50cc976f1c2632fc612dc682612120565b82604051612dd59291906144d7565b60405180910390a150949350505050565b6000816001600160a01b0316836001600160a01b031603612e955760408086015190516001600160a01b0386169180156108fc02916000818181858888f19350505050612e9057816001600160a01b031663d0e30db086604001516040518263ffffffff1660e01b81526004016000604051808303818588803b158015612e6c57600080fd5b505af1158015612e80573d6000803e3d6000fd5b5050505050612e908585856135b4565b611dd7565b600085516001811115612eaa57612eaa613ce1565b03613013576040516370a0823160e01b81523060048201526000906001600160a01b038516906370a0823190602401602060405180830381865afa158015612ef6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612f1a91906148d3565b9050856040015181101561300257836001600160a01b03166340c10f1930838960400151612f4891906148ff565b6040516001600160a01b03909216602483015260448201526064016040516020818303038152906040529060e01b6020820180516001600160e01b038381831617835250505050604051612f9c91906149c3565b6000604051808303816000865af19150503d8060008114612fd9576040519150601f19603f3d011682016040523d82523d6000602084013e612fde565b606091505b5050809250508161300257604051632f739fff60e11b815260040160405180910390fd5b61300d8686866135b4565b50611dd7565b60018551600181111561302857613028613ce1565b03612c1d5761303c83858760200151613632565b612e9057602085810151604080516001600160a01b038881166024830152604480830194909452825180830390940184526064909101825292820180516001600160e01b03166340c10f1960e01b179052519185169161309c91906149c3565b6000604051808303816000865af19150503d80600081146130d9576040519150601f19603f3d011682016040523d82523d6000602084013e6130de565b606091505b50508091505080612e905760405163c8e3a09f60e01b815260040160405180910390fd5b604080517f353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764815282516020808301919091528301518183015291015160608201526080902090565b60008360030154118015613162575042836003015411155b1561317357825460ff191660041783555b6001600160a01b0382166000908152600284016020526040902054156131b75760405163025fd59560e41b81526001600160a01b0383166004820152602401610dfa565b6001600160a01b039091166000818152600284016020908152604082209390935560059093018054600181018255908452919092200180546001600160a01b0319169091179055565b600080600061320f600b611882565b6001600160a01b031663c441c4a86040518163ffffffff1660e01b8152600401600060405180830381865afa15801561324c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526132749190810190614b18565b81519194509250905060005b8181101561330457858760020160008684815181106132a1576132a16144a6565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002054036132fc578281815181106132e1576132e16144a6565b60200260200101516bffffffffffffffffffffffff16850194505b600101613280565b5050505092915050565b600083831015801561333557506000855460ff16600481111561333357613333613ce1565b145b1561334d57845460ff19166001908117865585018290555b5050915460ff1692915050565b61336482826114a7565b6109ac5761337c816001600160a01b031660146136dd565b6133878360206136dd565b604051602001613398929190614c10565b60408051601f198184030181529082905262461bcd60e51b8252610dfa91600401614c85565b6133c882826114a7565b6109ac576000828152606b602090815260408083206001600160a01b03851684529091529020805460ff191660011790556134003390565b6001600160a01b0316816001600160a01b0316837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45050565b6000610f0b836001600160a01b038416613878565b61346382826114a7565b156109ac576000828152606b602090815260408083206001600160a01b0385168085529252808320805460ff1916905551339285917ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b9190a45050565b6000610f0b836001600160a01b0384166138c7565b60005460ff16610f4c5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610dfa565b6000826000018281548110613535576135356144a6565b9060005260206000200154905092915050565b613550613a8d565b92835260016020808501919091526060840180516001600160a01b0396871690528682015181519087169083015251466040918201528651818601805191881690915280519490961693909101929092529251810192909252910151608082015290565b600080845160018111156135ca576135ca613ce1565b036135e5576135de828486604001516139ba565b905061360e565b6001845160018111156135fa576135fa613ce1565b03612c1d576135de82848660200151613632565b80611178578383836040516341bd7d9160e11b8152600401610dfa93929190614c98565b604080513060248201526001600160a01b038481166044830152606480830185905283518084039091018152608490920183526020820180516001600160e01b03166323b872dd60e01b1790529151600092861691613690916149c3565b6000604051808303816000865af19150503d80600081146136cd576040519150601f19603f3d011682016040523d82523d6000602084013e6136d2565b606091505b509095945050505050565b606060006136ec8360026145e5565b6136f79060026148ec565b6001600160401b0381111561370e5761370e6142ca565b6040519080825280601f01601f191660200182016040528015613738576020820181803683370190505b509050600360fc1b81600081518110613753576137536144a6565b60200101906001600160f81b031916908160001a905350600f60fb1b81600181518110613782576137826144a6565b60200101906001600160f81b031916908160001a90535060006137a68460026145e5565b6137b19060016148ec565b90505b6001811115613829576f181899199a1a9b1b9c1cb0b131b232b360811b85600f16601081106137e5576137e56144a6565b1a60f81b8282815181106137fb576137fb6144a6565b60200101906001600160f81b031916908160001a90535060049490941c9361382281614cc8565b90506137b4565b508315610f0b5760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610dfa565b60008181526001830160205260408120546138bf57508154600181810184556000848152602080822090930184905584548482528286019093526040902091909155610993565b506000610993565b600081815260018301602052604081205480156139b05760006138eb6001836148ff565b85549091506000906138ff906001906148ff565b905081811461396457600086600001828154811061391f5761391f6144a6565b9060005260206000200154905080876000018481548110613942576139426144a6565b6000918252602080832090910192909255918252600188019052604090208390555b855486908061397557613975614cdf565b600190038181906000526020600020016000905590558560010160008681526020019081526020016000206000905560019350505050610993565b6000915050610993565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663a9059cbb60e01b179052915160009260609290871691613a1791906149c3565b6000604051808303816000865af19150503d8060008114613a54576040519150601f19603f3d011682016040523d82523d6000602084013e613a59565b606091505b509092509050818015613a84575080511580613a84575080806020019051810190613a8491906147e3565b95945050505050565b6040805160a08101825260008082526020808301829052835160608082018652838252818301849052818601849052848601919091528451808201865283815280830184905280860184905281850152845190810185528281529081018290529283015290608082015290565b600060208284031215613b0c57600080fd5b81356001600160e01b031981168114610f0b57600080fd5b60008082840360c0811215613b3857600080fd5b60a0811215613b4657600080fd5b50919360a08501359350915050565b60006101608284031215613b6857600080fd5b50919050565b60008083601f840112613b8057600080fd5b5081356001600160401b03811115613b9757600080fd5b6020830191508360208260051b850101111561137457600080fd5b60008060208385031215613bc557600080fd5b82356001600160401b03811115613bdb57600080fd5b613be785828601613b6e565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b81811015613c2d578351151583529284019291840191600101613c0f565b50909695505050505050565b600060208284031215613c4b57600080fd5b5035919050565b6001600160a01b038116811461222557600080fd5b80356118f881613c52565b60008060408385031215613c8557600080fd5b823591506020830135613c9781613c52565b809150509250929050565b600060208284031215613cb457600080fd5b8135610f0b81613c52565b60008060408385031215613cd257600080fd5b50508035926020909101359150565b634e487b7160e01b600052602160045260246000fd5b6080810160058610613d0b57613d0b613ce1565b9481526020810193909352604083019190915260609091015290565b600080600060408486031215613d3c57600080fd5b83356001600160401b0380821115613d5357600080fd5b818601915086601f830112613d6757600080fd5b813581811115613d7657600080fd5b87602060a083028501011115613d8b57600080fd5b6020928301989097509590910135949350505050565b60008060408385031215613db457600080fd5b8235613dbf81613c52565b946020939093013593505050565b6002811061222557612225613ce1565b81516040820190613ded81613dcd565b82526020928301516001600160a01b0316929091019190915290565b60008060008060408587031215613e1f57600080fd5b84356001600160401b0380821115613e3657600080fd5b613e4288838901613b6e565b90965094506020870135915080821115613e5b57600080fd5b50613e6887828801613b6e565b95989497509550505050565b80516001600160a01b03908116835260208083015190911690830152604090810151910152565b8051613ea681613dcd565b825260208181015190830152604090810151910152565b8581526101608101613ece86613dcd565b856020830152613ee16040830186613e74565b613eee60a0830185613e74565b612211610100830184613e9b565b8035601081106118f857600080fd5b60008060408385031215613f1e57600080fd5b613f2783613efc565b91506020830135613c9781613c52565b806040810183101561099357600080fd5b60008060008060008060008060008060006101208c8e031215613f6a57600080fd5b613f738c613c67565b9a5060208c0135995060408c0135985060608c0135975060808c013596506001600160401b038060a08e01351115613faa57600080fd5b613fba8e60a08f01358f01613b6e565b909750955060c08d0135811015613fd057600080fd5b613fe08e60c08f01358f01613f37565b94508060e08e01351115613ff357600080fd5b6140038e60e08f01358f01613f37565b9350806101008e0135111561401757600080fd5b506140298d6101008e01358e01613b6e565b81935080925050509295989b509295989b9093969950565b6000806020838503121561405457600080fd5b82356001600160401b038082111561406b57600080fd5b818501915085601f83011261407f57600080fd5b81358181111561408e57600080fd5b866020610160830285010111156140a457600080fd5b60209290920196919550909350505050565b6000806000806000806000806080898b0312156140d257600080fd5b88356001600160401b03808211156140e957600080fd5b6140f58c838d01613b6e565b909a50985060208b013591508082111561410e57600080fd5b61411a8c838d01613b6e565b909850965060408b013591508082111561413357600080fd5b61413f8c838d01613b6e565b909650945060608b013591508082111561415857600080fd5b506141658b828c01613b6e565b999c989b5096995094979396929594505050565b60006020828403121561418b57600080fd5b610f0b82613efc565b6000806000604084860312156141a957600080fd5b8335925060208401356001600160401b038111156141c657600080fd5b6141d286828701613b6e565b9497909650939450505050565b60005b838110156141fa5781810151838201526020016141e2565b50506000910152565b6000815180845261421b8160208601602086016141df565b601f01601f19169290920160200192915050565b6000602080830181845280855180835260408601915060408160051b870101925083870160005b8281101561428457603f19888603018452614272858351614203565b94509285019290850190600101614256565b5092979650505050505050565b6000806000606084860312156142a657600080fd5b833592506020840135915060408401356142bf81613c52565b809150509250925092565b634e487b7160e01b600052604160045260246000fd5b604051606081016001600160401b0381118282101715614302576143026142ca565b60405290565b604051601f8201601f191681016001600160401b0381118282101715614330576143306142ca565b604052919050565b6002811061222557600080fd5b60006060828403121561435757600080fd5b61435f6142e0565b9050813561436c81613c52565b8152602082013561437c81613c52565b806020830152506040820135604082015292915050565b6000606082840312156143a557600080fd5b6143ad6142e0565b905081356143ba81614338565b80825250602082013560208201526040820135604082015292915050565b600061016082840312156143eb57600080fd5b60405160a081018181106001600160401b038211171561440d5761440d6142ca565b60405282358152602083013561442281614338565b60208201526144348460408501614345565b60408201526144468460a08501614345565b6060820152614459846101008501614393565b60808201529392505050565b6003811061447557614475613ce1565b9052565b606081016144878286614465565b60208201939093526001600160a01b0391909116604090910152919050565b634e487b7160e01b600052603260045260246000fd5b604081016144ca8285614465565b8260208301529392505050565b6000610180820190508382528251602083015260208301516144f881613dcd565b8060408401525060408301516145116060840182613e74565b50606083015161452460c0840182613e74565b506080830151611a5c610120840182613e9b565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b6000808335601e1984360301811261459d57600080fd5b8301803591506001600160401b038211156145b757600080fd5b6020019150600581901b360382131561137457600080fd5b634e487b7160e01b600052601160045260246000fd5b8082028115828204841417610993576109936145cf565b6001600160e01b031991909116815260200190565b602081016010831061462557614625613ce1565b91905290565b600181811c9082168061463f57607f821691505b602082108103613b6857634e487b7160e01b600052602260045260246000fd5b6000808335601e1984360301811261467657600080fd5b8301803591506001600160401b0382111561469057600080fd5b60200191503681900382131561137457600080fd5b601f821115610db757600081815260208120601f850160051c810160208610156146cc5750805b601f850160051c820191505b81811015610a4d578281556001016146d8565b6001600160401b03831115614702576147026142ca565b61471683614710835461462b565b836146a5565b6000601f84116001811461474a57600085156147325750838201355b600019600387901b1c1916600186901b178355611dd7565b600083815260209020601f19861690835b8281101561477b578685013582556020948501946001909201910161475b565b50868210156147985760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b6000606082840312156147bc57600080fd5b610f0b8383614393565b6000602082840312156147d857600080fd5b8135610f0b81614338565b6000602082840312156147f557600080fd5b81518015158114610f0b57600080fd5b6001600160e01b03198316815260408101600b83106144ca576144ca613ce1565b8183526000602080850194508260005b8581101561486457813561484981613c52565b6001600160a01b031687529582019590820190600101614836565b509495945050505050565b81835260006001600160fb1b0383111561488857600080fd5b8260051b80836020870137939093016020019392505050565b6040815260006148b5604083018688614826565b82810360208401526148c881858761486f565b979650505050505050565b6000602082840312156148e557600080fd5b5051919050565b80820180821115610993576109936145cf565b81810381811115610993576109936145cf565b60008261492f57634e487b7160e01b600052601260045260246000fd5b500490565b608081526000614948608083018a8c614826565b60208382038185015261495c828a8c614826565b9150838203604085015261497182888a61486f565b8481036060860152858152869250810160005b868110156149b257833561499781614338565b6149a081613dcd565b82529282019290820190600101614984565b509c9b505050505050505050505050565b600082516149d58184602087016141df565b9190910192915050565b60c081016149ed8287613e9b565b6001600160a01b0394851660608301529284166080820152921660a090920191909152919050565b600060018201614a2757614a276145cf565b5060010190565b600060a08284031215614a4057600080fd5b614a486142e0565b8235614a5381613c52565b81526020830135614a6381613c52565b6020820152614a758460408501614393565b60408201529392505050565b60006001600160401b03821115614a9a57614a9a6142ca565b5060051b60200190565b600082601f830112614ab557600080fd5b81516020614aca614ac583614a81565b614308565b82815260059290921b84018101918181019086841115614ae957600080fd5b8286015b84811015614b0d578051614b0081613c52565b8352918301918301614aed565b509695505050505050565b600080600060608486031215614b2d57600080fd5b83516001600160401b0380821115614b4457600080fd5b614b5087838801614aa4565b9450602091508186015181811115614b6757600080fd5b614b7388828901614aa4565b945050604086015181811115614b8857600080fd5b86019050601f81018713614b9b57600080fd5b8051614ba9614ac582614a81565b81815260059190911b82018301908381019089831115614bc857600080fd5b928401925b82841015614c015783516bffffffffffffffffffffffff81168114614bf25760008081fd5b82529284019290840190614bcd565b80955050505050509250925092565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000815260008351614c488160178501602088016141df565b7001034b99036b4b9b9b4b733903937b6329607d1b6017918401918201528351614c798160288401602088016141df565b01602801949350505050565b602081526000610f0b6020830184614203565b60a08101614ca68286613e9b565b6001600160a01b03938416606083015291909216608090920191909152919050565b600081614cd757614cd76145cf565b506000190190565b634e487b7160e01b600052603160045260246000fdfea2646970667358221220ec5e4d67a54601fd535977c8db3ac6acad4decf9c225f2e4583ebaf312358ccc64736f6c63430008110033", + "devdoc": { + "errors": { + "ErrAlreadyVoted(address)": [ + { + "details": "Error indicating that a voter has already voted.", + "params": { + "voter": "The address of the voter who has already voted." + } + } + ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrERC20MintingFailed()": [ + { + "details": "Error indicating that the minting of ERC20 tokens has failed." + } + ], + "ErrERC721MintingFailed()": [ + { + "details": "Error indicating that the minting of ERC721 tokens has failed." + } + ], + "ErrEmptyArray()": [ + { + "details": "Error indicating that an array is empty when it should contain elements." + } + ], + "ErrInvalidChainId(bytes4,uint256,uint256)": [ + { + "details": "Error indicating that the chain ID is invalid.", + "params": { + "actual": "Current chain ID that executing function.", + "expected": "Expected chain ID required for the tx to success.", + "msgSig": "The function signature (bytes4) of the operation that encountered an invalid chain ID." + } + } + ], + "ErrInvalidInfo()": [ + { + "details": "Error indicating that the provided information is invalid." + } + ], + "ErrInvalidReceipt()": [ + { + "details": "Error indicating that a receipt is invalid." + } + ], + "ErrInvalidReceiptKind()": [ + { + "details": "Error indicating that a receipt kind is invalid." + } + ], + "ErrInvalidRequest()": [ + { + "details": "Error indicating that a request is invalid." + } + ], + "ErrInvalidThreshold(bytes4)": [ + { + "details": "Error indicating that the provided threshold is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that the invalid threshold applies to." + } + } + ], + "ErrInvalidTokenStandard()": [ + { + "details": "Error indicating that a token standard is invalid." + } + ], + "ErrInvalidTrustedThreshold()": [ + { + "details": "Error thrown when an invalid trusted threshold is specified." + } + ], + "ErrLengthMismatch(bytes4)": [ + { + "details": "Error indicating a mismatch in the length of input parameters or arrays for a specific function.", + "params": { + "msgSig": "The function signature (bytes4) that has a length mismatch." + } + } + ], + "ErrQueryForTooSmallQuantity()": [ + { + "details": "Throwed when the ERC20 withdrawal quantity is less than the minimum threshold." + } + ], + "ErrTokenCouldNotTransfer((uint8,uint256,uint256),address,address)": [ + { + "details": "Error indicating that the `transfer` has failed.", + "params": { + "to": "Receiver of the token value.", + "token": "Address of the token.", + "tokenInfo": "Info of the token including ERC standard, id or quantity." + } + } + ], + "ErrTokenCouldNotTransferFrom((uint8,uint256,uint256),address,address,address)": [ + { + "details": "Error indicating that the `transferFrom` has failed.", + "params": { + "from": "Owner of the token value.", + "to": "Receiver of the token value.", + "token": "Address of the token.", + "tokenInfo": "Info of the token including ERC standard, id or quantity." + } + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnsupportedStandard()": [ + { + "details": "Error indicating that an unsupported standard is encountered." + } + ], + "ErrUnsupportedToken()": [ + { + "details": "Error indicating that a token is not supported." + } + ], + "ErrWithdrawalsMigrated()": [ + { + "details": "Error thrown when attempting to withdraw funds that have already been migrated." + } + ], + "ErrWithdrawnOnMainchainAlready()": [ + { + "details": "Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain." + } + ], + "ErrZeroCodeContract(address)": [ + { + "details": "Error of set to non-contract." + } + ] + }, + "kind": "dev", + "methods": { + "bulkRequestWithdrawalFor((address,address,(uint8,uint256,uint256))[],uint256)": { + "details": "Bulk requests withdrawals. Emits the `WithdrawalRequested` events." + }, + "bulkSubmitWithdrawalSignatures(uint256[],bytes[])": { + "details": "Submits withdrawal signatures. Requirements: - The method caller is a validator." + }, + "checkThreshold(uint256)": { + "details": "Checks whether the `_voteWeight` passes the threshold." + }, + "depositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))": { + "details": "Deposits based on the receipt. Requirements: - The method caller is a validator. Emits the `Deposited` once the assets are released." + }, + "depositVoted(uint256,uint256,address)": { + "details": "Returns whether the deposit is casted by the voter." + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, + "getMainchainToken(address,uint256)": { + "details": "Returns mainchain token address. Reverts for unsupported token." + }, + "getRoleAdmin(bytes32)": { + "details": "Returns the admin role that controls `role`. See {grantRole} and {revokeRole}. To change a role's admin, use {_setRoleAdmin}." + }, + "getRoleMember(bytes32,uint256)": { + "details": "Returns one of the accounts that have `role`. `index` must be a value between 0 and {getRoleMemberCount}, non-inclusive. Role bearers are not sorted in any particular way, and their ordering may change at any point. WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure you perform all queries on the same block. See the following https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post] for more information." + }, + "getRoleMemberCount(bytes32)": { + "details": "Returns the number of accounts that have `role`. Can be used together with {getRoleMember} to enumerate all bearers of a role." + }, + "getThreshold()": { + "details": "Returns the threshold." + }, + "getTrustedThreshold()": { + "details": "Returns the threshold about trusted org." + }, + "getWithdrawalSignatures(uint256,address[])": { + "details": "Returns withdrawal signatures." + }, + "grantRole(bytes32,address)": { + "details": "Grants `role` to `account`. If `account` had not been already granted `role`, emits a {RoleGranted} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleGranted} event." + }, + "hasRole(bytes32,address)": { + "details": "Returns `true` if `account` has been granted `role`." + }, + "initialize(address,uint256,uint256,uint256,uint256,address[],address[][2],uint256[][2],uint8[])": { + "details": "Initializes contract storage." + }, + "mainchainWithdrew(uint256)": { + "details": "Returns whether the withdrawal is done on mainchain." + }, + "mainchainWithdrewVoted(uint256,address)": { + "details": "Returns whether the mainchain withdrew is casted by the voter." + }, + "mapTokens(address[],address[],uint256[],uint8[])": { + "details": "Maps Ronin tokens to mainchain networks. Requirement: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `TokenMapped` event." + }, + "minimumVoteWeight()": { + "details": "Returns the minimum vote weight to pass the threshold." + }, + "pause()": { + "details": "Triggers paused state." + }, + "paused()": { + "details": "Returns true if the contract is paused, and false otherwise." + }, + "renounceRole(bytes32,address)": { + "details": "Revokes `role` from the calling account. Roles are often managed via {grantRole} and {revokeRole}: this function's purpose is to provide a mechanism for accounts to lose their privileges if they are compromised (such as when a trusted device is misplaced). If the calling account had been revoked `role`, emits a {RoleRevoked} event. Requirements: - the caller must be `account`. May emit a {RoleRevoked} event." + }, + "requestWithdrawalFor((address,address,(uint8,uint256,uint256)),uint256)": { + "details": "Locks the assets and request withdrawal. Emits the `WithdrawalRequested` event." + }, + "requestWithdrawalSignatures(uint256)": { + "details": "Requests withdrawal signatures for a specific withdrawal. Emits the `WithdrawalSignaturesRequested` event." + }, + "revokeRole(bytes32,address)": { + "details": "Revokes `role` from `account`. If `account` had been granted `role`, emits a {RoleRevoked} event. Requirements: - the caller must have ``role``'s admin role. May emit a {RoleRevoked} event." + }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, + "setEmergencyPauser(address)": { + "details": "Grant emergency pauser role for `_addr`." + }, + "setMinimumThresholds(address[],uint256[])": { + "details": "Sets the minimum thresholds to withdraw. Requirements: - The method caller is admin. - The arrays have the same length and its length larger than 0. Emits the `MinimumThresholdsUpdated` event." + }, + "setThreshold(uint256,uint256)": { + "details": "Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event." + }, + "supportsInterface(bytes4)": { + "details": "See {IERC165-supportsInterface}." + }, + "tryBulkAcknowledgeMainchainWithdrew(uint256[])": { + "details": "Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal vote is already done before. Requirements: - The method caller is a validator. Emits the `MainchainWithdrew` once the valid call passes the quorum threshold." + }, + "tryBulkDepositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256))[])": { + "details": "Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote is already done before. Reverts if the deposit is invalid or is voted by the validator again. Requirements: - The method caller is a validator. Emits the `Deposited` once the assets are released." + }, + "unpause()": { + "details": "Triggers unpaused state." + } + }, + "stateVariables": { + "____deprecated0": { + "custom:deprecated": "Previously `_validatorContract` (non-zero value)" + }, + "____deprecated1": { + "custom:deprecated": "Previously `_bridgeTrackingContract` (non-zero value)" + }, + "____deprecated2": { + "custom:deprecated": "Previously `_trustedOrgContract` (non-zero value)" + }, + "___deprecated4": { + "custom:deprecated": "Previously `withdrawalMigrated` (non-zero value)" + }, + "_mainchainToken": { + "details": "Mapping from token address => chain id => mainchain token address" + }, + "_withdrawalSig": { + "details": "Mapping from withdrawal id => validator address => signatures" + }, + "depositVote": { + "details": "Mapping from chain id => deposit id => deposit vote" + }, + "mainchainWithdrewVote": { + "details": "Mapping from withdrawal id => mainchain withdrew vote" + }, + "withdrawal": { + "details": "Mapping from withdrawal id => withdrawal receipt" + }, + "withdrawalCount": { + "details": "Total withdrawal" + }, + "withdrawalStatVote": { + "details": "Mapping from withdrawal id => vote for recording withdrawal stats" + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "depositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256)))": { + "notice": "The assets will be transferred whenever the valid call passes the quorum threshold." + }, + "tryBulkAcknowledgeMainchainWithdrew(uint256[])": { + "notice": "Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time." + }, + "tryBulkDepositFor((uint256,uint8,(address,address,uint256),(address,address,uint256),(uint8,uint256,uint256))[])": { + "notice": "The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time." + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [ + { + "astId": 1286, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_paused", + "offset": 0, + "slot": "0", + "type": "t_bool" + }, + { + "astId": 3249, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_num", + "offset": 0, + "slot": "1", + "type": "t_uint256" + }, + { + "astId": 3251, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_denom", + "offset": 0, + "slot": "2", + "type": "t_uint256" + }, + { + "astId": 3253, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "______deprecated", + "offset": 0, + "slot": "3", + "type": "t_address" + }, + { + "astId": 3255, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "nonce", + "offset": 0, + "slot": "4", + "type": "t_uint256" + }, + { + "astId": 3257, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "emergencyPauser", + "offset": 0, + "slot": "5", + "type": "t_address" + }, + { + "astId": 3262, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "______gap", + "offset": 0, + "slot": "6", + "type": "t_array(t_uint256)49_storage" + }, + { + "astId": 1124, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_initialized", + "offset": 0, + "slot": "55", + "type": "t_uint8" + }, + { + "astId": 1127, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_initializing", + "offset": 1, + "slot": "55", + "type": "t_bool" + }, + { + "astId": 3791, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "minimumThreshold", + "offset": 0, + "slot": "56", + "type": "t_mapping(t_address,t_uint256)" + }, + { + "astId": 3796, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "______gap", + "offset": 0, + "slot": "57", + "type": "t_array(t_uint256)50_storage" + }, + { + "astId": 24, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_roles", + "offset": 0, + "slot": "107", + "type": "t_mapping(t_bytes32,t_struct(RoleData)19_storage)" + }, + { + "astId": 338, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_roleMembers", + "offset": 0, + "slot": "108", + "type": "t_mapping(t_bytes32,t_struct(AddressSet)2949_storage)" + }, + { + "astId": 26899, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "___deprecated4", + "offset": 0, + "slot": "109", + "type": "t_bool" + }, + { + "astId": 26902, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "withdrawalCount", + "offset": 0, + "slot": "110", + "type": "t_uint256" + }, + { + "astId": 26910, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "depositVote", + "offset": 0, + "slot": "111", + "type": "t_mapping(t_uint256,t_mapping(t_uint256,t_struct(Vote)14520_storage))" + }, + { + "astId": 26916, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "mainchainWithdrewVote", + "offset": 0, + "slot": "112", + "type": "t_mapping(t_uint256,t_struct(Vote)14520_storage)" + }, + { + "astId": 26922, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "withdrawal", + "offset": 0, + "slot": "113", + "type": "t_mapping(t_uint256,t_struct(Receipt)15871_storage)" + }, + { + "astId": 26929, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_withdrawalSig", + "offset": 0, + "slot": "114", + "type": "t_mapping(t_uint256,t_mapping(t_address,t_bytes_storage))" + }, + { + "astId": 26937, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_mainchainToken", + "offset": 0, + "slot": "115", + "type": "t_mapping(t_address,t_mapping(t_uint256,t_struct(MappedToken)11895_storage))" + }, + { + "astId": 26940, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "____deprecated0", + "offset": 0, + "slot": "116", + "type": "t_address" + }, + { + "astId": 26943, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "____deprecated1", + "offset": 0, + "slot": "117", + "type": "t_address" + }, + { + "astId": 26949, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "withdrawalStatVote", + "offset": 0, + "slot": "118", + "type": "t_mapping(t_uint256,t_struct(Vote)14520_storage)" + }, + { + "astId": 26952, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "____deprecated2", + "offset": 0, + "slot": "119", + "type": "t_address" + }, + { + "astId": 26954, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_trustedNum", + "offset": 0, + "slot": "120", + "type": "t_uint256" + }, + { + "astId": 26956, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_trustedDenom", + "offset": 0, + "slot": "121", + "type": "t_uint256" + } + ], + "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, + "t_array(t_address)dyn_storage": { + "base": "t_address", + "encoding": "dynamic_array", + "label": "address[]", + "numberOfBytes": "32" + }, + "t_array(t_bytes32)dyn_storage": { + "base": "t_bytes32", + "encoding": "dynamic_array", + "label": "bytes32[]", + "numberOfBytes": "32" + }, + "t_array(t_uint256)49_storage": { + "base": "t_uint256", + "encoding": "inplace", + "label": "uint256[49]", + "numberOfBytes": "1568" + }, + "t_array(t_uint256)50_storage": { + "base": "t_uint256", + "encoding": "inplace", + "label": "uint256[50]", + "numberOfBytes": "1600" + }, + "t_bool": { + "encoding": "inplace", + "label": "bool", + "numberOfBytes": "1" + }, + "t_bytes32": { + "encoding": "inplace", + "label": "bytes32", + "numberOfBytes": "32" + }, + "t_bytes_storage": { + "encoding": "bytes", + "label": "bytes", + "numberOfBytes": "32" + }, + "t_enum(Kind)15668": { + "encoding": "inplace", + "label": "enum Transfer.Kind", + "numberOfBytes": "1" + }, + "t_enum(Standard)15187": { + "encoding": "inplace", + "label": "enum Token.Standard", + "numberOfBytes": "1" + }, + "t_enum(VoteStatus)11922": { + "encoding": "inplace", + "label": "enum VoteStatusConsumer.VoteStatus", + "numberOfBytes": "1" + }, + "t_mapping(t_address,t_bool)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => bool)", + "numberOfBytes": "32", + "value": "t_bool" + }, + "t_mapping(t_address,t_bytes32)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => bytes32)", + "numberOfBytes": "32", + "value": "t_bytes32" + }, + "t_mapping(t_address,t_bytes_storage)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => bytes)", + "numberOfBytes": "32", + "value": "t_bytes_storage" + }, + "t_mapping(t_address,t_mapping(t_uint256,t_struct(MappedToken)11895_storage))": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => mapping(uint256 => struct MappedTokenConsumer.MappedToken))", + "numberOfBytes": "32", + "value": "t_mapping(t_uint256,t_struct(MappedToken)11895_storage)" + }, + "t_mapping(t_address,t_uint256)": { + "encoding": "mapping", + "key": "t_address", + "label": "mapping(address => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_mapping(t_bytes32,t_struct(AddressSet)2949_storage)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => struct EnumerableSet.AddressSet)", + "numberOfBytes": "32", + "value": "t_struct(AddressSet)2949_storage" + }, + "t_mapping(t_bytes32,t_struct(RoleData)19_storage)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => struct AccessControl.RoleData)", + "numberOfBytes": "32", + "value": "t_struct(RoleData)19_storage" + }, + "t_mapping(t_bytes32,t_uint256)": { + "encoding": "mapping", + "key": "t_bytes32", + "label": "mapping(bytes32 => uint256)", + "numberOfBytes": "32", + "value": "t_uint256" + }, + "t_mapping(t_uint256,t_mapping(t_address,t_bytes_storage))": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => mapping(address => bytes))", + "numberOfBytes": "32", + "value": "t_mapping(t_address,t_bytes_storage)" + }, + "t_mapping(t_uint256,t_mapping(t_uint256,t_struct(Vote)14520_storage))": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => mapping(uint256 => struct IsolatedGovernance.Vote))", + "numberOfBytes": "32", + "value": "t_mapping(t_uint256,t_struct(Vote)14520_storage)" + }, + "t_mapping(t_uint256,t_struct(MappedToken)11895_storage)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => struct MappedTokenConsumer.MappedToken)", + "numberOfBytes": "32", + "value": "t_struct(MappedToken)11895_storage" + }, + "t_mapping(t_uint256,t_struct(Receipt)15871_storage)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => struct Transfer.Receipt)", + "numberOfBytes": "32", + "value": "t_struct(Receipt)15871_storage" + }, + "t_mapping(t_uint256,t_struct(Vote)14520_storage)": { + "encoding": "mapping", + "key": "t_uint256", + "label": "mapping(uint256 => struct IsolatedGovernance.Vote)", + "numberOfBytes": "32", + "value": "t_struct(Vote)14520_storage" + }, + "t_struct(AddressSet)2949_storage": { + "encoding": "inplace", + "label": "struct EnumerableSet.AddressSet", + "members": [ + { + "astId": 2948, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_inner", + "offset": 0, + "slot": "0", + "type": "t_struct(Set)2648_storage" + } + ], + "numberOfBytes": "64" + }, + "t_struct(Info)15195_storage": { + "encoding": "inplace", + "label": "struct Token.Info", + "members": [ + { + "astId": 15190, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "erc", + "offset": 0, + "slot": "0", + "type": "t_enum(Standard)15187" + }, + { + "astId": 15192, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "id", + "offset": 0, + "slot": "1", + "type": "t_uint256" + }, + { + "astId": 15194, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "quantity", + "offset": 0, + "slot": "2", + "type": "t_uint256" + } + ], + "numberOfBytes": "96" + }, + "t_struct(MappedToken)11895_storage": { + "encoding": "inplace", + "label": "struct MappedTokenConsumer.MappedToken", + "members": [ + { + "astId": 11892, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "erc", + "offset": 0, + "slot": "0", + "type": "t_enum(Standard)15187" + }, + { + "astId": 11894, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "tokenAddr", + "offset": 1, + "slot": "0", + "type": "t_address" + } + ], + "numberOfBytes": "32" + }, + "t_struct(Owner)15642_storage": { + "encoding": "inplace", + "label": "struct Token.Owner", + "members": [ + { + "astId": 15637, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "addr", + "offset": 0, + "slot": "0", + "type": "t_address" + }, + { + "astId": 15639, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "tokenAddr", + "offset": 0, + "slot": "1", + "type": "t_address" + }, + { + "astId": 15641, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "chainId", + "offset": 0, + "slot": "2", + "type": "t_uint256" + } + ], + "numberOfBytes": "96" + }, + "t_struct(Receipt)15871_storage": { + "encoding": "inplace", + "label": "struct Transfer.Receipt", + "members": [ + { + "astId": 15858, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "id", + "offset": 0, + "slot": "0", + "type": "t_uint256" + }, + { + "astId": 15861, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "kind", + "offset": 0, + "slot": "1", + "type": "t_enum(Kind)15668" + }, + { + "astId": 15864, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "mainchain", + "offset": 0, + "slot": "2", + "type": "t_struct(Owner)15642_storage" + }, + { + "astId": 15867, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "ronin", + "offset": 0, + "slot": "5", + "type": "t_struct(Owner)15642_storage" + }, + { + "astId": 15870, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "info", + "offset": 0, + "slot": "8", + "type": "t_struct(Info)15195_storage" + } + ], + "numberOfBytes": "352" + }, + "t_struct(RoleData)19_storage": { + "encoding": "inplace", + "label": "struct AccessControl.RoleData", + "members": [ + { + "astId": 16, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "members", + "offset": 0, + "slot": "0", + "type": "t_mapping(t_address,t_bool)" + }, + { + "astId": 18, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "adminRole", + "offset": 0, + "slot": "1", + "type": "t_bytes32" + } + ], + "numberOfBytes": "64" + }, + "t_struct(Set)2648_storage": { + "encoding": "inplace", + "label": "struct EnumerableSet.Set", + "members": [ + { + "astId": 2643, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_values", + "offset": 0, + "slot": "0", + "type": "t_array(t_bytes32)dyn_storage" + }, + { + "astId": 2647, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "_indexes", + "offset": 0, + "slot": "1", + "type": "t_mapping(t_bytes32,t_uint256)" + } + ], + "numberOfBytes": "64" + }, + "t_struct(Vote)14520_storage": { + "encoding": "inplace", + "label": "struct IsolatedGovernance.Vote", + "members": [ + { + "astId": 14502, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "status", + "offset": 0, + "slot": "0", + "type": "t_enum(VoteStatus)11922" + }, + { + "astId": 14504, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "finalHash", + "offset": 0, + "slot": "1", + "type": "t_bytes32" + }, + { + "astId": 14509, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "voteHashOf", + "offset": 0, + "slot": "2", + "type": "t_mapping(t_address,t_bytes32)" + }, + { + "astId": 14512, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "expiredAt", + "offset": 0, + "slot": "3", + "type": "t_uint256" + }, + { + "astId": 14515, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "createdAt", + "offset": 0, + "slot": "4", + "type": "t_uint256" + }, + { + "astId": 14519, + "contract": "contracts/ronin/gateway/RoninGatewayV3.sol:RoninGatewayV3", + "label": "voters", + "offset": 0, + "slot": "5", + "type": "t_array(t_address)dyn_storage" + } + ], + "numberOfBytes": "192" + }, + "t_uint256": { + "encoding": "inplace", + "label": "uint256", + "numberOfBytes": "32" + }, + "t_uint8": { + "encoding": "inplace", + "label": "uint8", + "numberOfBytes": "1" + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/RoninGatewayV3Proxy.json b/deployments/ronin-mainnet/RoninGatewayV3Proxy.json new file mode 100644 index 000000000..4be2b0ec7 --- /dev/null +++ b/deployments/ronin-mainnet/RoninGatewayV3Proxy.json @@ -0,0 +1,332 @@ +{ + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "_logic", + "type": "address" + }, + { + "internalType": "address", + "name": "admin_", + "type": "address" + }, + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "stateMutability": "payable", + "type": "constructor" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "address", + "name": "previousAdmin", + "type": "address" + }, + { + "indexed": false, + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "AdminChanged", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "beacon", + "type": "address" + } + ], + "name": "BeaconUpgraded", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "implementation", + "type": "address" + } + ], + "name": "Upgraded", + "type": "event" + }, + { + "stateMutability": "payable", + "type": "fallback" + }, + { + "inputs": [], + "name": "admin", + "outputs": [ + { + "internalType": "address", + "name": "admin_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newAdmin", + "type": "address" + } + ], + "name": "changeAdmin", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "bytes", + "name": "_data", + "type": "bytes" + } + ], + "name": "functionDelegateCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "inputs": [], + "name": "implementation", + "outputs": [ + { + "internalType": "address", + "name": "implementation_", + "type": "address" + } + ], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + } + ], + "name": "upgradeTo", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "newImplementation", + "type": "address" + }, + { + "internalType": "bytes", + "name": "data", + "type": "bytes" + } + ], + "name": "upgradeToAndCall", + "outputs": [], + "stateMutability": "payable", + "type": "function" + }, + { + "stateMutability": "payable", + "type": "receive" + } + ], + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "receipt": { + "to": null, + "from": "0x0F68eDBE14C8f68481771016d7E2871d6a35DE11", + "contractAddress": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "transactionIndex": 8, + "gasUsed": "1187047", + "logsBloom": "0x40200004000000000000000000000000400000000000000000200000000400000000080000002000800000000000000000010000000000000000000000080400040000020000000000000000000002000000000000000000000400000000080000000000020000000000000000000800000040800000000000000000000000000000000000000000008000001000000000000000000000000008000000800000000000000000001000010000000000410200000000000000001000000000000041080020000000000000000000000000001000000400000108000800400020000000000000000000000001000080000000000004800000008000004000000000", + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb", + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "logs": [ + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0xbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b", + "0x00000000000000000000000075d23c8830bf28e5b88340638efc0f36e026b8a0" + ], + "data": "0x", + "logIndex": 15, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x000000000000000000000000ed4a9f48a62fb6fdcfb45bb00c9f61d1a436e58c", + "0x0000000000000000000000000f68edbe14c8f68481771016d7e2871d6a35de11" + ], + "data": "0x", + "logIndex": 16, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0xef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169" + ], + "data": "0x0000000000000000000000007f13232bdc3a010c3f749a1c25bf99f1c053ce70", + "logIndex": 17, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8", + "0x0000000000000000000000000000000000000000000000000000000000000000", + "0x0000000000000000000000000000000000000000000000000000000000000046", + "0x0000000000000000000000000000000000000000000000000000000000000064" + ], + "data": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 18, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x2544bff60c6d5b84946e06804af9f84e150bbee85238dbdee79efca4e0adf401" + ], + "data": "0x0000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001c000000000000000000000000000000000000000000000000000000000000002600000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c99a6a985ed2cac1ef41640596c5a5f9f4e19ef5000000000000000000000000a8754b9fa15fc18bb59458815510e40a12cd201400000000000000000000000097a9107c1793bc407d6f527b77e7fff4d812bece0000000000000000000000000b7007c13325c48911f73a2dad5fa5dcbf808adc0000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb480000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "logIndex": 19, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x6f52f53a938df83439fa4c6055c7df0a6906d621aa6dfa4708187037fdfc41da" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c99a6a985ed2cac1ef41640596c5a5f9f4e19ef5000000000000000000000000a8754b9fa15fc18bb59458815510e40a12cd201400000000000000000000000097a9107c1793bc407d6f527b77e7fff4d812bece0000000000000000000000000b7007c13325c48911f73a2dad5fa5dcbf808adc0000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000002386f26fc100000000000000000000000000000000000000000000000000000000000000000ab300000000000000000000000000000000000000000000000009da6d3cfe8700000000000000000000000000000000000000000000000000000000000000989680", + "logIndex": 20, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d", + "0x384495a48d92b97cd9b9d199c73ed783dd1aa0076a6ebcf9156ca7fef7d2cc40", + "0x000000000000000000000000ae8db4d9d3067a33a8241e415e65f0c69cfbb8e1", + "0x0000000000000000000000000f68edbe14c8f68481771016d7e2871d6a35de11" + ], + "data": "0x", + "logIndex": 21, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + }, + { + "transactionIndex": 8, + "blockNumber": 14765762, + "transactionHash": "0xb6cb6f8b5f2414589d26802c66c2d84c91ae0927be205512dff75080385156a3", + "address": "0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df", + "topics": [ + "0x7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f" + ], + "data": "0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000084390b8cf3e612e8c80d9ea2e92bcd029151404a", + "logIndex": 22, + "blockHash": "0x918662e14b538e4abaae71051f02d7b22b7332f5cdc59f608331e4bebb52bffb" + } + ], + "blockNumber": 14765762, + "cumulativeGasUsed": "2446859", + "status": 1, + "byzantium": true + }, + "args": [ + "0x75d23C8830BF28E5b88340638efC0f36e026B8a0", + "0x84390B8CF3E612e8c80D9EA2E92bcd029151404a", + "0xe22fe336000000000000000000000000ed4a9f48a62fb6fdcfb45bb00c9f61d1a436e58c0000000000000000000000007f13232bdc3a010c3f749a1c25bf99f1c053ce70000000000000000000000000000000000000000000000000000000000000004600000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000014000000000000000000000000000000000000000000000000000000000000002c000000000000000000000000000000000000000000000000000000000000004400000000000000000000000000000000000000000000000000000000000000001000000000000000000000000ae8db4d9d3067a33a8241e415e65f0c69cfbb8e1000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c99a6a985ed2cac1ef41640596c5a5f9f4e19ef5000000000000000000000000a8754b9fa15fc18bb59458815510e40a12cd201400000000000000000000000097a9107c1793bc407d6f527b77e7fff4d812bece0000000000000000000000000b7007c13325c48911f73a2dad5fa5dcbf808adc0000000000000000000000000000000000000000000000000000000000000004000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000cc8fa225d80b9c7d42f96e9570156c65d6caaa25000000000000000000000000bb0e17ef65f82ab018d8edd776e8dd940327b28b000000000000000000000000a0b86991c6218b36c1d19d4a2e9eb0ce3606eb48000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000002386f26fc100000000000000000000000000000000000000000000000000000000000000000ab300000000000000000000000000000000000000000000000009da6d3cfe870000000000000000000000000000000000000000000000000000000000000098968000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000" + ], + "numDeployments": 2, + "solcInputHash": "267ddc12ed25de7b99c302796e5ae6c1", + "metadata": "{\"compiler\":{\"version\":\"0.8.9+commit.e5eed63a\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_logic\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"stateMutability\":\"payable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"previousAdmin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"AdminChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"beacon\",\"type\":\"address\"}],\"name\":\"BeaconUpgraded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"implementation\",\"type\":\"address\"}],\"name\":\"Upgraded\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"admin\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"admin_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newAdmin\",\"type\":\"address\"}],\"name\":\"changeAdmin\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bytes\",\"name\":\"_data\",\"type\":\"bytes\"}],\"name\":\"functionDelegateCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"implementation\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"implementation_\",\"type\":\"address\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"}],\"name\":\"upgradeTo\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"newImplementation\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"upgradeToAndCall\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"admin()\":{\"details\":\"Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\"},\"changeAdmin(address)\":{\"details\":\"Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\"},\"functionDelegateCall(bytes)\":{\"details\":\"Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function.\"},\"implementation()\":{\"details\":\"Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\"},\"upgradeTo(address)\":{\"details\":\"Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\"},\"upgradeToAndCall(address,bytes)\":{\"details\":\"Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{\"functionDelegateCall(bytes)\":{\"notice\":\"The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this.\"}},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/v0.8/extensions/TransparentUpgradeableProxyV2.sol\":\"TransparentUpgradeableProxyV2\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":1000},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializating the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n assert(_IMPLEMENTATION_SLOT == bytes32(uint256(keccak256(\\\"eip1967.proxy.implementation\\\")) - 1));\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0x6309f9f39dc6f4f45a24f296543867aa358e32946cd6b2874627a996d606b3a0\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overriden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internall call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overriden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0x0edeb16b9821ae2b16e9d69c383b38d3ad2fbb3e0c06cf809a0786d96e602551\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n assert(_ADMIN_SLOT == bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0x140055a64cf579d622e04f5a198595832bf2cb193cd0005f4f2d4d61ca906253\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2ccf9d2313a313d41a791505f2b5abfdc62191b5d4334f7f7a82691c088a1c87\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xfe1b7a9aa2a530a9e705b220e26cd584e2fbdc9602a3a1066032b12816b46aca\",\"license\":\"MIT\"},\"contracts/v0.8/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * @notice The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xdf52e28697a1af7d7e176d35df4cfa2eee79a19eb74df6eac7704953d3583449\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x6080604052604051620011353803806200113583398101604081905262000026916200051f565b82828282816200005860017f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbd620005ff565b600080516020620010ee8339815191521462000078576200007862000625565b6200008682826000620000ed565b50620000b6905060017fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6104620005ff565b600080516020620010ce83398151915214620000d657620000d662000625565b620000e1826200012a565b5050505050506200068e565b620000f88362000185565b600082511180620001065750805b156200012557620001238383620001c760201b620002dd1760201c565b505b505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f62000155620001f6565b604080516001600160a01b03928316815291841660208301520160405180910390a162000182816200022f565b50565b6200019081620002e4565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6060620001ef83836040518060600160405280602781526020016200110e6027913962000387565b9392505050565b600062000220600080516020620010ce83398151915260001b6200046d60201b620002851760201c565b546001600160a01b0316919050565b6001600160a01b0381166200029a5760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201526564647265737360d01b60648201526084015b60405180910390fd5b80620002c3600080516020620010ce83398151915260001b6200046d60201b620002851760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b620002fa816200047060201b620003091760201c565b6200035e5760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201526c1bdd08184818dbdb9d1c9858dd609a1b606482015260840162000291565b80620002c3600080516020620010ee83398151915260001b6200046d60201b620002851760201c565b60606001600160a01b0384163b620003f15760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b606482015260840162000291565b600080856001600160a01b0316856040516200040e91906200063b565b600060405180830381855af49150503d80600081146200044b576040519150601f19603f3d011682016040523d82523d6000602084013e62000450565b606091505b509092509050620004638282866200047f565b9695505050505050565b90565b6001600160a01b03163b151590565b6060831562000490575081620001ef565b825115620004a15782518084602001fd5b8160405162461bcd60e51b815260040162000291919062000659565b80516001600160a01b0381168114620004d557600080fd5b919050565b634e487b7160e01b600052604160045260246000fd5b60005b838110156200050d578181015183820152602001620004f3565b83811115620001235750506000910152565b6000806000606084860312156200053557600080fd5b6200054084620004bd565b92506200055060208501620004bd565b60408501519092506001600160401b03808211156200056e57600080fd5b818601915086601f8301126200058357600080fd5b815181811115620005985762000598620004da565b604051601f8201601f19908116603f01168101908382118183101715620005c357620005c3620004da565b81604052828152896020848701011115620005dd57600080fd5b620005f0836020830160208801620004f0565b80955050505050509250925092565b6000828210156200062057634e487b7160e01b600052601160045260246000fd5b500390565b634e487b7160e01b600052600160045260246000fd5b600082516200064f818460208701620004f0565b9190910192915050565b60208152600082518060208401526200067a816040850160208701620004f0565b601f01601f19169190910160400192915050565b610a30806200069e6000396000f3fe6080604052600436106100695760003560e01c80635c60da1b116100435780635c60da1b146100c65780638f283970146100f7578063f851a4401461011757610078565b80633659cfe6146100805780634bb5274a146100a05780634f1ef286146100b357610078565b366100785761007661012c565b005b61007661012c565b34801561008c57600080fd5b5061007661009b3660046107da565b610146565b6100766100ae366004610824565b61018d565b6100766100c13660046108d5565b6101dc565b3480156100d257600080fd5b506100db61024d565b6040516001600160a01b03909116815260200160405180910390f35b34801561010357600080fd5b506100766101123660046107da565b610288565b34801561012357600080fd5b506100db6102b2565b610134610318565b61014461013f6103d2565b6103dc565b565b61014e6103fb565b6001600160a01b0316336001600160a01b03161415610185576101828160405180602001604052806000815250600061042e565b50565b61018261012c565b6101956103fb565b6001600160a01b0316336001600160a01b031614156101855760006101b86103d2565b9050600080835160208501845af43d6000803e8080156101d7573d6000f35b3d6000fd5b6101e46103fb565b6001600160a01b0316336001600160a01b03161415610245576102408383838080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152506001925061042e915050565b505050565b61024061012c565b60006102576103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103d2565b905090565b61028561012c565b90565b6102906103fb565b6001600160a01b0316336001600160a01b031614156101855761018281610459565b60006102bc6103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103fb565b606061030283836040518060600160405280602781526020016109d4602791396104ad565b9392505050565b6001600160a01b03163b151590565b6103206103fb565b6001600160a01b0316336001600160a01b031614156101445760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f7879207461726760648201527f6574000000000000000000000000000000000000000000000000000000000000608482015260a4015b60405180910390fd5b60006102786105a1565b3660008037600080366000845af43d6000803e8080156101d7573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b610437836105c9565b6000825111806104445750805b156102405761045383836102dd565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f6104826103fb565b604080516001600160a01b03928316815291841660208301520160405180910390a161018281610609565b60606001600160a01b0384163b61052c5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f60448201527f6e7472616374000000000000000000000000000000000000000000000000000060648201526084016103c9565b600080856001600160a01b0316856040516105479190610984565b600060405180830381855af49150503d8060008114610582576040519150601f19603f3d011682016040523d82523d6000602084013e610587565b606091505b50915091506105978282866106e1565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc61041f565b6105d28161071a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166106855760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016103c9565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b039290921691909117905550565b606083156106f0575081610302565b8251156107005782518084602001fd5b8160405162461bcd60e51b81526004016103c991906109a0565b6001600160a01b0381163b6107975760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201527f6f74206120636f6e74726163740000000000000000000000000000000000000060648201526084016103c9565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6106a8565b80356001600160a01b03811681146107d557600080fd5b919050565b6000602082840312156107ec57600080fd5b610302826107be565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b60006020828403121561083657600080fd5b813567ffffffffffffffff8082111561084e57600080fd5b818401915084601f83011261086257600080fd5b813581811115610874576108746107f5565b604051601f8201601f19908116603f0116810190838211818310171561089c5761089c6107f5565b816040528281528760208487010111156108b557600080fd5b826020860160208301376000928101602001929092525095945050505050565b6000806000604084860312156108ea57600080fd5b6108f3846107be565b9250602084013567ffffffffffffffff8082111561091057600080fd5b818601915086601f83011261092457600080fd5b81358181111561093357600080fd5b87602082850101111561094557600080fd5b6020830194508093505050509250925092565b60005b8381101561097357818101518382015260200161095b565b838111156104535750506000910152565b60008251610996818460208701610958565b9190910192915050565b60208152600082518060208401526109bf816040850160208701610958565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203b097b88c1cee26a495ec73a23404fc321233caf781f72087a86ad15c85d8f1d64736f6c63430008090033b53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564", + "deployedBytecode": "0x6080604052600436106100695760003560e01c80635c60da1b116100435780635c60da1b146100c65780638f283970146100f7578063f851a4401461011757610078565b80633659cfe6146100805780634bb5274a146100a05780634f1ef286146100b357610078565b366100785761007661012c565b005b61007661012c565b34801561008c57600080fd5b5061007661009b3660046107da565b610146565b6100766100ae366004610824565b61018d565b6100766100c13660046108d5565b6101dc565b3480156100d257600080fd5b506100db61024d565b6040516001600160a01b03909116815260200160405180910390f35b34801561010357600080fd5b506100766101123660046107da565b610288565b34801561012357600080fd5b506100db6102b2565b610134610318565b61014461013f6103d2565b6103dc565b565b61014e6103fb565b6001600160a01b0316336001600160a01b03161415610185576101828160405180602001604052806000815250600061042e565b50565b61018261012c565b6101956103fb565b6001600160a01b0316336001600160a01b031614156101855760006101b86103d2565b9050600080835160208501845af43d6000803e8080156101d7573d6000f35b3d6000fd5b6101e46103fb565b6001600160a01b0316336001600160a01b03161415610245576102408383838080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152506001925061042e915050565b505050565b61024061012c565b60006102576103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103d2565b905090565b61028561012c565b90565b6102906103fb565b6001600160a01b0316336001600160a01b031614156101855761018281610459565b60006102bc6103fb565b6001600160a01b0316336001600160a01b0316141561027d576102786103fb565b606061030283836040518060600160405280602781526020016109d4602791396104ad565b9392505050565b6001600160a01b03163b151590565b6103206103fb565b6001600160a01b0316336001600160a01b031614156101445760405162461bcd60e51b815260206004820152604260248201527f5472616e73706172656e745570677261646561626c6550726f78793a2061646d60448201527f696e2063616e6e6f742066616c6c6261636b20746f2070726f7879207461726760648201527f6574000000000000000000000000000000000000000000000000000000000000608482015260a4015b60405180910390fd5b60006102786105a1565b3660008037600080366000845af43d6000803e8080156101d7573d6000f35b60007fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b546001600160a01b0316919050565b610437836105c9565b6000825111806104445750805b156102405761045383836102dd565b50505050565b7f7e644d79422f17c01e4894b5f4f588d331ebfa28653d42ae832dc59e38c9798f6104826103fb565b604080516001600160a01b03928316815291841660208301520160405180910390a161018281610609565b60606001600160a01b0384163b61052c5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f60448201527f6e7472616374000000000000000000000000000000000000000000000000000060648201526084016103c9565b600080856001600160a01b0316856040516105479190610984565b600060405180830381855af49150503d8060008114610582576040519150601f19603f3d011682016040523d82523d6000602084013e610587565b606091505b50915091506105978282866106e1565b9695505050505050565b60007f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc61041f565b6105d28161071a565b6040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a250565b6001600160a01b0381166106855760405162461bcd60e51b815260206004820152602660248201527f455243313936373a206e65772061646d696e20697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016103c9565b807fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d61035b80547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b039290921691909117905550565b606083156106f0575081610302565b8251156107005782518084602001fd5b8160405162461bcd60e51b81526004016103c991906109a0565b6001600160a01b0381163b6107975760405162461bcd60e51b815260206004820152602d60248201527f455243313936373a206e657720696d706c656d656e746174696f6e206973206e60448201527f6f74206120636f6e74726163740000000000000000000000000000000000000060648201526084016103c9565b807f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc6106a8565b80356001600160a01b03811681146107d557600080fd5b919050565b6000602082840312156107ec57600080fd5b610302826107be565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b60006020828403121561083657600080fd5b813567ffffffffffffffff8082111561084e57600080fd5b818401915084601f83011261086257600080fd5b813581811115610874576108746107f5565b604051601f8201601f19908116603f0116810190838211818310171561089c5761089c6107f5565b816040528281528760208487010111156108b557600080fd5b826020860160208301376000928101602001929092525095945050505050565b6000806000604084860312156108ea57600080fd5b6108f3846107be565b9250602084013567ffffffffffffffff8082111561091057600080fd5b818601915086601f83011261092457600080fd5b81358181111561093357600080fd5b87602082850101111561094557600080fd5b6020830194508093505050509250925092565b60005b8381101561097357818101518382015260200161095b565b838111156104535750506000910152565b60008251610996818460208701610958565b9190910192915050565b60208152600082518060208401526109bf816040850160208701610958565b601f01601f1916919091016040019291505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203b097b88c1cee26a495ec73a23404fc321233caf781f72087a86ad15c85d8f1d64736f6c63430008090033", + "devdoc": { + "kind": "dev", + "methods": { + "admin()": { + "details": "Returns the current admin. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`" + }, + "changeAdmin(address)": { + "details": "Changes the admin of the proxy. Emits an {AdminChanged} event. NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}." + }, + "functionDelegateCall(bytes)": { + "details": "Calls a function from the current implementation as specified by `_data`, which should be an encoded function call. Requirements: - Only the admin can call this function." + }, + "implementation()": { + "details": "Returns the current implementation. NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}. TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call. `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`" + }, + "upgradeTo(address)": { + "details": "Upgrade the implementation of the proxy. NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}." + }, + "upgradeToAndCall(address,bytes)": { + "details": "Upgrade the implementation of the proxy, and then call a function from the new implementation as specified by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the proxied contract. NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}." + } + }, + "version": 1 + }, + "userdoc": { + "kind": "user", + "methods": { + "functionDelegateCall(bytes)": { + "notice": "The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider reviewing the encoded data `_data` and the method which is called before using this." + } + }, + "version": 1 + }, + "storageLayout": { + "storage": [], + "types": null + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/RoninTrustedOrganizationLogic.json b/deployments/ronin-mainnet/RoninTrustedOrganizationLogic.json index 96fa43694..4742374bc 100644 --- a/deployments/ronin-mainnet/RoninTrustedOrganizationLogic.json +++ b/deployments/ronin-mainnet/RoninTrustedOrganizationLogic.json @@ -1,6 +1,119 @@ { - "address": "0x877A15cD0bf1667BaaB50b4C85FD79125c47b7B3", + "address": "0x0AaDA85A2b3c9fb1be158D43e71cdcca6Fe85e02", "abi": [ + { + "inputs": [ + { + "internalType": "address", + "name": "voter", + "type": "address" + } + ], + "name": "ErrBridgeVoterIsAlreadyAdded", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrConsensusAddressIsAlreadyAdded", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrConsensusAddressIsNotAdded", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrDuplicated", + "type": "error" + }, + { + "inputs": [], + "name": "ErrEmptyArray", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ErrGovernorAddressIsAlreadyAdded", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidRequest", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidVoteWeight", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForDupplicated", + "type": "error" + }, + { + "inputs": [], + "name": "ErrQueryForNonExistentConsensusAddress", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, { "anonymous": false, "inputs": [ @@ -205,7 +318,7 @@ }, { "inputs": [], - "name": "countTrustedOrganizations", + "name": "countTrustedOrganization", "outputs": [ { "internalType": "uint256", @@ -593,7 +706,7 @@ "type": "address[]" } ], - "name": "sumBridgeVoterWeights", + "name": "sumBridgeVoterWeight", "outputs": [ { "internalType": "uint256", @@ -612,7 +725,7 @@ "type": "address[]" } ], - "name": "sumConsensusWeights", + "name": "sumConsensusWeight", "outputs": [ { "internalType": "uint256", @@ -631,7 +744,7 @@ "type": "address[]" } ], - "name": "sumGovernorWeights", + "name": "sumGovernorWeight", "outputs": [ { "internalType": "uint256", @@ -644,7 +757,7 @@ }, { "inputs": [], - "name": "totalWeights", + "name": "totalWeight", "outputs": [ { "internalType": "uint256", @@ -696,29 +809,116 @@ "type": "function" } ], - "transactionHash": "0xdf5e1aac15251234404eba4f7200f2569c27679c37baabbefd4b533ff6cf9241", + "transactionHash": "0xa02a9cb84db06e4d277bfd8eebcda2bdd6ea3dc1e98670bf7f4b526ffc5cfca5", "receipt": { "to": null, - "from": "0x0F68eDBE14C8f68481771016d7E2871d6a35DE11", - "contractAddress": "0x877A15cD0bf1667BaaB50b4C85FD79125c47b7B3", - "transactionIndex": 2, - "gasUsed": "2119207", + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x0AaDA85A2b3c9fb1be158D43e71cdcca6Fe85e02", + "transactionIndex": 1, + "gasUsed": "1749401", "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0x2be871a69164ae9b369265e177e12a3be72e2622ce71bc0cfc27a244a9fe819f", - "transactionHash": "0xdf5e1aac15251234404eba4f7200f2569c27679c37baabbefd4b533ff6cf9241", + "blockHash": "0x464be23b57042898cb44c511258bfbf4153681c3bd50b285abdda89d2a3eb4fa", + "transactionHash": "0xa02a9cb84db06e4d277bfd8eebcda2bdd6ea3dc1e98670bf7f4b526ffc5cfca5", "logs": [], - "blockNumber": 22608297, - "cumulativeGasUsed": "2162823", + "blockNumber": 28538521, + "cumulativeGasUsed": "1800398", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 1, - "solcInputHash": "a50a3f056fa24c0b5a230a9cb29a1cb4", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"orgs\",\"type\":\"tuple[]\"}],\"name\":\"TrustedOrganizationsAdded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"orgs\",\"type\":\"address[]\"}],\"name\":\"TrustedOrganizationsRemoved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"orgs\",\"type\":\"tuple[]\"}],\"name\":\"TrustedOrganizationsUpdated\",\"type\":\"event\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"name\":\"addTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"countTrustedOrganizations\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getAllTrustedOrganizations\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"getBridgeVoterWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getBridgeVoterWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getConsensusWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getConsensusWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_governor\",\"type\":\"address\"}],\"name\":\"getGovernorWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getGovernorWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getTrustedOrganization\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_idx\",\"type\":\"uint256\"}],\"name\":\"getTrustedOrganizationAt\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_trustedOrgs\",\"type\":\"tuple[]\"},{\"internalType\":\"uint256\",\"name\":\"__num\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__denom\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"removeTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumBridgeVoterWeights\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumConsensusWeights\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumGovernorWeights\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalWeights\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"name\":\"updateTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"kind\":\"dev\",\"methods\":{\"addTrustedOrganizations((address,address,address,uint256,uint256)[])\":{\"details\":\"Adds a list of addresses into the trusted organization. Requirements: - The weights should larger than 0. - The method caller is admin. - The field `addedBlock` should be blank. Emits the event `TrustedOrganizationAdded` once an organization is added.\"},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"countTrustedOrganizations()\":{\"details\":\"Returns the number of trusted organizations.\"},\"getAllTrustedOrganizations()\":{\"details\":\"Returns all of the trusted organizations.\"},\"getBridgeVoterWeight(address)\":{\"details\":\"Returns the weight of a bridge voter.\"},\"getBridgeVoterWeights(address[])\":{\"details\":\"Returns the weights of a list of bridge voter addresses.\"},\"getConsensusWeight(address)\":{\"details\":\"Returns the weight of a consensus.\"},\"getConsensusWeights(address[])\":{\"details\":\"Returns the weights of a list of consensus addresses.\"},\"getGovernorWeight(address)\":{\"details\":\"Returns the weight of a governor.\"},\"getGovernorWeights(address[])\":{\"details\":\"Returns the weights of a list of governor addresses.\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"getTrustedOrganization(address)\":{\"details\":\"Returns the trusted organization by consensus address. Reverts once the consensus address is non-existent.\"},\"getTrustedOrganizationAt(uint256)\":{\"details\":\"Returns the trusted organization at `_index`.\"},\"initialize((address,address,address,uint256,uint256)[],uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"removeTrustedOrganizations(address[])\":{\"details\":\"Removes a list of addresses from the trusted organization. Requirements: - The method caller is admin. Emits the event `TrustedOrganizationRemoved` once an organization is removed.\",\"params\":{\"_consensusAddrs\":\"The list of consensus addresses linked to corresponding trusted organization that to be removed.\"}},\"setThreshold(uint256,uint256)\":{\"details\":\"Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event.\"},\"sumBridgeVoterWeights(address[])\":{\"details\":\"Returns total weights of the bridge voter list.\"},\"sumConsensusWeights(address[])\":{\"details\":\"Returns total weights of the consensus list.\"},\"sumGovernorWeights(address[])\":{\"details\":\"Returns total weights of the governor list.\"},\"totalWeights()\":{\"details\":\"Returns total weights.\"},\"updateTrustedOrganizations((address,address,address,uint256,uint256)[])\":{\"details\":\"Updates weights for a list of existent trusted organization. Requirements: - The weights should larger than 0. - The method caller is admin. Emits the `TrustedOrganizationUpdated` event.\"}},\"stateVariables\":{\"_addedBlock\":{\"details\":\"Mapping from consensus address => added block\"},\"_bridgeVoterList\":{\"details\":\"Bridge voters array\"},\"_bridgeVoterWeight\":{\"details\":\"Mapping from bridge voter address => weight\"},\"_consensusList\":{\"details\":\"Consensus array\"},\"_consensusWeight\":{\"details\":\"Mapping from consensus address => weight\"},\"_governorList\":{\"details\":\"Governors array\"},\"_governorWeight\":{\"details\":\"Mapping from governor address => weight\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/multi-chains/RoninTrustedOrganization.sol\":\"RoninTrustedOrganization\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(uint256 _numerator, uint256 _denominator)\\n external\\n returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x10f3b360430e6d03773c9959f54cbed6fb0346069645c05b05ef50cfb19f3753\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeights() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganizations() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x1edb7a3f5d340e7efc141cb8d94c5499954dec869f026d3998ad92cbc714d604\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool) {\\n bytes32 _thisHash;\\n bytes32 _otherHash;\\n\\n assembly {\\n _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n }\\n\\n return _thisHash == _otherHash;\\n }\\n}\\n\",\"keccak256\":\"0xea4ac2b0783926a0e6ae257bc069fa37ea864ce77bfb25dd327d4727a38ad0ea\",\"license\":\"UNLICENSED\"},\"contracts/multi-chains/RoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/utils/Strings.sol\\\";\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport \\\"../interfaces/IRoninTrustedOrganization.sol\\\";\\nimport \\\"../extensions/collections/HasProxyAdmin.sol\\\";\\n\\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\\n uint256 internal _num;\\n uint256 internal _denom;\\n uint256 internal _totalWeight;\\n uint256 internal _nonce;\\n\\n /// @dev Mapping from consensus address => weight\\n mapping(address => uint256) internal _consensusWeight;\\n /// @dev Mapping from governor address => weight\\n mapping(address => uint256) internal _governorWeight;\\n /// @dev Mapping from bridge voter address => weight\\n mapping(address => uint256) internal _bridgeVoterWeight;\\n\\n /// @dev Mapping from consensus address => added block\\n mapping(address => uint256) internal _addedBlock;\\n\\n /// @dev Consensus array\\n address[] internal _consensusList;\\n /// @dev Governors array\\n address[] internal _governorList;\\n /// @dev Bridge voters array\\n address[] internal _bridgeVoterList;\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n TrustedOrganization[] calldata _trustedOrgs,\\n uint256 __num,\\n uint256 __denom\\n ) external initializer {\\n if (_trustedOrgs.length > 0) {\\n _addTrustedOrganizations(_trustedOrgs);\\n }\\n _setThreshold(__num, __denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (_num, _denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * _denom >= _num * _totalWeight;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() external view virtual returns (uint256) {\\n return (_num * _totalWeight + _denom - 1) / _denom;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(uint256 _numerator, uint256 _denominator)\\n external\\n override\\n onlyAdmin\\n returns (uint256, uint256)\\n {\\n return _setThreshold(_numerator, _denominator);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\\n _addTrustedOrganizations(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\\n require(_list.length > 0, \\\"RoninTrustedOrganization: invalid array length\\\");\\n for (uint256 _i; _i < _list.length; _i++) {\\n _updateTrustedOrganization(_list[_i]);\\n }\\n emit TrustedOrganizationsUpdated(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\\n require(_list.length > 0, \\\"RoninTrustedOrganization: invalid array length\\\");\\n for (uint _i = 0; _i < _list.length; _i++) {\\n _removeTrustedOrganization(_list[_i]);\\n }\\n emit TrustedOrganizationsRemoved(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function totalWeights() external view virtual returns (uint256) {\\n return _totalWeight;\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\\n return _consensusWeight[_consensusAddr];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256) {\\n return _governorWeight[_governor];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\\n return _bridgeVoterWeight[_addr];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; _i++) {\\n _res[_i] = _consensusWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; _i++) {\\n _res[_i] = _governorWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; _i++) {\\n _res[_i] = _bridgeVoterWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumConsensusWeights(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; _i++) {\\n _res += _consensusWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumGovernorWeights(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; _i++) {\\n _res += _governorWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumBridgeVoterWeights(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; _i++) {\\n _res += _bridgeVoterWeight[_list[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function countTrustedOrganizations() external view override returns (uint256) {\\n return _consensusList.length;\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\\n _list = new TrustedOrganization[](_consensusList.length);\\n address _addr;\\n for (uint256 _i; _i < _list.length; _i++) {\\n _addr = _consensusList[_i];\\n _list[_i].consensusAddr = _addr;\\n _list[_i].governor = _governorList[_i];\\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\\n _list[_i].weight = _consensusWeight[_addr];\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\\n for (uint _i = 0; _i < _consensusList.length; _i++) {\\n if (_consensusList[_i] == _consensusAddr) {\\n return getTrustedOrganizationAt(_i);\\n }\\n }\\n revert(\\\"RoninTrustedOrganization: query for non-existent consensus address\\\");\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\\n address _addr = _consensusList[_idx];\\n return\\n TrustedOrganization(\\n _addr,\\n _governorList[_idx],\\n _bridgeVoterList[_idx],\\n _consensusWeight[_addr],\\n _addedBlock[_addr]\\n );\\n }\\n\\n /**\\n * @dev Adds a list of trusted organizations.\\n */\\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\\n for (uint256 _i; _i < _list.length; _i++) {\\n _addTrustedOrganization(_list[_i]);\\n }\\n emit TrustedOrganizationsAdded(_list);\\n }\\n\\n /**\\n * @dev Adds a trusted organization.\\n *\\n * Requirements:\\n * - The weight is larger than 0.\\n * - The consensus address is not added.\\n * - The govenor address is not added.\\n * - The bridge voter address is not added.\\n *\\n */\\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\\n require(_v.addedBlock == 0, \\\"RoninTrustedOrganization: invalid request\\\");\\n _sanityCheckTrustedOrganizationData(_v);\\n\\n if (_consensusWeight[_v.consensusAddr] > 0) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"RoninTrustedOrganization: consensus address \\\",\\n Strings.toHexString(uint160(_v.consensusAddr), 20),\\n \\\" is added already\\\"\\n )\\n )\\n );\\n }\\n\\n if (_governorWeight[_v.governor] > 0) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"RoninTrustedOrganization: govenor address \\\",\\n Strings.toHexString(uint160(_v.governor), 20),\\n \\\" is added already\\\"\\n )\\n )\\n );\\n }\\n\\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"RoninTrustedOrganization: bridge voter address \\\",\\n Strings.toHexString(uint160(_v.bridgeVoter), 20),\\n \\\" is added already\\\"\\n )\\n )\\n );\\n }\\n\\n _consensusList.push(_v.consensusAddr);\\n _consensusWeight[_v.consensusAddr] = _v.weight;\\n\\n _governorList.push(_v.governor);\\n _governorWeight[_v.governor] = _v.weight;\\n\\n _bridgeVoterList.push(_v.bridgeVoter);\\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\\n\\n _addedBlock[_v.consensusAddr] = block.number;\\n\\n _totalWeight += _v.weight;\\n }\\n\\n /**\\n * @dev Updates a trusted organization.\\n *\\n * Requirements:\\n * - The weight is larger than 0.\\n * - The consensus address is already added.\\n *\\n */\\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\\n _sanityCheckTrustedOrganizationData(_v);\\n\\n uint256 _weight = _consensusWeight[_v.consensusAddr];\\n if (_weight == 0) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"RoninTrustedOrganization: consensus address \\\",\\n Strings.toHexString(uint160(_v.consensusAddr), 20),\\n \\\" is not added\\\"\\n )\\n )\\n );\\n }\\n\\n uint256 _count = _consensusList.length;\\n for (uint256 _i = 0; _i < _count; _i++) {\\n if (_consensusList[_i] == _v.consensusAddr) {\\n _totalWeight -= _weight;\\n _totalWeight += _v.weight;\\n\\n if (_governorList[_i] != _v.governor) {\\n require(_governorWeight[_v.governor] == 0, \\\"RoninTrustedOrganization: query for duplicated governor\\\");\\n delete _governorWeight[_governorList[_i]];\\n _governorList[_i] = _v.governor;\\n }\\n\\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\\n require(\\n _bridgeVoterWeight[_v.bridgeVoter] == 0,\\n \\\"RoninTrustedOrganization: query for duplicated bridge voter\\\"\\n );\\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\\n _bridgeVoterList[_i] = _v.bridgeVoter;\\n }\\n\\n _consensusWeight[_v.consensusAddr] = _v.weight;\\n _governorWeight[_v.governor] = _v.weight;\\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\\n return;\\n }\\n }\\n }\\n\\n /**\\n * @dev Removes a trusted organization.\\n *\\n * Requirements:\\n * - The consensus address is added.\\n *\\n */\\n function _removeTrustedOrganization(address _addr) internal virtual {\\n uint256 _weight = _consensusWeight[_addr];\\n if (_weight == 0) {\\n revert(\\n string(\\n abi.encodePacked(\\n \\\"RoninTrustedOrganization: consensus address \\\",\\n Strings.toHexString(uint160(_addr), 20),\\n \\\" is not added\\\"\\n )\\n )\\n );\\n }\\n\\n uint256 _index;\\n uint256 _count = _consensusList.length;\\n for (uint256 _i = 0; _i < _count; _i++) {\\n if (_consensusList[_i] == _addr) {\\n _index = _i;\\n break;\\n }\\n }\\n\\n _totalWeight -= _weight;\\n\\n delete _addedBlock[_addr];\\n delete _consensusWeight[_addr];\\n _consensusList[_index] = _consensusList[_count - 1];\\n _consensusList.pop();\\n\\n delete _governorWeight[_governorList[_index]];\\n _governorList[_index] = _governorList[_count - 1];\\n _governorList.pop();\\n\\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\\n _bridgeVoterList.pop();\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(uint256 _numerator, uint256 _denominator)\\n internal\\n virtual\\n returns (uint256 _previousNum, uint256 _previousDenom)\\n {\\n require(_numerator <= _denominator, \\\"RoninTrustedOrganization: invalid threshold\\\");\\n _previousNum = _num;\\n _previousDenom = _denom;\\n _num = _numerator;\\n _denom = _denominator;\\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\\n }\\n\\n /**\\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\\n *\\n * Requirements:\\n * - The weight must be larger than 0.\\n * - The consensus address, governor address, and bridge voter address are different.\\n */\\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\\n require(_v.weight > 0, \\\"RoninTrustedOrganization: invalid weight\\\");\\n\\n address[] memory _addresses = new address[](3);\\n _addresses[0] = _v.consensusAddr;\\n _addresses[1] = _v.governor;\\n _addresses[2] = _v.bridgeVoter;\\n require(!AddressArrayUtils.hasDuplicate(_addresses), \\\"RoninTrustedOrganization: three addresses must be distinct\\\");\\n }\\n}\\n\",\"keccak256\":\"0xcdc122c399d55a5c7ff9bb96a2e7c99c99b3814edcd1a4e24c6e021bacd15c32\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x608060405234801561001057600080fd5b5061255e806100206000396000f3fe608060405234801561001057600080fd5b50600436106101125760003560e01c80630ed285df14610117578063150740051461012c57806341feed1c1461014a578063520fce621461018157806356241911146101a15780635f14a1c3146101ca57806370823625146101dd5780637c37103c146101f05780637de5dedd14610203578063926323d51461020b578063a85c7d6e14610213578063b505a07c14610226578063b9c3620914610239578063cacf8fb514610261578063cc7e6b3b14610269578063d78392f81461027c578063d9d5dadb146102a5578063dafae408146102b8578063db6693a2146102db578063e75235b8146102fb578063e8c0685e14610306578063f09267c214610319575b600080fd5b61012a610125366004611ddc565b61032c565b005b61013461037b565b6040516101419190611e5a565b60405180910390f35b610173610158366004611ec4565b6001600160a01b031660009081526005602052604090205490565b604051908152602001610141565b61019461018f366004611edf565b610550565b6040516101419190611f53565b6101736101af366004611ec4565b6001600160a01b031660009081526007602052604090205490565b6101736101d8366004611edf565b610624565b6101946101eb366004611edf565b610693565b61012a6101fe366004611f8b565b610760565b610173610889565b600354610173565b61012a610221366004611edf565b6108c6565b61012a610234366004611ddc565b6109a5565b61024c610247366004611fdb565b610a79565b60408051928352602083019190915201610141565b600954610173565b610194610277366004611edf565b610aca565b61017361028a366004611ec4565b6001600160a01b031660009081526006602052604090205490565b6101736102b3366004611edf565b610b97565b6102cb6102c6366004611ffd565b610c06565b6040519015158152602001610141565b6102ee6102e9366004611ec4565b610c2d565b6040516101419190612016565b60015460025461024c565b610173610314366004611edf565b610d03565b6102ee610327366004611ffd565b610d72565b610334610e55565b6001600160a01b0316336001600160a01b03161461036d5760405162461bcd60e51b815260040161036490612024565b60405180910390fd5b6103778282610e83565b5050565b6009546060906001600160401b0381111561039857610398612066565b6040519080825280602002602001820160405280156103d157816020015b6103be611d6a565b8152602001906001900390816103b65790505b5090506000805b825181101561054b57600981815481106103f4576103f461207c565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104275761042761207c565b60209081029190910101516001600160a01b039091169052600a8054829081106104535761045361207c565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106104835761048361207c565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b81815481106104ba576104ba61207c565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106104ea576104ea61207c565b6020908102919091018101516001600160a01b03928316604091820152918416600090815260059091522054835184908390811061052a5761052a61207c565b60209081029190910101516060015280610543816120a8565b9150506103d8565b505090565b6060816001600160401b0381111561056a5761056a612066565b604051908082528060200260200182016040528015610593578160200160208202803683370190505b50905060005b815181101561061d57600560008585848181106105b8576105b861207c565b90506020020160208101906105cd9190611ec4565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106106005761060061207c565b602090810291909101015280610615816120a8565b915050610599565b5092915050565b6000805b8281101561061d57600660008585848181106106465761064661207c565b905060200201602081019061065b9190611ec4565b6001600160a01b0316815260208101919091526040016000205461067f90836120c1565b91508061068b816120a8565b915050610628565b6060816001600160401b038111156106ad576106ad612066565b6040519080825280602002602001820160405280156106d6578160200160208202803683370190505b50905060005b815181101561061d57600760008585848181106106fb576106fb61207c565b90506020020160208101906107109190611ec4565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107435761074361207c565b602090810291909101015280610758816120a8565b9150506106dc565b600054610100900460ff16158080156107805750600054600160ff909116105b8061079a5750303b15801561079a575060005460ff166001145b6107fd5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610364565b6000805460ff191660011790558015610820576000805461ff0019166101001790555b8315610830576108308585610e83565b61083a8383610f02565b50508015610882576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546108a391906120d4565b6108ad91906120c1565b6108b791906120eb565b6108c191906120fe565b905090565b6108ce610e55565b6001600160a01b0316336001600160a01b0316146108fe5760405162461bcd60e51b815260040161036490612024565b8061091b5760405162461bcd60e51b815260040161036490612120565b60005b818110156109675761095583838381811061093b5761093b61207c565b90506020020160208101906109509190611ec4565b610fc3565b8061095f816120a8565b91505061091e565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a7828260405161099992919061215c565b60405180910390a15050565b6109ad610e55565b6001600160a01b0316336001600160a01b0316146109dd5760405162461bcd60e51b815260040161036490612024565b806109fa5760405162461bcd60e51b815260040161036490612120565b60005b81811015610a4757610a35838383818110610a1a57610a1a61207c565b905060a00201803603810190610a3091906121a8565b611355565b80610a3f816120a8565b9150506109fd565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610999929190612238565b600080610a84610e55565b6001600160a01b0316336001600160a01b031614610ab45760405162461bcd60e51b815260040161036490612024565b610abe8484610f02565b915091505b9250929050565b6060816001600160401b03811115610ae457610ae4612066565b604051908082528060200260200182016040528015610b0d578160200160208202803683370190505b50905060005b815181101561061d5760066000858584818110610b3257610b3261207c565b9050602002016020810190610b479190611ec4565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610b7a57610b7a61207c565b602090810291909101015280610b8f816120a8565b915050610b13565b6000805b8281101561061d5760076000858584818110610bb957610bb961207c565b9050602002016020810190610bce9190611ec4565b6001600160a01b03168152602081019190915260400160002054610bf290836120c1565b915080610bfe816120a8565b915050610b9b565b6000600354600154610c1891906120d4565b600254610c2590846120d4565b101592915050565b610c35611d6a565b60005b600954811015610c9b57826001600160a01b031660098281548110610c5f57610c5f61207c565b6000918252602090912001546001600160a01b031603610c8957610c8281610d72565b9392505050565b80610c93816120a8565b915050610c38565b5060405162461bcd60e51b8152602060048201526042602482015260008051602061250983398151915260448201527f666f72206e6f6e2d6578697374656e7420636f6e73656e737573206164647265606482015261737360f01b608482015260a401610364565b6000805b8281101561061d5760056000858584818110610d2557610d2561207c565b9050602002016020810190610d3a9190611ec4565b6001600160a01b03168152602081019190915260400160002054610d5e90836120c1565b915080610d6a816120a8565b915050610d07565b610d7a611d6a565b600060098381548110610d8f57610d8f61207c565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610ddc57610ddc61207c565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610e0d57610e0d61207c565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b60005b81811015610ed057610ebe838383818110610ea357610ea361207c565b905060a00201803603810190610eb991906121a8565b6116f3565b80610ec8816120a8565b915050610e86565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610999929190612238565b60008082841115610f575760405162461bcd60e51b815260206004820152602b60248201526000805160206124e983398151915260448201526a19081d1a1c995cda1bdb1960aa1b6064820152608401610364565b50506001805460028054928590558390556004805491929184918691906000610f7f836120a8565b9091555060408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b0381166000908152600560205260408120549081900361102e57610ff8826001600160a01b03166014611968565b6040516020016110089190612323565b60408051601f198184030181529082905262461bcd60e51b82526103649160040161235e565b600954600090815b8181101561108f57846001600160a01b03166009828154811061105b5761105b61207c565b6000918252602090912001546001600160a01b03160361107d5780925061108f565b80611087816120a8565b915050611036565b5082600360008282546110a291906120eb565b90915550506001600160a01b0384166000908152600860209081526040808320839055600590915281205560096110da6001836120eb565b815481106110ea576110ea61207c565b600091825260209091200154600980546001600160a01b0390921691849081106111165761111661207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600980548061115557611155612391565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a84815481106111945761119461207c565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a6111c66001836120eb565b815481106111d6576111d661207c565b600091825260209091200154600a80546001600160a01b0390921691849081106112025761120261207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a80548061124157611241612391565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b84815481106112805761128061207c565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b6112b26001836120eb565b815481106112c2576112c261207c565b600091825260209091200154600b80546001600160a01b0390921691849081106112ee576112ee61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b80548061132d5761132d612391565b600082815260209020810160001990810180546001600160a01b031916905501905550505050565b61135e81611b0c565b80516001600160a01b031660009081526005602052604081205490819003611396578151610ff8906001600160a01b03166014611968565b60095460005b818110156116ed5783600001516001600160a01b0316600982815481106113c5576113c561207c565b6000918252602090912001546001600160a01b0316036116db5782600360008282546113f191906120eb565b909155505060608401516003805460009061140d9084906120c1565b9250508190555083602001516001600160a01b0316600a82815481106114355761143561207c565b6000918252602090912001546001600160a01b03161461154d576020808501516001600160a01b0316600090815260069091526040902054156114c85760405162461bcd60e51b815260206004820152603760248201526000805160206125098339815191526044820152763337b910323ab83634b1b0ba32b21033b7bb32b93737b960491b6064820152608401610364565b60066000600a83815481106114df576114df61207c565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a80548390811061151e5761151e61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b828154811061156e5761156e61207c565b6000918252602090912001546001600160a01b031614611689576040808501516001600160a01b0316600090815260076020522054156116025760405162461bcd60e51b815260206004820152603b602482015260008051602061250983398151915260448201527a3337b910323ab83634b1b0ba32b210313934b233b2903b37ba32b960291b6064820152608401610364565b60076000600b83815481106116195761161961207c565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b80548390811061165a5761165a61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b806116e5816120a8565b91505061139c565b50505050565b6080810151156117455760405162461bcd60e51b815260206004820152602960248201526000805160206124e983398151915260448201526819081c995c5d595cdd60ba1b6064820152608401610364565b61174e81611b0c565b80516001600160a01b031660009081526005602052604090205415611793578051611783906001600160a01b03166014611968565b60405160200161100891906123a7565b6020808201516001600160a01b0316600090815260069091526040902054156117de576117ce81602001516001600160a01b03166014611968565b60405160200161100891906123e6565b6040808201516001600160a01b0316600090815260076020522054156118265761181681604001516001600160a01b03166014611968565b6040516020016110089190612459565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af90910180546001600160a01b03199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916119609084906120c1565b909155505050565b606060006119778360026120d4565b6119829060026120c1565b6001600160401b0381111561199957611999612066565b6040519080825280601f01601f1916602001820160405280156119c3576020820181803683370190505b509050600360fc1b816000815181106119de576119de61207c565b60200101906001600160f81b031916908160001a905350600f60fb1b81600181518110611a0d57611a0d61207c565b60200101906001600160f81b031916908160001a9053506000611a318460026120d4565b611a3c9060016120c1565b90505b6001811115611ab4576f181899199a1a9b1b9c1cb0b131b232b360811b85600f1660108110611a7057611a7061207c565b1a60f81b828281518110611a8657611a8661207c565b60200101906001600160f81b031916908160001a90535060049490941c93611aad816124d1565b9050611a3f565b508315611b035760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610364565b90505b92915050565b6000816060015111611b5f5760405162461bcd60e51b815260206004820152602860248201526000805160206124e983398151915260448201526719081dd95a59da1d60c21b6064820152608401610364565b6040805160038082526080820190925260009160208201606080368337019050509050816000015181600081518110611b9a57611b9a61207c565b60200260200101906001600160a01b031690816001600160a01b031681525050816020015181600181518110611bd257611bd261207c565b60200260200101906001600160a01b031690816001600160a01b031681525050816040015181600281518110611c0a57611c0a61207c565b60200260200101906001600160a01b031690816001600160a01b031681525050611c3381611ca3565b156103775760405162461bcd60e51b815260206004820152603a60248201527f526f6e696e547275737465644f7267616e697a6174696f6e3a207468726565206044820152791859191c995cdcd95cc81b5d5cdd08189948191a5cdd1a5b98dd60321b6064820152608401610364565b60008151600003611cb657506000919050565b60005b60018351611cc791906120eb565b811015611d61576000611cdb8260016120c1565b90505b8351811015611d4e57838181518110611cf957611cf961207c565b60200260200101516001600160a01b0316848381518110611d1c57611d1c61207c565b60200260200101516001600160a01b031603611d3c575060019392505050565b80611d46816120a8565b915050611cde565b5080611d59816120a8565b915050611cb9565b50600092915050565b6040805160a08101825260008082526020820181905291810182905260608101829052608081019190915290565b60008083601f840112611daa57600080fd5b5081356001600160401b03811115611dc157600080fd5b60208301915083602060a083028501011115610ac357600080fd5b60008060208385031215611def57600080fd5b82356001600160401b03811115611e0557600080fd5b611e1185828601611d98565b90969095509350505050565b80516001600160a01b0390811683526020808301518216908401526040808301519091169083015260608082015190830152608090810151910152565b6020808252825182820181905260009190848201906040850190845b81811015611e9c57611e89838551611e1d565b9284019260a09290920191600101611e76565b50909695505050505050565b80356001600160a01b0381168114611ebf57600080fd5b919050565b600060208284031215611ed657600080fd5b610c8282611ea8565b60008060208385031215611ef257600080fd5b82356001600160401b0380821115611f0957600080fd5b818501915085601f830112611f1d57600080fd5b813581811115611f2c57600080fd5b8660208260051b8501011115611f4157600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015611e9c57835183529284019291840191600101611f6f565b60008060008060608587031215611fa157600080fd5b84356001600160401b03811115611fb757600080fd5b611fc387828801611d98565b90989097506020870135966040013595509350505050565b60008060408385031215611fee57600080fd5b50508035926020909101359150565b60006020828403121561200f57600080fd5b5035919050565b60a08101611b068284611e1d565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016120ba576120ba612092565b5060010190565b80820180821115611b0657611b06612092565b8082028115828204841417611b0657611b06612092565b81810381811115611b0657611b06612092565b60008261211b57634e487b7160e01b600052601260045260246000fd5b500490565b6020808252602e908201526000805160206124e983398151915260408201526d0c840c2e4e4c2f240d8cadccee8d60931b606082015260800190565b60208082528181018390526000908460408401835b8681101561219d576001600160a01b0361218a84611ea8565b1682529183019190830190600101612171565b509695505050505050565b600060a082840312156121ba57600080fd5b60405160a081016001600160401b03811182821017156121ea57634e487b7160e01b600052604160045260246000fd5b6040526121f683611ea8565b815261220460208401611ea8565b602082015261221560408401611ea8565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b878110156122b4576001600160a01b038061226884611ea8565b16845280612277878501611ea8565b168685015280612288868501611ea8565b168486015250606082810135908401526080808301359084015260a0928301929091019060010161224e565b5090979650505050505050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a20636f6e73656e81526b039bab99030b2323932b9b9960a51b6020820152602c0190565b60005b8381101561231a578181015183820152602001612302565b50506000910152565b600061232e826122c1565b835161233e8183602088016122ff565b6c081a5cc81b9bdd081859191959609a1b9101908152600d019392505050565b602081526000825180602084015261237d8160408501602087016122ff565b601f01601f19169190910160400192915050565b634e487b7160e01b600052603160045260246000fd5b60006123b2826122c1565b83516123c28183602088016122ff565b7020697320616464656420616c726561647960781b91019081526011019392505050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a20676f76656e6f8152690391030b2323932b9b9960b51b60208201526000825161243181602a8501602087016122ff565b7020697320616464656420616c726561647960781b602a939091019283015250603b01919050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a2062726964676581526e0103b37ba32b91030b2323932b9b99608d1b6020820152600082516124a981602f8501602087016122ff565b7020697320616464656420616c726561647960781b602f939091019283015250604001919050565b6000816124e0576124e0612092565b50600019019056fe526f6e696e547275737465644f7267616e697a6174696f6e3a20696e76616c69526f6e696e547275737465644f7267616e697a6174696f6e3a20717565727920a2646970667358221220171fedbb4d0e07d0f093c403c3df05c9996d7e7a3d24de0b489d3201b599112464736f6c63430008110033", - "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101125760003560e01c80630ed285df14610117578063150740051461012c57806341feed1c1461014a578063520fce621461018157806356241911146101a15780635f14a1c3146101ca57806370823625146101dd5780637c37103c146101f05780637de5dedd14610203578063926323d51461020b578063a85c7d6e14610213578063b505a07c14610226578063b9c3620914610239578063cacf8fb514610261578063cc7e6b3b14610269578063d78392f81461027c578063d9d5dadb146102a5578063dafae408146102b8578063db6693a2146102db578063e75235b8146102fb578063e8c0685e14610306578063f09267c214610319575b600080fd5b61012a610125366004611ddc565b61032c565b005b61013461037b565b6040516101419190611e5a565b60405180910390f35b610173610158366004611ec4565b6001600160a01b031660009081526005602052604090205490565b604051908152602001610141565b61019461018f366004611edf565b610550565b6040516101419190611f53565b6101736101af366004611ec4565b6001600160a01b031660009081526007602052604090205490565b6101736101d8366004611edf565b610624565b6101946101eb366004611edf565b610693565b61012a6101fe366004611f8b565b610760565b610173610889565b600354610173565b61012a610221366004611edf565b6108c6565b61012a610234366004611ddc565b6109a5565b61024c610247366004611fdb565b610a79565b60408051928352602083019190915201610141565b600954610173565b610194610277366004611edf565b610aca565b61017361028a366004611ec4565b6001600160a01b031660009081526006602052604090205490565b6101736102b3366004611edf565b610b97565b6102cb6102c6366004611ffd565b610c06565b6040519015158152602001610141565b6102ee6102e9366004611ec4565b610c2d565b6040516101419190612016565b60015460025461024c565b610173610314366004611edf565b610d03565b6102ee610327366004611ffd565b610d72565b610334610e55565b6001600160a01b0316336001600160a01b03161461036d5760405162461bcd60e51b815260040161036490612024565b60405180910390fd5b6103778282610e83565b5050565b6009546060906001600160401b0381111561039857610398612066565b6040519080825280602002602001820160405280156103d157816020015b6103be611d6a565b8152602001906001900390816103b65790505b5090506000805b825181101561054b57600981815481106103f4576103f461207c565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104275761042761207c565b60209081029190910101516001600160a01b039091169052600a8054829081106104535761045361207c565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106104835761048361207c565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b81815481106104ba576104ba61207c565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106104ea576104ea61207c565b6020908102919091018101516001600160a01b03928316604091820152918416600090815260059091522054835184908390811061052a5761052a61207c565b60209081029190910101516060015280610543816120a8565b9150506103d8565b505090565b6060816001600160401b0381111561056a5761056a612066565b604051908082528060200260200182016040528015610593578160200160208202803683370190505b50905060005b815181101561061d57600560008585848181106105b8576105b861207c565b90506020020160208101906105cd9190611ec4565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106106005761060061207c565b602090810291909101015280610615816120a8565b915050610599565b5092915050565b6000805b8281101561061d57600660008585848181106106465761064661207c565b905060200201602081019061065b9190611ec4565b6001600160a01b0316815260208101919091526040016000205461067f90836120c1565b91508061068b816120a8565b915050610628565b6060816001600160401b038111156106ad576106ad612066565b6040519080825280602002602001820160405280156106d6578160200160208202803683370190505b50905060005b815181101561061d57600760008585848181106106fb576106fb61207c565b90506020020160208101906107109190611ec4565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107435761074361207c565b602090810291909101015280610758816120a8565b9150506106dc565b600054610100900460ff16158080156107805750600054600160ff909116105b8061079a5750303b15801561079a575060005460ff166001145b6107fd5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610364565b6000805460ff191660011790558015610820576000805461ff0019166101001790555b8315610830576108308585610e83565b61083a8383610f02565b50508015610882576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546108a391906120d4565b6108ad91906120c1565b6108b791906120eb565b6108c191906120fe565b905090565b6108ce610e55565b6001600160a01b0316336001600160a01b0316146108fe5760405162461bcd60e51b815260040161036490612024565b8061091b5760405162461bcd60e51b815260040161036490612120565b60005b818110156109675761095583838381811061093b5761093b61207c565b90506020020160208101906109509190611ec4565b610fc3565b8061095f816120a8565b91505061091e565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a7828260405161099992919061215c565b60405180910390a15050565b6109ad610e55565b6001600160a01b0316336001600160a01b0316146109dd5760405162461bcd60e51b815260040161036490612024565b806109fa5760405162461bcd60e51b815260040161036490612120565b60005b81811015610a4757610a35838383818110610a1a57610a1a61207c565b905060a00201803603810190610a3091906121a8565b611355565b80610a3f816120a8565b9150506109fd565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610999929190612238565b600080610a84610e55565b6001600160a01b0316336001600160a01b031614610ab45760405162461bcd60e51b815260040161036490612024565b610abe8484610f02565b915091505b9250929050565b6060816001600160401b03811115610ae457610ae4612066565b604051908082528060200260200182016040528015610b0d578160200160208202803683370190505b50905060005b815181101561061d5760066000858584818110610b3257610b3261207c565b9050602002016020810190610b479190611ec4565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610b7a57610b7a61207c565b602090810291909101015280610b8f816120a8565b915050610b13565b6000805b8281101561061d5760076000858584818110610bb957610bb961207c565b9050602002016020810190610bce9190611ec4565b6001600160a01b03168152602081019190915260400160002054610bf290836120c1565b915080610bfe816120a8565b915050610b9b565b6000600354600154610c1891906120d4565b600254610c2590846120d4565b101592915050565b610c35611d6a565b60005b600954811015610c9b57826001600160a01b031660098281548110610c5f57610c5f61207c565b6000918252602090912001546001600160a01b031603610c8957610c8281610d72565b9392505050565b80610c93816120a8565b915050610c38565b5060405162461bcd60e51b8152602060048201526042602482015260008051602061250983398151915260448201527f666f72206e6f6e2d6578697374656e7420636f6e73656e737573206164647265606482015261737360f01b608482015260a401610364565b6000805b8281101561061d5760056000858584818110610d2557610d2561207c565b9050602002016020810190610d3a9190611ec4565b6001600160a01b03168152602081019190915260400160002054610d5e90836120c1565b915080610d6a816120a8565b915050610d07565b610d7a611d6a565b600060098381548110610d8f57610d8f61207c565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610ddc57610ddc61207c565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610e0d57610e0d61207c565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b60005b81811015610ed057610ebe838383818110610ea357610ea361207c565b905060a00201803603810190610eb991906121a8565b6116f3565b80610ec8816120a8565b915050610e86565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610999929190612238565b60008082841115610f575760405162461bcd60e51b815260206004820152602b60248201526000805160206124e983398151915260448201526a19081d1a1c995cda1bdb1960aa1b6064820152608401610364565b50506001805460028054928590558390556004805491929184918691906000610f7f836120a8565b9091555060408051868152602081018690527f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b0381166000908152600560205260408120549081900361102e57610ff8826001600160a01b03166014611968565b6040516020016110089190612323565b60408051601f198184030181529082905262461bcd60e51b82526103649160040161235e565b600954600090815b8181101561108f57846001600160a01b03166009828154811061105b5761105b61207c565b6000918252602090912001546001600160a01b03160361107d5780925061108f565b80611087816120a8565b915050611036565b5082600360008282546110a291906120eb565b90915550506001600160a01b0384166000908152600860209081526040808320839055600590915281205560096110da6001836120eb565b815481106110ea576110ea61207c565b600091825260209091200154600980546001600160a01b0390921691849081106111165761111661207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600980548061115557611155612391565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a84815481106111945761119461207c565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a6111c66001836120eb565b815481106111d6576111d661207c565b600091825260209091200154600a80546001600160a01b0390921691849081106112025761120261207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a80548061124157611241612391565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b84815481106112805761128061207c565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b6112b26001836120eb565b815481106112c2576112c261207c565b600091825260209091200154600b80546001600160a01b0390921691849081106112ee576112ee61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b80548061132d5761132d612391565b600082815260209020810160001990810180546001600160a01b031916905501905550505050565b61135e81611b0c565b80516001600160a01b031660009081526005602052604081205490819003611396578151610ff8906001600160a01b03166014611968565b60095460005b818110156116ed5783600001516001600160a01b0316600982815481106113c5576113c561207c565b6000918252602090912001546001600160a01b0316036116db5782600360008282546113f191906120eb565b909155505060608401516003805460009061140d9084906120c1565b9250508190555083602001516001600160a01b0316600a82815481106114355761143561207c565b6000918252602090912001546001600160a01b03161461154d576020808501516001600160a01b0316600090815260069091526040902054156114c85760405162461bcd60e51b815260206004820152603760248201526000805160206125098339815191526044820152763337b910323ab83634b1b0ba32b21033b7bb32b93737b960491b6064820152608401610364565b60066000600a83815481106114df576114df61207c565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a80548390811061151e5761151e61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b828154811061156e5761156e61207c565b6000918252602090912001546001600160a01b031614611689576040808501516001600160a01b0316600090815260076020522054156116025760405162461bcd60e51b815260206004820152603b602482015260008051602061250983398151915260448201527a3337b910323ab83634b1b0ba32b210313934b233b2903b37ba32b960291b6064820152608401610364565b60076000600b83815481106116195761161961207c565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b80548390811061165a5761165a61207c565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b806116e5816120a8565b91505061139c565b50505050565b6080810151156117455760405162461bcd60e51b815260206004820152602960248201526000805160206124e983398151915260448201526819081c995c5d595cdd60ba1b6064820152608401610364565b61174e81611b0c565b80516001600160a01b031660009081526005602052604090205415611793578051611783906001600160a01b03166014611968565b60405160200161100891906123a7565b6020808201516001600160a01b0316600090815260069091526040902054156117de576117ce81602001516001600160a01b03166014611968565b60405160200161100891906123e6565b6040808201516001600160a01b0316600090815260076020522054156118265761181681604001516001600160a01b03166014611968565b6040516020016110089190612459565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af90910180546001600160a01b03199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916119609084906120c1565b909155505050565b606060006119778360026120d4565b6119829060026120c1565b6001600160401b0381111561199957611999612066565b6040519080825280601f01601f1916602001820160405280156119c3576020820181803683370190505b509050600360fc1b816000815181106119de576119de61207c565b60200101906001600160f81b031916908160001a905350600f60fb1b81600181518110611a0d57611a0d61207c565b60200101906001600160f81b031916908160001a9053506000611a318460026120d4565b611a3c9060016120c1565b90505b6001811115611ab4576f181899199a1a9b1b9c1cb0b131b232b360811b85600f1660108110611a7057611a7061207c565b1a60f81b828281518110611a8657611a8661207c565b60200101906001600160f81b031916908160001a90535060049490941c93611aad816124d1565b9050611a3f565b508315611b035760405162461bcd60e51b815260206004820181905260248201527f537472696e67733a20686578206c656e67746820696e73756666696369656e746044820152606401610364565b90505b92915050565b6000816060015111611b5f5760405162461bcd60e51b815260206004820152602860248201526000805160206124e983398151915260448201526719081dd95a59da1d60c21b6064820152608401610364565b6040805160038082526080820190925260009160208201606080368337019050509050816000015181600081518110611b9a57611b9a61207c565b60200260200101906001600160a01b031690816001600160a01b031681525050816020015181600181518110611bd257611bd261207c565b60200260200101906001600160a01b031690816001600160a01b031681525050816040015181600281518110611c0a57611c0a61207c565b60200260200101906001600160a01b031690816001600160a01b031681525050611c3381611ca3565b156103775760405162461bcd60e51b815260206004820152603a60248201527f526f6e696e547275737465644f7267616e697a6174696f6e3a207468726565206044820152791859191c995cdcd95cc81b5d5cdd08189948191a5cdd1a5b98dd60321b6064820152608401610364565b60008151600003611cb657506000919050565b60005b60018351611cc791906120eb565b811015611d61576000611cdb8260016120c1565b90505b8351811015611d4e57838181518110611cf957611cf961207c565b60200260200101516001600160a01b0316848381518110611d1c57611d1c61207c565b60200260200101516001600160a01b031603611d3c575060019392505050565b80611d46816120a8565b915050611cde565b5080611d59816120a8565b915050611cb9565b50600092915050565b6040805160a08101825260008082526020820181905291810182905260608101829052608081019190915290565b60008083601f840112611daa57600080fd5b5081356001600160401b03811115611dc157600080fd5b60208301915083602060a083028501011115610ac357600080fd5b60008060208385031215611def57600080fd5b82356001600160401b03811115611e0557600080fd5b611e1185828601611d98565b90969095509350505050565b80516001600160a01b0390811683526020808301518216908401526040808301519091169083015260608082015190830152608090810151910152565b6020808252825182820181905260009190848201906040850190845b81811015611e9c57611e89838551611e1d565b9284019260a09290920191600101611e76565b50909695505050505050565b80356001600160a01b0381168114611ebf57600080fd5b919050565b600060208284031215611ed657600080fd5b610c8282611ea8565b60008060208385031215611ef257600080fd5b82356001600160401b0380821115611f0957600080fd5b818501915085601f830112611f1d57600080fd5b813581811115611f2c57600080fd5b8660208260051b8501011115611f4157600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015611e9c57835183529284019291840191600101611f6f565b60008060008060608587031215611fa157600080fd5b84356001600160401b03811115611fb757600080fd5b611fc387828801611d98565b90989097506020870135966040013595509350505050565b60008060408385031215611fee57600080fd5b50508035926020909101359150565b60006020828403121561200f57600080fd5b5035919050565b60a08101611b068284611e1d565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016120ba576120ba612092565b5060010190565b80820180821115611b0657611b06612092565b8082028115828204841417611b0657611b06612092565b81810381811115611b0657611b06612092565b60008261211b57634e487b7160e01b600052601260045260246000fd5b500490565b6020808252602e908201526000805160206124e983398151915260408201526d0c840c2e4e4c2f240d8cadccee8d60931b606082015260800190565b60208082528181018390526000908460408401835b8681101561219d576001600160a01b0361218a84611ea8565b1682529183019190830190600101612171565b509695505050505050565b600060a082840312156121ba57600080fd5b60405160a081016001600160401b03811182821017156121ea57634e487b7160e01b600052604160045260246000fd5b6040526121f683611ea8565b815261220460208401611ea8565b602082015261221560408401611ea8565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b878110156122b4576001600160a01b038061226884611ea8565b16845280612277878501611ea8565b168685015280612288868501611ea8565b168486015250606082810135908401526080808301359084015260a0928301929091019060010161224e565b5090979650505050505050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a20636f6e73656e81526b039bab99030b2323932b9b9960a51b6020820152602c0190565b60005b8381101561231a578181015183820152602001612302565b50506000910152565b600061232e826122c1565b835161233e8183602088016122ff565b6c081a5cc81b9bdd081859191959609a1b9101908152600d019392505050565b602081526000825180602084015261237d8160408501602087016122ff565b601f01601f19169190910160400192915050565b634e487b7160e01b600052603160045260246000fd5b60006123b2826122c1565b83516123c28183602088016122ff565b7020697320616464656420616c726561647960781b91019081526011019392505050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a20676f76656e6f8152690391030b2323932b9b9960b51b60208201526000825161243181602a8501602087016122ff565b7020697320616464656420616c726561647960781b602a939091019283015250603b01919050565b7f526f6e696e547275737465644f7267616e697a6174696f6e3a2062726964676581526e0103b37ba32b91030b2323932b9b99608d1b6020820152600082516124a981602f8501602087016122ff565b7020697320616464656420616c726561647960781b602f939091019283015250604001919050565b6000816124e0576124e0612092565b50600019019056fe526f6e696e547275737465644f7267616e697a6174696f6e3a20696e76616c69526f6e696e547275737465644f7267616e697a6174696f6e3a20717565727920a2646970667358221220171fedbb4d0e07d0f093c403c3df05c9996d7e7a3d24de0b489d3201b599112464736f6c63430008110033", + "numDeployments": 2, + "solcInputHash": "0e13282b1de32a862f3ea9c3dc0543e9", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[{\"internalType\":\"address\",\"name\":\"voter\",\"type\":\"address\"}],\"name\":\"ErrBridgeVoterIsAlreadyAdded\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrConsensusAddressIsAlreadyAdded\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrConsensusAddressIsNotAdded\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrDuplicated\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrEmptyArray\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrGovernorAddressIsAlreadyAdded\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidRequest\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidVoteWeight\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForDupplicated\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrQueryForNonExistentConsensusAddress\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"nonce\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"numerator\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"denominator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousNumerator\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"previousDenominator\",\"type\":\"uint256\"}],\"name\":\"ThresholdUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"orgs\",\"type\":\"tuple[]\"}],\"name\":\"TrustedOrganizationsAdded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"orgs\",\"type\":\"address[]\"}],\"name\":\"TrustedOrganizationsRemoved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"indexed\":false,\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"orgs\",\"type\":\"tuple[]\"}],\"name\":\"TrustedOrganizationsUpdated\",\"type\":\"event\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"name\":\"addTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_voteWeight\",\"type\":\"uint256\"}],\"name\":\"checkThreshold\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"countTrustedOrganization\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getAllTrustedOrganizations\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"getBridgeVoterWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getBridgeVoterWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getConsensusWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getConsensusWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_governor\",\"type\":\"address\"}],\"name\":\"getGovernorWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"getGovernorWeights\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_res\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"num_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"denom_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getTrustedOrganization\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_idx\",\"type\":\"uint256\"}],\"name\":\"getTrustedOrganizationAt\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_trustedOrgs\",\"type\":\"tuple[]\"},{\"internalType\":\"uint256\",\"name\":\"__num\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__denom\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minimumVoteWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"removeTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numerator\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_denominator\",\"type\":\"uint256\"}],\"name\":\"setThreshold\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumBridgeVoterWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumConsensusWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_list\",\"type\":\"address[]\"}],\"name\":\"sumGovernorWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_res\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalWeight\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"governor\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeVoter\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"weight\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"addedBlock\",\"type\":\"uint256\"}],\"internalType\":\"struct IRoninTrustedOrganization.TrustedOrganization[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"name\":\"updateTrustedOrganizations\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrBridgeVoterIsAlreadyAdded(address)\":[{\"details\":\"Error indicating that a bridge voter has already been added.\",\"params\":{\"voter\":\"The address of the bridge voter that is already added.\"}}],\"ErrConsensusAddressIsAlreadyAdded(address)\":[{\"details\":\"Error indicating that a consensus address is already added.\",\"params\":{\"addr\":\"The address of the consensus contract that is already added.\"}}],\"ErrConsensusAddressIsNotAdded(address)\":[{\"details\":\"Error indicating that a consensus address is not added.\",\"params\":{\"addr\":\"The address of the consensus contract that is not added.\"}}],\"ErrDuplicated(bytes4)\":[{\"details\":\"Error thrown when a duplicated element is detected in an array.\",\"params\":{\"msgSig\":\"The function signature that invoke the error.\"}}],\"ErrEmptyArray()\":[{\"details\":\"Error indicating that an array is empty when it should contain elements.\"}],\"ErrGovernorAddressIsAlreadyAdded(address)\":[{\"details\":\"Error indicating that a governor address has already been added.\",\"params\":{\"addr\":\"The address of the governor that is already added.\"}}],\"ErrInvalidRequest()\":[{\"details\":\"Error indicating that a request is invalid.\"}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrInvalidVoteWeight(bytes4)\":[{\"details\":\"Error indicating that a vote weight is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that encountered an invalid vote weight.\"}}],\"ErrQueryForDupplicated()\":[{\"details\":\"Error indicating that a query for a duplicate entry was made.\"}],\"ErrQueryForNonExistentConsensusAddress()\":[{\"details\":\"Error indicating that a query was made for a non-existent consensus address.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}]},\"kind\":\"dev\",\"methods\":{\"addTrustedOrganizations((address,address,address,uint256,uint256)[])\":{\"details\":\"Adds a list of addresses into the trusted organization. Requirements: - The weights should larger than 0. - The method caller is admin. - The field `addedBlock` should be blank. Emits the event `TrustedOrganizationAdded` once an organization is added.\"},\"checkThreshold(uint256)\":{\"details\":\"Checks whether the `_voteWeight` passes the threshold.\"},\"countTrustedOrganization()\":{\"details\":\"Returns the number of trusted organizations.\"},\"getAllTrustedOrganizations()\":{\"details\":\"Returns all of the trusted organizations.\"},\"getBridgeVoterWeight(address)\":{\"details\":\"Returns the weight of a bridge voter.\"},\"getBridgeVoterWeights(address[])\":{\"details\":\"Returns the weights of a list of bridge voter addresses.\"},\"getConsensusWeight(address)\":{\"details\":\"Returns the weight of a consensus.\"},\"getConsensusWeights(address[])\":{\"details\":\"Returns the weights of a list of consensus addresses.\"},\"getGovernorWeight(address)\":{\"details\":\"Returns the weight of a governor.\"},\"getGovernorWeights(address[])\":{\"details\":\"Returns the weights of a list of governor addresses.\"},\"getThreshold()\":{\"details\":\"Returns the threshold.\"},\"getTrustedOrganization(address)\":{\"details\":\"Returns the trusted organization by consensus address. Reverts once the consensus address is non-existent.\"},\"getTrustedOrganizationAt(uint256)\":{\"details\":\"Returns the trusted organization at `_index`.\"},\"initialize((address,address,address,uint256,uint256)[],uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"minimumVoteWeight()\":{\"details\":\"Returns the minimum vote weight to pass the threshold.\"},\"removeTrustedOrganizations(address[])\":{\"details\":\"Removes a list of addresses from the trusted organization. Requirements: - The method caller is admin. Emits the event `TrustedOrganizationRemoved` once an organization is removed.\",\"params\":{\"_consensusAddrs\":\"The list of consensus addresses linked to corresponding trusted organization that to be removed.\"}},\"setThreshold(uint256,uint256)\":{\"details\":\"Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event.\"},\"sumBridgeVoterWeight(address[])\":{\"details\":\"Returns total weights of the bridge voter list.\"},\"sumConsensusWeight(address[])\":{\"details\":\"Returns total weights of the consensus list.\"},\"sumGovernorWeight(address[])\":{\"details\":\"Returns total weights of the governor list.\"},\"totalWeight()\":{\"details\":\"Returns total weights.\"},\"updateTrustedOrganizations((address,address,address,uint256,uint256)[])\":{\"details\":\"Updates weights for a list of existent trusted organization. Requirements: - The weights should larger than 0. - The method caller is admin. Emits the `TrustedOrganizationUpdated` event.\"}},\"stateVariables\":{\"_addedBlock\":{\"details\":\"Mapping from consensus address => added block\"},\"_bridgeVoterList\":{\"details\":\"Bridge voters array\"},\"_bridgeVoterWeight\":{\"details\":\"Mapping from bridge voter address => weight\"},\"_consensusList\":{\"details\":\"Consensus array\"},\"_consensusWeight\":{\"details\":\"Mapping from consensus address => weight\"},\"_governorList\":{\"details\":\"Governors array\"},\"_governorWeight\":{\"details\":\"Mapping from governor address => weight\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/multi-chains/RoninTrustedOrganization.sol\":\"RoninTrustedOrganization\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n /**\\n * @dev Error indicating that a query for a duplicate entry was made.\\n */\\n error ErrQueryForDupplicated();\\n\\n /**\\n * @dev Error indicating that a query was made for a non-existent consensus address.\\n */\\n error ErrQueryForNonExistentConsensusAddress();\\n\\n /**\\n * @dev Error indicating that a bridge voter has already been added.\\n * @param voter The address of the bridge voter that is already added.\\n */\\n error ErrBridgeVoterIsAlreadyAdded(address voter);\\n\\n /**\\n * @dev Error indicating that a governor address has already been added.\\n * @param addr The address of the governor that is already added.\\n */\\n error ErrGovernorAddressIsAlreadyAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is not added.\\n * @param addr The address of the consensus contract that is not added.\\n */\\n error ErrConsensusAddressIsNotAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is already added.\\n * @param addr The address of the consensus contract that is already added.\\n */\\n error ErrConsensusAddressIsAlreadyAdded(address addr);\\n\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganization() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x2eaef3332e209474b24574aeded61091e82a145fcbcf479577535c0cd210e1e5\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/multi-chains/RoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport \\\"../interfaces/IRoninTrustedOrganization.sol\\\";\\nimport \\\"../extensions/collections/HasProxyAdmin.sol\\\";\\n\\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\\n uint256 internal _num;\\n uint256 internal _denom;\\n uint256 internal _totalWeight;\\n uint256 internal _nonce;\\n\\n /// @dev Mapping from consensus address => weight\\n mapping(address => uint256) internal _consensusWeight;\\n /// @dev Mapping from governor address => weight\\n mapping(address => uint256) internal _governorWeight;\\n /// @dev Mapping from bridge voter address => weight\\n mapping(address => uint256) internal _bridgeVoterWeight;\\n\\n /// @dev Mapping from consensus address => added block\\n mapping(address => uint256) internal _addedBlock;\\n\\n /// @dev Consensus array\\n address[] internal _consensusList;\\n /// @dev Governors array\\n address[] internal _governorList;\\n /// @dev Bridge voters array\\n address[] internal _bridgeVoterList;\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n TrustedOrganization[] calldata _trustedOrgs,\\n uint256 __num,\\n uint256 __denom\\n ) external initializer {\\n if (_trustedOrgs.length > 0) {\\n _addTrustedOrganizations(_trustedOrgs);\\n }\\n _setThreshold(__num, __denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\\n return (_num, _denom);\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\\n return _voteWeight * _denom >= _num * _totalWeight;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function minimumVoteWeight() external view virtual returns (uint256) {\\n return (_num * _totalWeight + _denom - 1) / _denom;\\n }\\n\\n /**\\n * @inheritdoc IQuorum\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external override onlyAdmin returns (uint256, uint256) {\\n return _setThreshold(_numerator, _denominator);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\\n _addTrustedOrganizations(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\\n if (_list.length == 0) revert ErrEmptyArray();\\n for (uint256 _i; _i < _list.length; ) {\\n _updateTrustedOrganization(_list[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit TrustedOrganizationsUpdated(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\\n if (_list.length == 0) revert ErrEmptyArray();\\n\\n for (uint _i = 0; _i < _list.length; ) {\\n _removeTrustedOrganization(_list[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit TrustedOrganizationsRemoved(_list);\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function totalWeight() external view virtual returns (uint256) {\\n return _totalWeight;\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\\n return _consensusWeight[_consensusAddr];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256) {\\n return _governorWeight[_governor];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\\n return _bridgeVoterWeight[_addr];\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; ) {\\n _res[_i] = _consensusWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; ) {\\n _res[_i] = _governorWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\\n _res = new uint256[](_list.length);\\n for (uint _i = 0; _i < _res.length; ) {\\n _res[_i] = _bridgeVoterWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; ) {\\n _res += _consensusWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; ) {\\n _res += _governorWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\\n for (uint _i = 0; _i < _list.length; ) {\\n _res += _bridgeVoterWeight[_list[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function countTrustedOrganization() external view override returns (uint256) {\\n return _consensusList.length;\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\\n _list = new TrustedOrganization[](_consensusList.length);\\n address _addr;\\n for (uint256 _i; _i < _list.length; ) {\\n _addr = _consensusList[_i];\\n _list[_i].consensusAddr = _addr;\\n _list[_i].governor = _governorList[_i];\\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\\n _list[_i].weight = _consensusWeight[_addr];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\\n for (uint _i = 0; _i < _consensusList.length; ) {\\n if (_consensusList[_i] == _consensusAddr) {\\n return getTrustedOrganizationAt(_i);\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n revert ErrQueryForNonExistentConsensusAddress();\\n }\\n\\n /**\\n * @inheritdoc IRoninTrustedOrganization\\n */\\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\\n address _addr = _consensusList[_idx];\\n return\\n TrustedOrganization(\\n _addr,\\n _governorList[_idx],\\n _bridgeVoterList[_idx],\\n _consensusWeight[_addr],\\n _addedBlock[_addr]\\n );\\n }\\n\\n /**\\n * @dev Adds a list of trusted organizations.\\n */\\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\\n for (uint256 _i; _i < _list.length; ) {\\n _addTrustedOrganization(_list[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit TrustedOrganizationsAdded(_list);\\n }\\n\\n /**\\n * @dev Adds a trusted organization.\\n *\\n * Requirements:\\n * - The weight is larger than 0.\\n * - The consensus address is not added.\\n * - The govenor address is not added.\\n * - The bridge voter address is not added.\\n *\\n */\\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\\n _sanityCheckTrustedOrganizationData(_v);\\n\\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\\n\\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\\n\\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\\n\\n _consensusList.push(_v.consensusAddr);\\n _consensusWeight[_v.consensusAddr] = _v.weight;\\n\\n _governorList.push(_v.governor);\\n _governorWeight[_v.governor] = _v.weight;\\n\\n _bridgeVoterList.push(_v.bridgeVoter);\\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\\n\\n _addedBlock[_v.consensusAddr] = block.number;\\n\\n _totalWeight += _v.weight;\\n }\\n\\n /**\\n * @dev Updates a trusted organization.\\n *\\n * Requirements:\\n * - The weight is larger than 0.\\n * - The consensus address is already added.\\n *\\n */\\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\\n _sanityCheckTrustedOrganizationData(_v);\\n\\n uint256 _weight = _consensusWeight[_v.consensusAddr];\\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\\n\\n uint256 _count = _consensusList.length;\\n for (uint256 _i = 0; _i < _count; ) {\\n if (_consensusList[_i] == _v.consensusAddr) {\\n _totalWeight -= _weight;\\n _totalWeight += _v.weight;\\n\\n if (_governorList[_i] != _v.governor) {\\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\\n\\n delete _governorWeight[_governorList[_i]];\\n _governorList[_i] = _v.governor;\\n }\\n\\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\\n\\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\\n _bridgeVoterList[_i] = _v.bridgeVoter;\\n }\\n\\n _consensusWeight[_v.consensusAddr] = _v.weight;\\n _governorWeight[_v.governor] = _v.weight;\\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\\n return;\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Removes a trusted organization.\\n *\\n * Requirements:\\n * - The consensus address is added.\\n *\\n */\\n function _removeTrustedOrganization(address _addr) internal virtual {\\n uint256 _weight = _consensusWeight[_addr];\\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\\n\\n uint256 _index;\\n uint256 _count = _consensusList.length;\\n for (uint256 _i = 0; _i < _count; ) {\\n if (_consensusList[_i] == _addr) {\\n _index = _i;\\n break;\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n _totalWeight -= _weight;\\n\\n delete _addedBlock[_addr];\\n delete _consensusWeight[_addr];\\n _consensusList[_index] = _consensusList[_count - 1];\\n _consensusList.pop();\\n\\n delete _governorWeight[_governorList[_index]];\\n _governorList[_index] = _governorList[_count - 1];\\n _governorList.pop();\\n\\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\\n _bridgeVoterList.pop();\\n }\\n\\n /**\\n * @dev Sets threshold and returns the old one.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function _setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\\n\\n _previousNum = _num;\\n _previousDenom = _denom;\\n _num = _numerator;\\n _denom = _denominator;\\n unchecked {\\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\\n }\\n }\\n\\n /**\\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\\n *\\n * Requirements:\\n * - The weight must be larger than 0.\\n * - The consensus address, governor address, and bridge voter address are different.\\n */\\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\\n\\n address[] memory _addresses = new address[](3);\\n _addresses[0] = _v.consensusAddr;\\n _addresses[1] = _v.governor;\\n _addresses[2] = _v.bridgeVoter;\\n\\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n}\\n\",\"keccak256\":\"0xf20be6100f9c33831c2915eb1c68f2b31f6d9f0ffacc6a63d3edb95aedfda166\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b50611eaf806100206000396000f3fe608060405234801561001057600080fd5b50600436106101425760003560e01c806396c82e57116100b8578063cc7e6b3b1161007c578063cc7e6b3b146102bb578063d78392f8146102ce578063dafae408146102f7578063db6693a21461031a578063e75235b81461033a578063f09267c21461034557600080fd5b806396c82e571461025d578063a85c7d6e14610265578063b505a07c14610278578063b7f67e971461028b578063b9c362091461029357600080fd5b8063562419111161010a57806356241911146101e0578063691845a914610209578063708236251461021c5780637c37103c1461022f5780637de5dedd14610242578063903bb3c51461024a57600080fd5b80630e777c06146101475780630ed285df1461016d578063150740051461018257806341feed1c14610197578063520fce62146101c0575b600080fd5b61015a61015536600461198a565b610358565b6040519081526020015b60405180910390f35b61018061017b366004611a44565b6103c4565b005b61018a6103da565b6040516101649190611ac3565b61015a6101a5366004611b2d565b6001600160a01b031660009081526005602052604090205490565b6101d36101ce36600461198a565b6105c6565b6040516101649190611b48565b61015a6101ee366004611b2d565b6001600160a01b031660009081526007602052604090205490565b61015a61021736600461198a565b61068a565b6101d361022a36600461198a565b6106ef565b61018061023d366004611b80565b6107b3565b61015a6108e1565b61015a61025836600461198a565b61091e565b60035461015a565b61018061027336600461198a565b610983565b610180610286366004611a44565b610a2d565b60095461015a565b6102a66102a1366004611bd1565b610acc565b60408051928352602083019190915201610164565b6101d36102c936600461198a565b610aed565b61015a6102dc366004611b2d565b6001600160a01b031660009081526006602052604090205490565b61030a610305366004611bf3565b610bb1565b6040519015158152602001610164565b61032d610328366004611b2d565b610bd8565b6040516101649190611c0c565b6001546002546102a6565b61032d610353366004611bf3565b610c77565b6000805b828110156103bd576007600085858481811061037a5761037a611c20565b905060200201602081019061038f9190611b2d565b6001600160a01b031681526020810191909152604001600020546103b39083611c4c565b915060010161035c565b5092915050565b6103cc610d7d565b6103d68282610dd9565b5050565b60095460609067ffffffffffffffff8111156103f8576103f8611c5f565b60405190808252806020026020018201604052801561045157816020015b6040805160a0810182526000808252602080830182905292820181905260608201819052608082015282526000199092019101816104165790505b5090506000805b82518110156105c1576009818154811061047457610474611c20565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104a7576104a7611c20565b60209081029190910101516001600160a01b039091169052600a8054829081106104d3576104d3611c20565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061050357610503611c20565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b818154811061053a5761053a611c20565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061056a5761056a611c20565b6020908102919091018101516001600160a01b0392831660409182015291841660009081526005909152205483518490839081106105aa576105aa611c20565b602090810291909101015160600152600101610458565b505090565b60608167ffffffffffffffff8111156105e1576105e1611c5f565b60405190808252806020026020018201604052801561060a578160200160208202803683370190505b50905060005b81518110156103bd576005600085858481811061062f5761062f611c20565b90506020020160208101906106449190611b2d565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061067757610677611c20565b6020908102919091010152600101610610565b6000805b828110156103bd57600560008585848181106106ac576106ac611c20565b90506020020160208101906106c19190611b2d565b6001600160a01b031681526020810191909152604001600020546106e59083611c4c565b915060010161068e565b60608167ffffffffffffffff81111561070a5761070a611c5f565b604051908082528060200260200182016040528015610733578160200160208202803683370190505b50905060005b81518110156103bd576007600085858481811061075857610758611c20565b905060200201602081019061076d9190611b2d565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107a0576107a0611c20565b6020908102919091010152600101610739565b600054610100900460ff16158080156107d35750600054600160ff909116105b806107ed5750303b1580156107ed575060005460ff166001145b6108555760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff191660011790558015610878576000805461ff0019166101001790555b8315610888576108888585610dd9565b6108928383610e4e565b505080156108da576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546108fb9190611c75565b6109059190611c4c565b61090f9190611c8c565b6109199190611c9f565b905090565b6000805b828110156103bd576006600085858481811061094057610940611c20565b90506020020160208101906109559190611b2d565b6001600160a01b031681526020810191909152604001600020546109799083611c4c565b9150600101610922565b61098b610d7d565b60008190036109ad576040516316ee9d3b60e11b815260040160405180910390fd5b60005b818110156109ef576109e78383838181106109cd576109cd611c20565b90506020020160208101906109e29190611b2d565b610ee4565b6001016109b0565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a78282604051610a21929190611cc1565b60405180910390a15050565b610a35610d7d565b6000819003610a57576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610a9a57610a92838383818110610a7757610a77611c20565b905060a00201803603810190610a8d9190611d0d565b611246565b600101610a5a565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610a21929190611d9e565b600080610ad7610d7d565b610ae18484610e4e565b915091505b9250929050565b60608167ffffffffffffffff811115610b0857610b08611c5f565b604051908082528060200260200182016040528015610b31578160200160208202803683370190505b50905060005b81518110156103bd5760066000858584818110610b5657610b56611c20565b9050602002016020810190610b6b9190611b2d565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610b9e57610b9e611c20565b6020908102919091010152600101610b37565b6000600354600154610bc39190611c75565b600254610bd09084611c75565b101592915050565b6040805160a0810182526000808252602082018190529181018290526060810182905260808101829052905b600954811015610c5d57826001600160a01b031660098281548110610c2b57610c2b611c20565b6000918252602090912001546001600160a01b031603610c5557610c4e81610c77565b9392505050565b600101610c04565b5060405163e57fdbef60e01b815260040160405180910390fd5b6040805160a081018252600080825260208201819052918101829052606081018290526080810191909152600060098381548110610cb757610cb7611c20565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610d0457610d04611c20565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610d3557610d35611c20565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610dd7576000356001600160e01b0319166001604051620f948f60ea1b815260040161084c929190611e27565b565b60005b81811015610e1c57610e14838383818110610df957610df9611c20565b905060a00201803603810190610e0f9190611d0d565b61156d565b600101610ddc565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610a21929190611d9e565b60008082841115610e80576040516387f6f09560e01b81526001600160e01b031960003516600482015260240161084c565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b03811660009081526005602052604081205490819003610f29576040516349f748eb60e01b81526001600160a01b038316600482015260240161084c565b600954600090815b81811015610f8057846001600160a01b031660098281548110610f5657610f56611c20565b6000918252602090912001546001600160a01b031603610f7857809250610f80565b600101610f31565b508260036000828254610f939190611c8c565b90915550506001600160a01b038416600090815260086020908152604080832083905560059091528120556009610fcb600183611c8c565b81548110610fdb57610fdb611c20565b600091825260209091200154600980546001600160a01b03909216918490811061100757611007611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600980548061104657611046611e63565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a848154811061108557611085611c20565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a6110b7600183611c8c565b815481106110c7576110c7611c20565b600091825260209091200154600a80546001600160a01b0390921691849081106110f3576110f3611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a80548061113257611132611e63565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b848154811061117157611171611c20565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b6111a3600183611c8c565b815481106111b3576111b3611c20565b600091825260209091200154600b80546001600160a01b0390921691849081106111df576111df611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b80548061121e5761121e611e63565b600082815260209020810160001990810180546001600160a01b031916905501905550505050565b61124f816117b8565b80516001600160a01b0316600090815260056020526040812054908190036112985781516040516349f748eb60e01b81526001600160a01b03909116600482015260240161084c565b60095460005b818110156115675783600001516001600160a01b0316600982815481106112c7576112c7611c20565b6000918252602090912001546001600160a01b03160361155f5782600360008282546112f39190611c8c565b909155505060608401516003805460009061130f908490611c4c565b9250508190555083602001516001600160a01b0316600a828154811061133757611337611c20565b6000918252602090912001546001600160a01b031614611412576020808501516001600160a01b03166000908152600690915260409020541561138d576040516346da180960e01b815260040160405180910390fd5b60066000600a83815481106113a4576113a4611c20565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a8054839081106113e3576113e3611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b828154811061143357611433611c20565b6000918252602090912001546001600160a01b03161461150d576040808501516001600160a01b031660009081526007602052205415611486576040516346da180960e01b815260040160405180910390fd5b60076000600b838154811061149d5761149d611c20565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b8054839081106114de576114de611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b60010161129e565b50505050565b6080810151156115905760405163129c2ce160e31b815260040160405180910390fd5b611599816117b8565b80516001600160a01b0316600090815260056020526040902054156115df57805160405163ada9a35360e01b81526001600160a01b03909116600482015260240161084c565b6020808201516001600160a01b03166000908152600690915260409020541561162c576020810151604051637f5e2f5960e11b81526001600160a01b03909116600482015260240161084c565b6040808201516001600160a01b031660009081526007602052205415611676576040808201519051630f69702d60e01b81526001600160a01b03909116600482015260240161084c565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af90910180546001600160a01b03199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916117b0908490611c4c565b909155505050565b80606001516000036117eb57604051637f11b8a360e11b81526001600160e01b031960003516600482015260240161084c565b604080516003808252608082019092526000916020820160608036833701905050905081600001518160008151811061182657611826611c20565b60200260200101906001600160a01b031690816001600160a01b03168152505081602001518160018151811061185e5761185e611c20565b60200260200101906001600160a01b031690816001600160a01b03168152505081604001518160028151811061189657611896611c20565b60200260200101906001600160a01b031690816001600160a01b0316815250506118bf816118eb565b156103d657604051630d697db160e11b81526001600160e01b031960003516600482015260240161084c565b600081516000036118fe57506000919050565b60005b600183510381101561198157600181015b83518110156119785783818151811061192d5761192d611c20565b60200260200101516001600160a01b031684838151811061195057611950611c20565b60200260200101516001600160a01b031603611970575060019392505050565b600101611912565b50600101611901565b50600092915050565b6000806020838503121561199d57600080fd5b823567ffffffffffffffff808211156119b557600080fd5b818501915085601f8301126119c957600080fd5b8135818111156119d857600080fd5b8660208260051b85010111156119ed57600080fd5b60209290920196919550909350505050565b60008083601f840112611a1157600080fd5b50813567ffffffffffffffff811115611a2957600080fd5b60208301915083602060a083028501011115610ae657600080fd5b60008060208385031215611a5757600080fd5b823567ffffffffffffffff811115611a6e57600080fd5b611a7a858286016119ff565b90969095509350505050565b80516001600160a01b0390811683526020808301518216908401526040808301519091169083015260608082015190830152608090810151910152565b6020808252825182820181905260009190848201906040850190845b81811015611b0557611af2838551611a86565b9284019260a09290920191600101611adf565b50909695505050505050565b80356001600160a01b0381168114611b2857600080fd5b919050565b600060208284031215611b3f57600080fd5b610c4e82611b11565b6020808252825182820181905260009190848201906040850190845b81811015611b0557835183529284019291840191600101611b64565b60008060008060608587031215611b9657600080fd5b843567ffffffffffffffff811115611bad57600080fd5b611bb9878288016119ff565b90989097506020870135966040013595509350505050565b60008060408385031215611be457600080fd5b50508035926020909101359150565b600060208284031215611c0557600080fd5b5035919050565b60a08101611c1a8284611a86565b92915050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b80820180821115611c1a57611c1a611c36565b634e487b7160e01b600052604160045260246000fd5b8082028115828204841417611c1a57611c1a611c36565b81810381811115611c1a57611c1a611c36565b600082611cbc57634e487b7160e01b600052601260045260246000fd5b500490565b60208082528181018390526000908460408401835b86811015611d02576001600160a01b03611cef84611b11565b1682529183019190830190600101611cd6565b509695505050505050565b600060a08284031215611d1f57600080fd5b60405160a0810181811067ffffffffffffffff82111715611d5057634e487b7160e01b600052604160045260246000fd5b604052611d5c83611b11565b8152611d6a60208401611b11565b6020820152611d7b60408401611b11565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b87811015611e1a576001600160a01b0380611dce84611b11565b16845280611ddd878501611b11565b168685015280611dee868501611b11565b168486015250606082810135908401526080808301359084015260a09283019290910190600101611db4565b5090979650505050505050565b6001600160e01b03198316815260408101600b8310611e5657634e487b7160e01b600052602160045260246000fd5b8260208301529392505050565b634e487b7160e01b600052603160045260246000fdfea26469706673582212203139d5d9c469856b74824d5818781b74262f9a82086d9f97e25b722de869ded564736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101425760003560e01c806396c82e57116100b8578063cc7e6b3b1161007c578063cc7e6b3b146102bb578063d78392f8146102ce578063dafae408146102f7578063db6693a21461031a578063e75235b81461033a578063f09267c21461034557600080fd5b806396c82e571461025d578063a85c7d6e14610265578063b505a07c14610278578063b7f67e971461028b578063b9c362091461029357600080fd5b8063562419111161010a57806356241911146101e0578063691845a914610209578063708236251461021c5780637c37103c1461022f5780637de5dedd14610242578063903bb3c51461024a57600080fd5b80630e777c06146101475780630ed285df1461016d578063150740051461018257806341feed1c14610197578063520fce62146101c0575b600080fd5b61015a61015536600461198a565b610358565b6040519081526020015b60405180910390f35b61018061017b366004611a44565b6103c4565b005b61018a6103da565b6040516101649190611ac3565b61015a6101a5366004611b2d565b6001600160a01b031660009081526005602052604090205490565b6101d36101ce36600461198a565b6105c6565b6040516101649190611b48565b61015a6101ee366004611b2d565b6001600160a01b031660009081526007602052604090205490565b61015a61021736600461198a565b61068a565b6101d361022a36600461198a565b6106ef565b61018061023d366004611b80565b6107b3565b61015a6108e1565b61015a61025836600461198a565b61091e565b60035461015a565b61018061027336600461198a565b610983565b610180610286366004611a44565b610a2d565b60095461015a565b6102a66102a1366004611bd1565b610acc565b60408051928352602083019190915201610164565b6101d36102c936600461198a565b610aed565b61015a6102dc366004611b2d565b6001600160a01b031660009081526006602052604090205490565b61030a610305366004611bf3565b610bb1565b6040519015158152602001610164565b61032d610328366004611b2d565b610bd8565b6040516101649190611c0c565b6001546002546102a6565b61032d610353366004611bf3565b610c77565b6000805b828110156103bd576007600085858481811061037a5761037a611c20565b905060200201602081019061038f9190611b2d565b6001600160a01b031681526020810191909152604001600020546103b39083611c4c565b915060010161035c565b5092915050565b6103cc610d7d565b6103d68282610dd9565b5050565b60095460609067ffffffffffffffff8111156103f8576103f8611c5f565b60405190808252806020026020018201604052801561045157816020015b6040805160a0810182526000808252602080830182905292820181905260608201819052608082015282526000199092019101816104165790505b5090506000805b82518110156105c1576009818154811061047457610474611c20565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104a7576104a7611c20565b60209081029190910101516001600160a01b039091169052600a8054829081106104d3576104d3611c20565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061050357610503611c20565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b818154811061053a5761053a611c20565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061056a5761056a611c20565b6020908102919091018101516001600160a01b0392831660409182015291841660009081526005909152205483518490839081106105aa576105aa611c20565b602090810291909101015160600152600101610458565b505090565b60608167ffffffffffffffff8111156105e1576105e1611c5f565b60405190808252806020026020018201604052801561060a578160200160208202803683370190505b50905060005b81518110156103bd576005600085858481811061062f5761062f611c20565b90506020020160208101906106449190611b2d565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061067757610677611c20565b6020908102919091010152600101610610565b6000805b828110156103bd57600560008585848181106106ac576106ac611c20565b90506020020160208101906106c19190611b2d565b6001600160a01b031681526020810191909152604001600020546106e59083611c4c565b915060010161068e565b60608167ffffffffffffffff81111561070a5761070a611c5f565b604051908082528060200260200182016040528015610733578160200160208202803683370190505b50905060005b81518110156103bd576007600085858481811061075857610758611c20565b905060200201602081019061076d9190611b2d565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107a0576107a0611c20565b6020908102919091010152600101610739565b600054610100900460ff16158080156107d35750600054600160ff909116105b806107ed5750303b1580156107ed575060005460ff166001145b6108555760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff191660011790558015610878576000805461ff0019166101001790555b8315610888576108888585610dd9565b6108928383610e4e565b505080156108da576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546108fb9190611c75565b6109059190611c4c565b61090f9190611c8c565b6109199190611c9f565b905090565b6000805b828110156103bd576006600085858481811061094057610940611c20565b90506020020160208101906109559190611b2d565b6001600160a01b031681526020810191909152604001600020546109799083611c4c565b9150600101610922565b61098b610d7d565b60008190036109ad576040516316ee9d3b60e11b815260040160405180910390fd5b60005b818110156109ef576109e78383838181106109cd576109cd611c20565b90506020020160208101906109e29190611b2d565b610ee4565b6001016109b0565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a78282604051610a21929190611cc1565b60405180910390a15050565b610a35610d7d565b6000819003610a57576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610a9a57610a92838383818110610a7757610a77611c20565b905060a00201803603810190610a8d9190611d0d565b611246565b600101610a5a565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610a21929190611d9e565b600080610ad7610d7d565b610ae18484610e4e565b915091505b9250929050565b60608167ffffffffffffffff811115610b0857610b08611c5f565b604051908082528060200260200182016040528015610b31578160200160208202803683370190505b50905060005b81518110156103bd5760066000858584818110610b5657610b56611c20565b9050602002016020810190610b6b9190611b2d565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610b9e57610b9e611c20565b6020908102919091010152600101610b37565b6000600354600154610bc39190611c75565b600254610bd09084611c75565b101592915050565b6040805160a0810182526000808252602082018190529181018290526060810182905260808101829052905b600954811015610c5d57826001600160a01b031660098281548110610c2b57610c2b611c20565b6000918252602090912001546001600160a01b031603610c5557610c4e81610c77565b9392505050565b600101610c04565b5060405163e57fdbef60e01b815260040160405180910390fd5b6040805160a081018252600080825260208201819052918101829052606081018290526080810191909152600060098381548110610cb757610cb7611c20565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610d0457610d04611c20565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610d3557610d35611c20565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610dd7576000356001600160e01b0319166001604051620f948f60ea1b815260040161084c929190611e27565b565b60005b81811015610e1c57610e14838383818110610df957610df9611c20565b905060a00201803603810190610e0f9190611d0d565b61156d565b600101610ddc565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610a21929190611d9e565b60008082841115610e80576040516387f6f09560e01b81526001600160e01b031960003516600482015260240161084c565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b03811660009081526005602052604081205490819003610f29576040516349f748eb60e01b81526001600160a01b038316600482015260240161084c565b600954600090815b81811015610f8057846001600160a01b031660098281548110610f5657610f56611c20565b6000918252602090912001546001600160a01b031603610f7857809250610f80565b600101610f31565b508260036000828254610f939190611c8c565b90915550506001600160a01b038416600090815260086020908152604080832083905560059091528120556009610fcb600183611c8c565b81548110610fdb57610fdb611c20565b600091825260209091200154600980546001600160a01b03909216918490811061100757611007611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600980548061104657611046611e63565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a848154811061108557611085611c20565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a6110b7600183611c8c565b815481106110c7576110c7611c20565b600091825260209091200154600a80546001600160a01b0390921691849081106110f3576110f3611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a80548061113257611132611e63565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b848154811061117157611171611c20565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b6111a3600183611c8c565b815481106111b3576111b3611c20565b600091825260209091200154600b80546001600160a01b0390921691849081106111df576111df611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b80548061121e5761121e611e63565b600082815260209020810160001990810180546001600160a01b031916905501905550505050565b61124f816117b8565b80516001600160a01b0316600090815260056020526040812054908190036112985781516040516349f748eb60e01b81526001600160a01b03909116600482015260240161084c565b60095460005b818110156115675783600001516001600160a01b0316600982815481106112c7576112c7611c20565b6000918252602090912001546001600160a01b03160361155f5782600360008282546112f39190611c8c565b909155505060608401516003805460009061130f908490611c4c565b9250508190555083602001516001600160a01b0316600a828154811061133757611337611c20565b6000918252602090912001546001600160a01b031614611412576020808501516001600160a01b03166000908152600690915260409020541561138d576040516346da180960e01b815260040160405180910390fd5b60066000600a83815481106113a4576113a4611c20565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a8054839081106113e3576113e3611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b828154811061143357611433611c20565b6000918252602090912001546001600160a01b03161461150d576040808501516001600160a01b031660009081526007602052205415611486576040516346da180960e01b815260040160405180910390fd5b60076000600b838154811061149d5761149d611c20565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b8054839081106114de576114de611c20565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b60010161129e565b50505050565b6080810151156115905760405163129c2ce160e31b815260040160405180910390fd5b611599816117b8565b80516001600160a01b0316600090815260056020526040902054156115df57805160405163ada9a35360e01b81526001600160a01b03909116600482015260240161084c565b6020808201516001600160a01b03166000908152600690915260409020541561162c576020810151604051637f5e2f5960e11b81526001600160a01b03909116600482015260240161084c565b6040808201516001600160a01b031660009081526007602052205415611676576040808201519051630f69702d60e01b81526001600160a01b03909116600482015260240161084c565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af90910180546001600160a01b03199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916117b0908490611c4c565b909155505050565b80606001516000036117eb57604051637f11b8a360e11b81526001600160e01b031960003516600482015260240161084c565b604080516003808252608082019092526000916020820160608036833701905050905081600001518160008151811061182657611826611c20565b60200260200101906001600160a01b031690816001600160a01b03168152505081602001518160018151811061185e5761185e611c20565b60200260200101906001600160a01b031690816001600160a01b03168152505081604001518160028151811061189657611896611c20565b60200260200101906001600160a01b031690816001600160a01b0316815250506118bf816118eb565b156103d657604051630d697db160e11b81526001600160e01b031960003516600482015260240161084c565b600081516000036118fe57506000919050565b60005b600183510381101561198157600181015b83518110156119785783818151811061192d5761192d611c20565b60200260200101516001600160a01b031684838151811061195057611950611c20565b60200260200101516001600160a01b031603611970575060019392505050565b600101611912565b50600101611901565b50600092915050565b6000806020838503121561199d57600080fd5b823567ffffffffffffffff808211156119b557600080fd5b818501915085601f8301126119c957600080fd5b8135818111156119d857600080fd5b8660208260051b85010111156119ed57600080fd5b60209290920196919550909350505050565b60008083601f840112611a1157600080fd5b50813567ffffffffffffffff811115611a2957600080fd5b60208301915083602060a083028501011115610ae657600080fd5b60008060208385031215611a5757600080fd5b823567ffffffffffffffff811115611a6e57600080fd5b611a7a858286016119ff565b90969095509350505050565b80516001600160a01b0390811683526020808301518216908401526040808301519091169083015260608082015190830152608090810151910152565b6020808252825182820181905260009190848201906040850190845b81811015611b0557611af2838551611a86565b9284019260a09290920191600101611adf565b50909695505050505050565b80356001600160a01b0381168114611b2857600080fd5b919050565b600060208284031215611b3f57600080fd5b610c4e82611b11565b6020808252825182820181905260009190848201906040850190845b81811015611b0557835183529284019291840191600101611b64565b60008060008060608587031215611b9657600080fd5b843567ffffffffffffffff811115611bad57600080fd5b611bb9878288016119ff565b90989097506020870135966040013595509350505050565b60008060408385031215611be457600080fd5b50508035926020909101359150565b600060208284031215611c0557600080fd5b5035919050565b60a08101611c1a8284611a86565b92915050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b80820180821115611c1a57611c1a611c36565b634e487b7160e01b600052604160045260246000fd5b8082028115828204841417611c1a57611c1a611c36565b81810381811115611c1a57611c1a611c36565b600082611cbc57634e487b7160e01b600052601260045260246000fd5b500490565b60208082528181018390526000908460408401835b86811015611d02576001600160a01b03611cef84611b11565b1682529183019190830190600101611cd6565b509695505050505050565b600060a08284031215611d1f57600080fd5b60405160a0810181811067ffffffffffffffff82111715611d5057634e487b7160e01b600052604160045260246000fd5b604052611d5c83611b11565b8152611d6a60208401611b11565b6020820152611d7b60408401611b11565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b87811015611e1a576001600160a01b0380611dce84611b11565b16845280611ddd878501611b11565b168685015280611dee868501611b11565b168486015250606082810135908401526080808301359084015260a09283019290910190600101611db4565b5090979650505050505050565b6001600160e01b03198316815260408101600b8310611e5657634e487b7160e01b600052602160045260246000fd5b8260208301529392505050565b634e487b7160e01b600052603160045260246000fdfea26469706673582212203139d5d9c469856b74824d5818781b74262f9a82086d9f97e25b722de869ded564736f6c63430008110033", "devdoc": { + "errors": { + "ErrBridgeVoterIsAlreadyAdded(address)": [ + { + "details": "Error indicating that a bridge voter has already been added.", + "params": { + "voter": "The address of the bridge voter that is already added." + } + } + ], + "ErrConsensusAddressIsAlreadyAdded(address)": [ + { + "details": "Error indicating that a consensus address is already added.", + "params": { + "addr": "The address of the consensus contract that is already added." + } + } + ], + "ErrConsensusAddressIsNotAdded(address)": [ + { + "details": "Error indicating that a consensus address is not added.", + "params": { + "addr": "The address of the consensus contract that is not added." + } + } + ], + "ErrDuplicated(bytes4)": [ + { + "details": "Error thrown when a duplicated element is detected in an array.", + "params": { + "msgSig": "The function signature that invoke the error." + } + } + ], + "ErrEmptyArray()": [ + { + "details": "Error indicating that an array is empty when it should contain elements." + } + ], + "ErrGovernorAddressIsAlreadyAdded(address)": [ + { + "details": "Error indicating that a governor address has already been added.", + "params": { + "addr": "The address of the governor that is already added." + } + } + ], + "ErrInvalidRequest()": [ + { + "details": "Error indicating that a request is invalid." + } + ], + "ErrInvalidThreshold(bytes4)": [ + { + "details": "Error indicating that the provided threshold is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that the invalid threshold applies to." + } + } + ], + "ErrInvalidVoteWeight(bytes4)": [ + { + "details": "Error indicating that a vote weight is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that encountered an invalid vote weight." + } + } + ], + "ErrQueryForDupplicated()": [ + { + "details": "Error indicating that a query for a duplicate entry was made." + } + ], + "ErrQueryForNonExistentConsensusAddress()": [ + { + "details": "Error indicating that a query was made for a non-existent consensus address." + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ] + }, "kind": "dev", "methods": { "addTrustedOrganizations((address,address,address,uint256,uint256)[])": { @@ -727,7 +927,7 @@ "checkThreshold(uint256)": { "details": "Checks whether the `_voteWeight` passes the threshold." }, - "countTrustedOrganizations()": { + "countTrustedOrganization()": { "details": "Returns the number of trusted organizations." }, "getAllTrustedOrganizations()": { @@ -775,16 +975,16 @@ "setThreshold(uint256,uint256)": { "details": "Sets the threshold. Requirements: - The method caller is admin. Emits the `ThresholdUpdated` event." }, - "sumBridgeVoterWeights(address[])": { + "sumBridgeVoterWeight(address[])": { "details": "Returns total weights of the bridge voter list." }, - "sumConsensusWeights(address[])": { + "sumConsensusWeight(address[])": { "details": "Returns total weights of the consensus list." }, - "sumGovernorWeights(address[])": { + "sumGovernorWeight(address[])": { "details": "Returns total weights of the governor list." }, - "totalWeights()": { + "totalWeight()": { "details": "Returns total weights." }, "updateTrustedOrganizations((address,address,address,uint256,uint256)[])": { @@ -840,7 +1040,7 @@ "type": "t_bool" }, { - "astId": 19292, + "astId": 22746, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_num", "offset": 0, @@ -848,7 +1048,7 @@ "type": "t_uint256" }, { - "astId": 19294, + "astId": 22748, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_denom", "offset": 0, @@ -856,7 +1056,7 @@ "type": "t_uint256" }, { - "astId": 19296, + "astId": 22750, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_totalWeight", "offset": 0, @@ -864,7 +1064,7 @@ "type": "t_uint256" }, { - "astId": 19298, + "astId": 22752, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_nonce", "offset": 0, @@ -872,7 +1072,7 @@ "type": "t_uint256" }, { - "astId": 19303, + "astId": 22757, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_consensusWeight", "offset": 0, @@ -880,7 +1080,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 19308, + "astId": 22762, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_governorWeight", "offset": 0, @@ -888,7 +1088,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 19313, + "astId": 22767, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_bridgeVoterWeight", "offset": 0, @@ -896,7 +1096,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 19318, + "astId": 22772, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_addedBlock", "offset": 0, @@ -904,7 +1104,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 19322, + "astId": 22776, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_consensusList", "offset": 0, @@ -912,7 +1112,7 @@ "type": "t_array(t_address)dyn_storage" }, { - "astId": 19326, + "astId": 22780, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_governorList", "offset": 0, @@ -920,7 +1120,7 @@ "type": "t_array(t_address)dyn_storage" }, { - "astId": 19330, + "astId": 22784, "contract": "contracts/multi-chains/RoninTrustedOrganization.sol:RoninTrustedOrganization", "label": "_bridgeVoterList", "offset": 0, diff --git a/deployments/ronin-mainnet/RoninValidatorSetLogic.json b/deployments/ronin-mainnet/RoninValidatorSetLogic.json index 4f38380b6..cd433da5f 100644 --- a/deployments/ronin-mainnet/RoninValidatorSetLogic.json +++ b/deployments/ronin-mainnet/RoninValidatorSetLogic.json @@ -1,5 +1,5 @@ { - "address": "0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0", + "address": "0x0C1Dee1b435C464b4E94781f94F991Cb90e3399d", "abi": [ { "inputs": [], @@ -36,41 +36,11 @@ "name": "ErrCallPrecompiled", "type": "error" }, - { - "inputs": [], - "name": "ErrCallerMustBeBridgeTrackingContract", - "type": "error" - }, { "inputs": [], "name": "ErrCallerMustBeCoinbase", "type": "error" }, - { - "inputs": [], - "name": "ErrCallerMustBeMaintenanceContract", - "type": "error" - }, - { - "inputs": [], - "name": "ErrCallerMustBeRoninTrustedOrgContract", - "type": "error" - }, - { - "inputs": [], - "name": "ErrCallerMustBeSlashIndicatorContract", - "type": "error" - }, - { - "inputs": [], - "name": "ErrCallerMustBeStakingContract", - "type": "error" - }, - { - "inputs": [], - "name": "ErrCallerMustBeStakingVestingContract", - "type": "error" - }, { "inputs": [ { @@ -82,20 +52,20 @@ "name": "ErrCannotBailout", "type": "error" }, - { - "inputs": [], - "name": "ErrExceedsMaxNumberOfCandidate", - "type": "error" - }, { "inputs": [ { - "internalType": "address", - "name": "_bridgeOperatorAddr", - "type": "address" + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" } ], - "name": "ErrExistentBridgeOperator", + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrExceedsMaxNumberOfCandidate", "type": "error" }, { @@ -126,7 +96,23 @@ "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "currentBalance", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "sendAmount", + "type": "uint256" + } + ], "name": "ErrInsufficientBalance", "type": "error" }, @@ -156,7 +142,13 @@ "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], "name": "ErrRecipientRevert", "type": "error" }, @@ -165,13 +157,56 @@ "name": "ErrTrustedOrgCannotRenounce", "type": "error" }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, { "inputs": [], "name": "ErrUnauthorizedReceiveRON", "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, @@ -348,25 +383,6 @@ "name": "BridgeOperatorSetUpdated", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "BridgeTrackingContractUpdated", - "type": "event" - }, - { - "anonymous": false, - "inputs": [], - "name": "BridgeTrackingIncorrectlyResponded", - "type": "event" - }, { "anonymous": false, "inputs": [ @@ -387,12 +403,6 @@ "internalType": "address", "name": "admin", "type": "address" - }, - { - "indexed": false, - "internalType": "address", - "name": "bridgeOperator", - "type": "address" } ], "name": "CandidateGranted", @@ -493,6 +503,25 @@ "name": "CommissionRateUpdated", "type": "event" }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, { "anonymous": false, "inputs": [ @@ -641,27 +670,70 @@ { "anonymous": false, "inputs": [ + { + "indexed": true, + "internalType": "address", + "name": "consensusAddr", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "recipient", + "type": "address" + }, { "indexed": false, - "internalType": "uint8", - "name": "version", - "type": "uint8" + "internalType": "uint256", + "name": "amount", + "type": "uint256" } ], - "name": "Initialized", + "name": "FastFinalityRewardDistributed", "type": "event" }, { "anonymous": false, "inputs": [ { - "indexed": false, + "indexed": true, "internalType": "address", - "name": "", + "name": "consensusAddr", + "type": "address" + }, + { + "indexed": true, + "internalType": "address", + "name": "recipient", "type": "address" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "amount", + "type": "uint256" + }, + { + "indexed": false, + "internalType": "uint256", + "name": "contractBalance", + "type": "uint256" + } + ], + "name": "FastFinalityRewardDistributionFailed", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" } ], - "name": "MaintenanceContractUpdated", + "name": "Initialized", "type": "event" }, { @@ -772,45 +844,6 @@ "name": "MiningRewardDistributionFailed", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "RoninTrustedOrganizationContractUpdated", - "type": "event" - }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "SlashIndicatorContractUpdated", - "type": "event" - }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "StakingContractUpdated", - "type": "event" - }, { "anonymous": false, "inputs": [ @@ -867,19 +900,6 @@ "name": "StakingRewardDistributionFailed", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "StakingVestingContractUpdated", - "type": "event" - }, { "anonymous": false, "inputs": [ @@ -1016,32 +1036,19 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [], - "name": "bridgeTrackingContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [ { "internalType": "address", - "name": "_consensusAddr", + "name": "_addr", "type": "address" } ], - "name": "checkBridgeRewardDeprecatedAtLatestPeriod", + "name": "checkJailed", "outputs": [ { "internalType": "bool", - "name": "_result", + "name": "", "type": "bool" } ], @@ -1052,20 +1059,20 @@ "inputs": [ { "internalType": "address", - "name": "_consensusAddr", + "name": "_addr", "type": "address" }, { "internalType": "uint256", - "name": "_period", + "name": "_blockNum", "type": "uint256" } ], - "name": "checkBridgeRewardDeprecatedAtPeriod", + "name": "checkJailedAtBlock", "outputs": [ { "internalType": "bool", - "name": "_result", + "name": "", "type": "bool" } ], @@ -1075,52 +1082,9 @@ { "inputs": [ { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "checkJailed", - "outputs": [ - { - "internalType": "bool", - "name": "", - "type": "bool" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - }, - { - "internalType": "uint256", - "name": "_blockNum", - "type": "uint256" - } - ], - "name": "checkJailedAtBlock", - "outputs": [ - { - "internalType": "bool", - "name": "", - "type": "bool" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address[]", - "name": "_addrList", - "type": "address[]" + "internalType": "address[]", + "name": "_addrList", + "type": "address[]" } ], "name": "checkManyJailed", @@ -1284,11 +1248,6 @@ "name": "_treasuryAddr", "type": "address" }, - { - "internalType": "address", - "name": "_bridgeOperatorAddr", - "type": "address" - }, { "internalType": "uint256", "name": "_commissionRate", @@ -1304,12 +1263,12 @@ "inputs": [ { "internalType": "address", - "name": "_validatorAddr", + "name": "validatorAddr", "type": "address" }, { "internalType": "uint256", - "name": "_period", + "name": "period", "type": "uint256" } ], @@ -1399,22 +1358,22 @@ "inputs": [ { "internalType": "address", - "name": "_validatorAddr", + "name": "validatorAddr", "type": "address" }, { "internalType": "uint256", - "name": "_newJailedUntil", + "name": "newJailedUntil", "type": "uint256" }, { "internalType": "uint256", - "name": "_slashAmount", + "name": "slashAmount", "type": "uint256" }, { "internalType": "bool", - "name": "_cannotBailout", + "name": "cannotBailout", "type": "bool" } ], @@ -1436,38 +1395,6 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [], - "name": "getBridgeOperators", - "outputs": [ - { - "internalType": "address[]", - "name": "_result", - "type": "address[]" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address[]", - "name": "_validatorAddrs", - "type": "address[]" - } - ], - "name": "getBridgeOperatorsOf", - "outputs": [ - { - "internalType": "address[]", - "name": "_result", - "type": "address[]" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [ { @@ -1497,7 +1424,7 @@ }, { "internalType": "address", - "name": "bridgeOperatorAddr", + "name": "______deprecatedbridgeOperatorAddr", "type": "address" }, { @@ -1547,7 +1474,7 @@ }, { "internalType": "address", - "name": "bridgeOperatorAddr", + "name": "______deprecatedbridgeOperatorAddr", "type": "address" }, { @@ -1605,6 +1532,25 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -1733,16 +1679,6 @@ "internalType": "address[]", "name": "_validatorList", "type": "address[]" - }, - { - "internalType": "address[]", - "name": "_bridgeOperators", - "type": "address[]" - }, - { - "internalType": "enum EnumFlags.ValidatorFlag[]", - "name": "_flags", - "type": "uint8[]" } ], "stateMutability": "view", @@ -1777,7 +1713,7 @@ }, { "internalType": "address", - "name": "__bridgeTrackingContract", + "name": "", "type": "address" }, { @@ -1816,38 +1752,39 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [ { "internalType": "address", - "name": "_addr", + "name": "fastFinalityTrackingContract", "type": "address" } ], - "name": "isBlockProducer", - "outputs": [ - { - "internalType": "bool", - "name": "", - "type": "bool" - } - ], - "stateMutability": "view", + "name": "initializeV3", + "outputs": [], + "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ { "internalType": "address", - "name": "_bridgeOperatorAddr", + "name": "_addr", "type": "address" } ], - "name": "isBridgeOperator", + "name": "isBlockProducer", "outputs": [ { "internalType": "bool", - "name": "_isOperator", + "name": "", "type": "bool" } ], @@ -1878,25 +1815,6 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [ - { - "internalType": "address", - "name": "_consensusAddr", - "type": "address" - } - ], - "name": "isOperatingBridge", - "outputs": [ - { - "internalType": "bool", - "name": "", - "type": "bool" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [], "name": "isPeriodEnding", @@ -1910,25 +1828,6 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "isValidator", - "outputs": [ - { - "internalType": "bool", - "name": "", - "type": "bool" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [ { @@ -1948,19 +1847,6 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [], - "name": "maintenanceContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [], "name": "maxPrioritizedValidatorNumber", @@ -2002,7 +1888,7 @@ }, { "inputs": [], - "name": "minEffectiveDaysOnwards", + "name": "minEffectiveDaysOnward", "outputs": [ { "internalType": "uint256", @@ -2052,28 +1938,20 @@ "stateMutability": "view", "type": "function" }, - { - "inputs": [], - "name": "roninTrustedOrganizationContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, { "internalType": "address", - "name": "_addr", + "name": "addr", "type": "address" } ], - "name": "setBridgeTrackingContract", + "name": "setContract", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -2104,19 +1982,6 @@ "stateMutability": "nonpayable", "type": "function" }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setMaintenanceContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, { "inputs": [ { @@ -2169,97 +2034,6 @@ "stateMutability": "nonpayable", "type": "function" }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setRoninTrustedOrganizationContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setSlashIndicatorContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setStakingContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setStakingVestingContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [], - "name": "slashIndicatorContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [], - "name": "stakingContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [], - "name": "stakingVestingContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" - }, { "inputs": [], "name": "submitBlockReward", @@ -2269,20 +2043,7 @@ }, { "inputs": [], - "name": "totalBlockProducers", - "outputs": [ - { - "internalType": "uint256", - "name": "_total", - "type": "uint256" - } - ], - "stateMutability": "view", - "type": "function" - }, - { - "inputs": [], - "name": "totalBridgeOperators", + "name": "totalBlockProducer", "outputs": [ { "internalType": "uint256", @@ -2355,1050 +2116,39 @@ "type": "receive" } ], - "transactionHash": "0x333816480bb4ae5987a01fa77dd356147797438e0d69e7598d641db47f7a9f55", + "transactionHash": "0xcb39bb6b4871d96f9ceb62bffc4bdae2c7a479a5a428375b9517e8e4a0db5753", "receipt": { "to": null, "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", - "contractAddress": "0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0", + "contractAddress": "0x0C1Dee1b435C464b4E94781f94F991Cb90e3399d", "transactionIndex": 2, - "gasUsed": "5386803", - "logsBloom": "0x00000000000000000000000400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0x66e203819c58755a7ace185e09acc05c0172443a528358c38e13e6e77f6d1334", - "transactionHash": "0x333816480bb4ae5987a01fa77dd356147797438e0d69e7598d641db47f7a9f55", + "gasUsed": "4328967", + "logsBloom": "0x00000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000040000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x403527a26d0ddabf4fbd53ce253e907e40af6154761ea6b79149f535a99e85db", + "transactionHash": "0xcb39bb6b4871d96f9ceb62bffc4bdae2c7a479a5a428375b9517e8e4a0db5753", "logs": [ { "transactionIndex": 2, - "blockNumber": 24127506, - "transactionHash": "0x333816480bb4ae5987a01fa77dd356147797438e0d69e7598d641db47f7a9f55", - "address": "0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0", + "blockNumber": 28538546, + "transactionHash": "0xcb39bb6b4871d96f9ceb62bffc4bdae2c7a479a5a428375b9517e8e4a0db5753", + "address": "0x0C1Dee1b435C464b4E94781f94F991Cb90e3399d", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 12, - "blockHash": "0x66e203819c58755a7ace185e09acc05c0172443a528358c38e13e6e77f6d1334" + "logIndex": 9, + "blockHash": "0x403527a26d0ddabf4fbd53ce253e907e40af6154761ea6b79149f535a99e85db" } ], - "blockNumber": 24127506, - "cumulativeGasUsed": "5830410", + "blockNumber": 28538546, + "cumulativeGasUsed": "4670644", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 3, - "solcInputHash": "2a8db5de0d3bfe0cb40ba15ae8460f16", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedEmergencyExit\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedRevokingCandidate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedUpdatingCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyWrappedEpoch\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAtEndOfEpochOnly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallPrecompiled\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeBridgeTrackingContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeCoinbase\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeMaintenanceContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeRoninTrustedOrgContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeSlashIndicatorContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeStakingContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeStakingVestingContract\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"}],\"name\":\"ErrCannotBailout\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrExceedsMaxNumberOfCandidate\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_bridgeOperatorAddr\",\"type\":\"address\"}],\"name\":\"ErrExistentBridgeOperator\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrExistentCandidate\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdminAddr\",\"type\":\"address\"}],\"name\":\"ErrExistentCandidateAdmin\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_treasuryAddr\",\"type\":\"address\"}],\"name\":\"ErrExistentTreasury\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidEffectiveDaysOnwards\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMaxPrioritizedValidatorNumber\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMinEffectiveDaysOnwards\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrNonExistentCandidate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrTrustedOrgCannotRenounce\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnauthorizedReceiveRON\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"NonExistentRecyclingInfo\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epoch\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"BlockProducerSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"coinbaseAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rewardAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"enum ICoinbaseExecution.BlockRewardDeprecatedType\",\"name\":\"deprecatedType\",\"type\":\"uint8\"}],\"name\":\"BlockRewardDeprecated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"coinbaseAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"submittedAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bonusAmount\",\"type\":\"uint256\"}],\"name\":\"BlockRewardSubmitted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epoch\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"BridgeTrackingContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[],\"name\":\"BridgeTrackingIncorrectlyResponded\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"}],\"name\":\"CandidateGranted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"}],\"name\":\"CandidateRevokingTimestampUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"name\":\"CandidateTopupDeadlineUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"CandidatesRevoked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"effectiveTimestamp\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateUpdateScheduled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"balance\",\"type\":\"uint256\"}],\"name\":\"DeprecatedRewardRecycleFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"DeprecatedRewardRecycled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedAmountUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unlockedAmount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedFundReleased\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unlockedAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedFundReleasingFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"lockedAmount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitRequested\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExpiryDurationUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"MaintenanceContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"MaxPrioritizedValidatorNumberUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"}],\"name\":\"MaxValidatorCandidateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"MaxValidatorNumberUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"numOfDays\",\"type\":\"uint256\"}],\"name\":\"MinEffectiveDaysOnwardsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"MiningRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"MiningRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"RoninTrustedOrganizationContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"SlashIndicatorContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"StakingContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"totalAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"amounts\",\"type\":\"uint256[]\"}],\"name\":\"StakingRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"totalAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"amounts\",\"type\":\"uint256[]\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"StakingVestingContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailedUntil\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"deductedStakingAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"blockProducerRewardDeprecated\",\"type\":\"bool\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"bridgeOperatorRewardDeprecated\",\"type\":\"bool\"}],\"name\":\"ValidatorPunished\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"ValidatorSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"ValidatorUnjailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"periodNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epochNumber\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"periodEnding\",\"type\":\"bool\"}],\"name\":\"WrappedUpEpoch\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADDITION_GAS\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"PERIOD_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"bridgeTrackingContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"checkBridgeRewardDeprecatedAtLatestPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"checkBridgeRewardDeprecatedAtPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"checkJailed\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_blockNum\",\"type\":\"uint256\"}],\"name\":\"checkJailedAtBlock\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"}],\"name\":\"checkManyJailed\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_result\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_blockProducer\",\"type\":\"address\"}],\"name\":\"checkMiningRewardDeprecated\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_blockProducer\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"checkMiningRewardDeprecatedAtPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"currentPeriod\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"currentPeriodStartAtBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyExitLockedAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyExpiryDuration\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"epochEndingAt\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"epochOf\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_bridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"execApplyValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"execBailOut\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_secLeftToRevoke\",\"type\":\"uint256\"}],\"name\":\"execEmergencyExit\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_recipient\",\"type\":\"address\"}],\"name\":\"execReleaseLockedFundForEmergencyExitRequest\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_secsLeft\",\"type\":\"uint256\"}],\"name\":\"execRequestRenounceCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_effectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"execRequestUpdateCommissionRate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_newJailedUntil\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_slashAmount\",\"type\":\"uint256\"},{\"internalType\":\"bool\",\"name\":\"_cannotBailout\",\"type\":\"bool\"}],\"name\":\"execSlash\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBlockProducers\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_result\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeOperators\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_result\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validatorAddrs\",\"type\":\"address[]\"}],\"name\":\"getBridgeOperatorsOf\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_result\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateInfo\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.ValidatorCandidate\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCandidateInfos\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"bridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.ValidatorCandidate[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCommissionChangeSchedule\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"effectiveTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.CommissionSchedule\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getEmergencyExitInfo\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"lockedAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"recyclingAt\",\"type\":\"uint256\"}],\"internalType\":\"struct ICommonInfo.EmergencyExitInfo\",\"name\":\"_info\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"getJailedTimeLeft\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"isJailed_\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"blockLeft_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"epochLeft_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_blockNum\",\"type\":\"uint256\"}],\"name\":\"getJailedTimeLeftAtBlock\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"isJailed_\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"blockLeft_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"epochLeft_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getLastUpdatedBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getValidatorCandidates\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getValidators\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_validatorList\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_bridgeOperators\",\"type\":\"address[]\"},{\"internalType\":\"enum EnumFlags.ValidatorFlag[]\",\"name\":\"_flags\",\"type\":\"uint8[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__slashIndicatorContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__stakingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__stakingVestingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__maintenanceContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninTrustedOrganizationContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__bridgeTrackingContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__maxValidatorNumber\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxValidatorCandidate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxPrioritizedValidatorNumber\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__minEffectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__numberOfBlocksInEpoch\",\"type\":\"uint256\"},{\"internalType\":\"uint256[2]\",\"name\":\"__emergencyExitConfigs\",\"type\":\"uint256[2]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"isBlockProducer\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_bridgeOperatorAddr\",\"type\":\"address\"}],\"name\":\"isBridgeOperator\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_isOperator\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"}],\"name\":\"isCandidateAdmin\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"isOperatingBridge\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"isPeriodEnding\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"isValidator\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"isValidatorCandidate\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maintenanceContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxPrioritizedValidatorNumber\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_maximumPrioritizedValidatorNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxValidatorCandidate\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxValidatorNumber\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_maximumValidatorNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minEffectiveDaysOnwards\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"numberOfBlocksInEpoch\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_numberOfBlocks\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompilePickValidatorSetAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompileSortValidatorsAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"roninTrustedOrganizationContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setBridgeTrackingContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_emergencyExitLockedAmount\",\"type\":\"uint256\"}],\"name\":\"setEmergencyExitLockedAmount\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_emergencyExpiryDuration\",\"type\":\"uint256\"}],\"name\":\"setEmergencyExpiryDuration\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setMaintenanceContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_number\",\"type\":\"uint256\"}],\"name\":\"setMaxPrioritizedValidatorNumber\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_number\",\"type\":\"uint256\"}],\"name\":\"setMaxValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_max\",\"type\":\"uint256\"}],\"name\":\"setMaxValidatorNumber\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numOfDays\",\"type\":\"uint256\"}],\"name\":\"setMinEffectiveDaysOnwards\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setRoninTrustedOrganizationContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setSlashIndicatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setStakingContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setStakingVestingContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"slashIndicatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"stakingContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"stakingVestingContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"submitBlockReward\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalBlockProducers\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_total\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalBridgeOperators\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_total\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalDeprecatedReward\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_epoch\",\"type\":\"uint256\"}],\"name\":\"tryGetPeriodOfEpoch\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_filled\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"_periodNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"wrapUpEpoch\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrAlreadyRequestedEmergencyExit()\":[{\"details\":\"Error of already requested emergency exit before.\"}],\"ErrAlreadyRequestedRevokingCandidate()\":[{\"details\":\"Error of already requested revoking candidate before.\"}],\"ErrAlreadyRequestedUpdatingCommissionRate()\":[{\"details\":\"Error of commission change schedule exists.\"}],\"ErrAlreadyWrappedEpoch()\":[{\"details\":\"Error of query for already wrapped up epoch\"}],\"ErrAtEndOfEpochOnly()\":[{\"details\":\"Error of only allowed at the end of epoch\"}],\"ErrCallPrecompiled()\":[{\"details\":\"Error of call to precompile fails.\"}],\"ErrCallerMustBeBridgeTrackingContract()\":[{\"details\":\"Error of method caller must be bridge tracking contract.\"}],\"ErrCallerMustBeCoinbase()\":[{\"details\":\"Error of method caller must be coinbase\"}],\"ErrCallerMustBeMaintenanceContract()\":[{\"details\":\"Error of method caller must be maintenance contract.\"}],\"ErrCallerMustBeRoninTrustedOrgContract()\":[{\"details\":\"Error of method caller must be Ronin trusted org contract.\"}],\"ErrCallerMustBeSlashIndicatorContract()\":[{\"details\":\"Error of method caller must be slash indicator contract.\"}],\"ErrCallerMustBeStakingContract()\":[{\"details\":\"Error of method caller must be staking contract.\"}],\"ErrCallerMustBeStakingVestingContract()\":[{\"details\":\"Error of method caller must be staking vesting contract.\"}],\"ErrCannotBailout(address)\":[{\"details\":\"Error of cannot bailout due to high tier slash.\"}],\"ErrExceedsMaxNumberOfCandidate()\":[{\"details\":\"Error of exceeding maximum number of candidates.\"}],\"ErrExistentBridgeOperator(address)\":[{\"details\":\"Error of bridge operator already exists.\"}],\"ErrExistentCandidate()\":[{\"details\":\"Error of querying for already existent candidate.\"}],\"ErrExistentCandidateAdmin(address)\":[{\"details\":\"Error of candidate admin already exists.\"}],\"ErrExistentTreasury(address)\":[{\"details\":\"Error of treasury already exists.\"}],\"ErrInsufficientBalance()\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInvalidCommissionRate()\":[{\"details\":\"Error of invalid commission rate.\"}],\"ErrInvalidEffectiveDaysOnwards()\":[{\"details\":\"Error of invalid effective days onwards.\"}],\"ErrInvalidMaxPrioritizedValidatorNumber()\":[{\"details\":\"Error of number of prioritized greater than number of max validators.\"}],\"ErrInvalidMinEffectiveDaysOnwards()\":[{\"details\":\"Error of invalid min effective days onwards.\"}],\"ErrNonExistentCandidate()\":[{\"details\":\"Error of querying for non-existent candidate.\"}],\"ErrRecipientRevert()\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrTrustedOrgCannotRenounce()\":[{\"details\":\"Error of trusted org cannot renounce.\"}],\"ErrUnauthorizedReceiveRON()\":[{\"details\":\"Error thrown when receives RON from neither staking vesting contract nor staking contract\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}],\"NonExistentRecyclingInfo()\":[{\"details\":\"Error thrown when queries for a non existent info.\"}]},\"kind\":\"dev\",\"methods\":{\"bridgeTrackingContract()\":{\"details\":\"Returns the bridge tracking contract.\"},\"checkBridgeRewardDeprecatedAtLatestPeriod(address)\":{\"details\":\"Because the information of deprecating bridge reward of a period is only determined at the end of that period, this method will return the deprecating info of the latest period. A method for querying that info of current period is no need.\"},\"checkBridgeRewardDeprecatedAtPeriod(address,uint256)\":{\"details\":\"Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\"},\"checkJailed(address)\":{\"details\":\"Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\"},\"checkJailedAtBlock(address,uint256)\":{\"details\":\"Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\"},\"checkManyJailed(address[])\":{\"details\":\"Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\"},\"checkMiningRewardDeprecated(address)\":{\"details\":\"Returns whether the incoming reward of the block producer is deprecated during the current period.\"},\"checkMiningRewardDeprecatedAtPeriod(address,uint256)\":{\"details\":\"Returns whether the incoming reward of the block producer is deprecated during a specific period.\"},\"currentPeriod()\":{\"details\":\"Returns the period index from the current block.\"},\"currentPeriodStartAtBlock()\":{\"details\":\"Returns the block number that the current period starts at.\"},\"emergencyExitLockedAmount()\":{\"details\":\"Returns the amount of RON to lock from a consensus address.\"},\"emergencyExpiryDuration()\":{\"details\":\"Returns the duration that an emergency request is expired and the fund will be recycled.\"},\"epochEndingAt(uint256)\":{\"details\":\"Returns whether the epoch ending is at the block number `_block`.\"},\"epochOf(uint256)\":{\"details\":\"Returns the epoch index from the block number.\"},\"execApplyValidatorCandidate(address,address,address,address,uint256)\":{\"details\":\"Grants a validator candidate. Requirements: - The method caller is staking contract. Emits the event `CandidateGranted`.\"},\"execBailOut(address,uint256)\":{\"details\":\"Finalize the bailout request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorUnjailed`.\"},\"execEmergencyExit(address,uint256)\":{\"details\":\"Fallback function of `IStaking-requestEmergencyExit`. Requirements: - The method caller is staking contract.\"},\"execReleaseLockedFundForEmergencyExitRequest(address,address)\":{\"details\":\"Unlocks fund for emergency exit request. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked. Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\"},\"execRequestRenounceCandidate(address,uint256)\":{\"details\":\"Requests to revoke a validator candidate in next `_secsLeft` seconds. Requirements: - The method caller is staking contract. Emits the event `CandidateRevokingTimestampUpdated`.\"},\"execRequestUpdateCommissionRate(address,uint256,uint256)\":{\"details\":\"Fallback function of `CandidateStaking-requestUpdateCommissionRate`. Requirements: - The method caller is the staking contract. - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards - The `_rate` must be in range of [0_00; 100_00]. Emits the event `CommissionRateUpdateScheduled`.\"},\"execSlash(address,uint256,uint256,bool)\":{\"details\":\"Finalize the slash request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorPunished`.\"},\"getBlockProducers()\":{\"details\":\"Returns the current block producer list.\"},\"getBridgeOperators()\":{\"details\":\"Returns the current bridge operator list.\"},\"getBridgeOperatorsOf(address[])\":{\"details\":\"Returns the bridge operator list corresponding to validator address list.\"},\"getCandidateInfo(address)\":{\"details\":\"Returns the info of a candidate.\"},\"getCandidateInfos()\":{\"details\":\"Returns all candidate info.\"},\"getCommissionChangeSchedule(address)\":{\"details\":\"Returns the schedule of changing commission rate of a candidate address.\"},\"getEmergencyExitInfo(address)\":{\"details\":\"Returns the emergency exit request.\"},\"getJailedTimeLeft(address)\":{\"details\":\"Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\"},\"getJailedTimeLeftAtBlock(address,uint256)\":{\"details\":\"Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\"},\"getLastUpdatedBlock()\":{\"details\":\"Returns the block that validator set was updated.\"},\"getValidatorCandidates()\":{\"details\":\"Returns the validator candidate.\"},\"getValidators()\":{\"details\":\"Returns the current validator list.\"},\"initialize(address,address,address,address,address,address,uint256,uint256,uint256,uint256,uint256,uint256[2])\":{\"details\":\"Initializes the contract storage.\"},\"isBlockProducer(address)\":{\"details\":\"Returns whether the address is block producer or not.\"},\"isBridgeOperator(address)\":{\"details\":\"Returns whether the address is bridge operator.\"},\"isCandidateAdmin(address,address)\":{\"details\":\"Returns whether the address is the candidate admin.\"},\"isOperatingBridge(address)\":{\"details\":\"Returns whether the consensus address is operating the bridge or not.\"},\"isPeriodEnding()\":{\"details\":\"Returns whether the period ending at the current block number.\"},\"isValidator(address)\":{\"details\":\"Returns whether the address is either a bridge operator or a block producer.\"},\"isValidatorCandidate(address)\":{\"details\":\"Returns whether the address is a validator (candidate).\"},\"maintenanceContract()\":{\"details\":\"Returns the maintenance contract.\"},\"maxPrioritizedValidatorNumber()\":{\"details\":\"Returns the number of reserved slots for prioritized validators.\"},\"maxValidatorCandidate()\":{\"details\":\"Returns the maximum number of validator candidate.\"},\"maxValidatorNumber()\":{\"details\":\"Returns the maximum number of validators in the epoch.\"},\"minEffectiveDaysOnwards()\":{\"details\":\"Returns the minimum number of days to the effective date of commission rate change.\"},\"numberOfBlocksInEpoch()\":{\"details\":\"Returns the number of blocks in a epoch.\"},\"precompilePickValidatorSetAddress()\":{\"details\":\"Gets the address of the precompile of picking validator set\"},\"precompileSortValidatorsAddress()\":{\"details\":\"Gets the address of the precompile of sorting validators\"},\"roninTrustedOrganizationContract()\":{\"details\":\"Returns the ronin trusted organization contract.\"},\"setBridgeTrackingContract(address)\":{\"details\":\"Sets the bridge tracking contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `BridgeTrackingContractUpdated`.\"},\"setEmergencyExitLockedAmount(uint256)\":{\"details\":\"Sets the amount of RON to lock from a consensus address. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedAmountUpdated`.\"},\"setEmergencyExpiryDuration(uint256)\":{\"details\":\"Sets the duration that an emergency request is expired and the fund will be recycled. Requirements: - The method caller is admin. Emits the event `EmergencyExpiryDurationUpdated`.\"},\"setMaintenanceContract(address)\":{\"details\":\"Sets the maintenance contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `MaintenanceContractUpdated`.\"},\"setMaxPrioritizedValidatorNumber(uint256)\":{\"details\":\"Updates the number of reserved slots for prioritized validators Requirements: - The method caller is admin Emits the event `MaxPrioritizedValidatorNumberUpdated`\"},\"setMaxValidatorCandidate(uint256)\":{\"details\":\"Sets the maximum number of validator candidate. Requirements: - The method caller is admin. Emits the `MaxValidatorCandidateUpdated` event.\"},\"setMaxValidatorNumber(uint256)\":{\"details\":\"Updates the max validator number Requirements: - The method caller is admin Emits the event `MaxValidatorNumberUpdated`\"},\"setMinEffectiveDaysOnwards(uint256)\":{\"details\":\"Sets the minimum number of days to the effective date of commision rate change. Requirements: - The method caller is admin. Emits the `MinEffectiveDaysOnwardsUpdated` event.\"},\"setRoninTrustedOrganizationContract(address)\":{\"details\":\"Sets the ronin trusted organization contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninTrustedOrganizationContractUpdated`.\"},\"setSlashIndicatorContract(address)\":{\"details\":\"Sets the slash indicator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `SlashIndicatorContractUpdated`.\"},\"setStakingContract(address)\":{\"details\":\"Sets the staking contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `StakingContractUpdated`.\"},\"setStakingVestingContract(address)\":{\"details\":\"Sets the staking vesting contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `StakingVestingContractUpdated`.\"},\"slashIndicatorContract()\":{\"details\":\"Returns the slash indicator contract.\"},\"stakingContract()\":{\"details\":\"Returns the staking contract.\"},\"stakingVestingContract()\":{\"details\":\"Returns the staking vesting contract.\"},\"submitBlockReward()\":{\"details\":\"Submits reward of the current block. Requirements: - The method caller is coinbase. Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer. Emits the event `BlockRewardSubmitted` for the valid call.\"},\"totalBlockProducers()\":{\"details\":\"Returns total numbers of the block producers.\"},\"totalBridgeOperators()\":{\"details\":\"Returns total numbers of the bridge operators.\"},\"totalDeprecatedReward()\":{\"details\":\"Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\"},\"tryGetPeriodOfEpoch(uint256)\":{\"details\":\"Tries to get the period index from the epoch number.\"},\"wrapUpEpoch()\":{\"details\":\"Wraps up the current epoch. Requirements: - The method must be called when the current epoch is ending. - The epoch is not wrapped yet. - The method caller is coinbase. Emits the event `MiningRewardDistributed` when some validator has reward distributed. Emits the event `StakingRewardDistributed` when some staking pool has reward distributed. Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up. Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending. Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated. Emits the event `WrappedUpEpoch`.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/validator/RoninValidatorSet.sol\":\"RoninValidatorSet\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":0},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert();\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance();\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable _recipient, uint256 _amount) internal {\\n if (!_sendRON(_recipient, _amount)) revert ErrRecipientRevert();\\n }\\n\\n /**\\n * @dev Send `_amount` RON to the address `_recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n if (address(this).balance < _amount) revert ErrInsufficientBalance();\\n return _unsafeSendRON(_recipient, _amount);\\n }\\n\\n /**\\n * @dev Unsafe send `_amount` RON to the address `_recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRON(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRON(\\n address payable _recipient,\\n uint256 _amount,\\n uint256 _gas\\n ) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount, gas: _gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xbf47d40b2431cf190fa737b803e4cb6fb55aee3f8804470da57a9e340f7914f8\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasBridgeTrackingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasBridgeTrackingContract.sol\\\";\\nimport \\\"../../interfaces/IBridgeTracking.sol\\\";\\n\\ncontract HasBridgeTrackingContract is IHasBridgeTrackingContract, HasProxyAdmin {\\n IBridgeTracking internal _bridgeTrackingContract;\\n\\n modifier onlyBridgeTrackingContract() {\\n if (bridgeTrackingContract() != msg.sender) revert ErrCallerMustBeBridgeTrackingContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasBridgeTrackingContract\\n */\\n function bridgeTrackingContract() public view override returns (address) {\\n return address(_bridgeTrackingContract);\\n }\\n\\n /**\\n * @inheritdoc IHasBridgeTrackingContract\\n */\\n function setBridgeTrackingContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setBridgeTrackingContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the bridge tracking contract.\\n *\\n * Emits the event `BridgeTrackingContractUpdated`.\\n *\\n */\\n function _setBridgeTrackingContract(address _addr) internal {\\n _bridgeTrackingContract = IBridgeTracking(_addr);\\n emit BridgeTrackingContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x195b0d3fc2305aa4620f5091ba161f3e983b4cef2272d80f5f5b180a8ab98a34\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasMaintenanceContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasMaintenanceContract.sol\\\";\\nimport \\\"../../interfaces/IMaintenance.sol\\\";\\n\\ncontract HasMaintenanceContract is IHasMaintenanceContract, HasProxyAdmin {\\n IMaintenance internal _maintenanceContract;\\n\\n modifier onlyMaintenanceContract() {\\n if (maintenanceContract() != msg.sender) revert ErrCallerMustBeMaintenanceContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasMaintenanceContract\\n */\\n function maintenanceContract() public view override returns (address) {\\n return address(_maintenanceContract);\\n }\\n\\n /**\\n * @inheritdoc IHasMaintenanceContract\\n */\\n function setMaintenanceContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setMaintenanceContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the scheduled maintenance contract.\\n *\\n * Emits the event `MaintenanceContractUpdated`.\\n *\\n */\\n function _setMaintenanceContract(address _addr) internal {\\n _maintenanceContract = IMaintenance(_addr);\\n emit MaintenanceContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x117a29d878d44a20350df8ab539d34335713ba0f3b2c768a58124f61efb74357\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasRoninTrustedOrganizationContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasRoninTrustedOrganizationContract.sol\\\";\\nimport \\\"../../interfaces/IRoninTrustedOrganization.sol\\\";\\n\\ncontract HasRoninTrustedOrganizationContract is IHasRoninTrustedOrganizationContract, HasProxyAdmin {\\n IRoninTrustedOrganization internal _roninTrustedOrganizationContract;\\n\\n modifier onlyRoninTrustedOrganizationContract() {\\n if (roninTrustedOrganizationContract() != msg.sender) revert ErrCallerMustBeRoninTrustedOrgContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasRoninTrustedOrganizationContract\\n */\\n function roninTrustedOrganizationContract() public view override returns (address) {\\n return address(_roninTrustedOrganizationContract);\\n }\\n\\n /**\\n * @inheritdoc IHasRoninTrustedOrganizationContract\\n */\\n function setRoninTrustedOrganizationContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setRoninTrustedOrganizationContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the ronin trusted organization contract.\\n *\\n * Emits the event `RoninTrustedOrganizationContractUpdated`.\\n *\\n */\\n function _setRoninTrustedOrganizationContract(address _addr) internal {\\n _roninTrustedOrganizationContract = IRoninTrustedOrganization(_addr);\\n emit RoninTrustedOrganizationContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x951fd730f4853d8c932da5484ea093f3094c8186735b603d31fb53035c395751\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasSlashIndicatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasSlashIndicatorContract.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashIndicator.sol\\\";\\n\\ncontract HasSlashIndicatorContract is IHasSlashIndicatorContract, HasProxyAdmin {\\n ISlashIndicator internal _slashIndicatorContract;\\n\\n modifier onlySlashIndicatorContract() {\\n if (slashIndicatorContract() != msg.sender) revert ErrCallerMustBeSlashIndicatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasSlashIndicatorContract\\n */\\n function slashIndicatorContract() public view override returns (address) {\\n return address(_slashIndicatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasSlashIndicatorContract\\n */\\n function setSlashIndicatorContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setSlashIndicatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the slash indicator contract.\\n *\\n * Emits the event `SlashIndicatorContractUpdated`.\\n *\\n */\\n function _setSlashIndicatorContract(address _addr) internal {\\n _slashIndicatorContract = ISlashIndicator(_addr);\\n emit SlashIndicatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x280c56e53c53bf1438cf7d3e71026baf383d24332359bce59282074c94abe5bb\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasStakingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasStakingContract.sol\\\";\\nimport \\\"../../interfaces/staking/IStaking.sol\\\";\\n\\ncontract HasStakingContract is IHasStakingContract, HasProxyAdmin {\\n IStaking internal _stakingContract;\\n\\n modifier onlyStakingContract() {\\n if (stakingContract() != msg.sender) revert ErrCallerMustBeStakingContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasStakingContract\\n */\\n function stakingContract() public view override returns (address) {\\n return address(_stakingContract);\\n }\\n\\n /**\\n * @inheritdoc IHasStakingContract\\n */\\n function setStakingContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setStakingContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the staking contract.\\n *\\n * Emits the event `StakingContractUpdated`.\\n *\\n */\\n function _setStakingContract(address _addr) internal {\\n _stakingContract = IStaking(_addr);\\n emit StakingContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x54d2a4608e0a8819ebd7fdb4ae784d3c709285e93f002034f9e2e787a6607923\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasStakingVestingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasStakingVestingContract.sol\\\";\\nimport \\\"../../interfaces/IStakingVesting.sol\\\";\\n\\ncontract HasStakingVestingContract is IHasStakingVestingContract, HasProxyAdmin {\\n IStakingVesting internal _stakingVestingContract;\\n\\n modifier onlyStakingVestingContract() {\\n if (stakingVestingContract() != msg.sender) revert ErrCallerMustBeStakingVestingContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasStakingVestingContract\\n */\\n function stakingVestingContract() public view override returns (address) {\\n return address(_stakingVestingContract);\\n }\\n\\n /**\\n * @inheritdoc IHasStakingVestingContract\\n */\\n function setStakingVestingContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setStakingVestingContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the staking vesting contract.\\n *\\n * Emits the event `StakingVestingContractUpdated`.\\n *\\n */\\n function _setStakingVestingContract(address _addr) internal {\\n _stakingVestingContract = IStakingVesting(_addr);\\n emit StakingVestingContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x1893fae5d612b0d78f6d66695194aa6b03817a3b92be602887918781fba29e37\",\"license\":\"MIT\"},\"contracts/extensions/consumers/GlobalConfigConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract GlobalConfigConsumer {\\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\\n /// @dev The length of a period in second.\\n uint256 public constant PERIOD_DURATION = 1 days;\\n}\\n\",\"keccak256\":\"0x96d6b1ea4c8e126a8c2468683e7513d195f8e05456d85dd8f259ab049347b527\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/IBridgeTracking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IBridgeTracking {\\n struct Request {\\n VoteKind kind;\\n uint256 id;\\n }\\n\\n enum VoteKind {\\n Deposit,\\n Withdrawal,\\n MainchainWithdrawal\\n }\\n\\n /**\\n * @dev Returns the total number of votes at the specific period `_period`.\\n */\\n function totalVotes(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots at the specific period `_period`.\\n */\\n function totalBallots(uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\\n */\\n function getManyTotalBallots(uint256 _period, address[] calldata _bridgeOperators)\\n external\\n view\\n returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\\n */\\n function totalBallotsOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\\n\\n /**\\n * @dev Handles the request once it is approved.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\\n\\n /**\\n * @dev Records vote for a receipt and a operator.\\n *\\n * Requirements:\\n * - The method caller is the bridge contract.\\n *\\n */\\n function recordVote(\\n VoteKind _kind,\\n uint256 _requestId,\\n address _operator\\n ) external;\\n}\\n\",\"keccak256\":\"0x6066ff36c2ad0494a676dfeb4289c3cbe48d0d70266e8ec0930014a41f2a39a3\",\"license\":\"MIT\"},\"contracts/interfaces/IMaintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IMaintenance {\\n struct Schedule {\\n uint256 from;\\n uint256 to;\\n uint256 lastUpdatedBlock;\\n uint256 requestTimestamp;\\n }\\n\\n /// @dev Emitted when a maintenance is scheduled.\\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\\n /// @dev Emitted when a schedule of maintenance is cancelled.\\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\\n /// @dev Emitted when the maintenance config is updated.\\n event MaintenanceConfigUpdated(\\n uint256 minMaintenanceDurationInBlock,\\n uint256 maxMaintenanceDurationInBlock,\\n uint256 minOffsetToStartSchedule,\\n uint256 maxOffsetToStartSchedule,\\n uint256 maxSchedules,\\n uint256 cooldownSecsToMaintain\\n );\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool);\\n\\n /**\\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\\n */\\n function checkScheduled(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr`\\n */\\n function checkCooldownEnds(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\\n */\\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\\n\\n /**\\n * @dev Returns the total of current schedules.\\n */\\n function totalSchedules() external view returns (uint256 _count);\\n\\n /**\\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The max duration is larger than the min duration.\\n * - The max offset is larger than the min offset.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external;\\n\\n /**\\n * @dev Returns the min duration for maintenance in block.\\n */\\n function minMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max duration for maintenance in block.\\n */\\n function maxMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the min block number that the schedule can start\\n */\\n function minOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the max block number that the schedule can start\\n */\\n function maxOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max number of scheduled maintenances.\\n */\\n function maxSchedules() external view returns (uint256);\\n\\n /**\\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\\n * - The total number of schedules is not larger than `maxSchedules()`.\\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\\n * - The end block is larger than the start block.\\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\\n * - The start block is at the start of an epoch.\\n * - The end block is at the end of an epoch.\\n *\\n * Emits the event `MaintenanceScheduled`.\\n *\\n */\\n function schedule(\\n address _consensusAddr,\\n uint256 _startedAtBlock,\\n uint256 _endedAtBlock\\n ) external;\\n\\n /**\\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\\n *\\n * Emits the event `MaintenanceScheduleCancelled`.\\n */\\n function cancelSchedule(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x4f06c8f3ad7ec8b863882c655ddf443675d557272445e51d8a1e1f3454089d09\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(uint256 _numerator, uint256 _denominator)\\n external\\n returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x10f3b360430e6d03773c9959f54cbed6fb0346069645c05b05ef50cfb19f3753\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninGovernanceAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../libraries/BridgeOperatorsBallot.sol\\\";\\n\\ninterface IRoninGovernanceAdmin {\\n /// @dev Emitted when the bridge operators are approved.\\n event BridgeOperatorsApproved(uint256 _period, uint256 _epoch, address[] _operators);\\n /// @dev Emitted when an emergency exit poll is created.\\n event EmergencyExitPollCreated(\\n bytes32 _voteHash,\\n address _consensusAddr,\\n address _recipientAfterUnlockedFund,\\n uint256 _requestedAt,\\n uint256 _expiredAt\\n );\\n /// @dev Emitted when an emergency exit poll is approved.\\n event EmergencyExitPollApproved(bytes32 _voteHash);\\n /// @dev Emitted when an emergency exit poll is expired.\\n event EmergencyExitPollExpired(bytes32 _voteHash);\\n\\n /**\\n * @dev Returns the last voted block of the bridge voter.\\n */\\n function lastVotedBlock(address _bridgeVoter) external view returns (uint256);\\n\\n /**\\n * @dev Returns the synced bridge operator set info.\\n */\\n function lastSyncedBridgeOperatorSetInfo()\\n external\\n view\\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory _bridgeOperatorSetInfo);\\n\\n /**\\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\\n *\\n * Requirements:\\n * - The method caller is validator contract.\\n *\\n */\\n function createEmergencyExitPoll(\\n address _consensusAddr,\\n address _recipientAfterUnlockedFund,\\n uint256 _requestedAt,\\n uint256 _expiredAt\\n ) external;\\n}\\n\",\"keccak256\":\"0x1aa218f9a8cad8fa9f865c179b257aa8f2614e034100dedebdd352da9a7d96d9\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeights() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganizations() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x1edb7a3f5d340e7efc141cb8d94c5499954dec869f026d3998ad92cbc714d604\",\"license\":\"MIT\"},\"contracts/interfaces/IStakingVesting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IStakingVesting {\\n /// @dev Emitted when the block bonus for block producer is transferred.\\n event BonusTransferred(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount\\n );\\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\\n event BonusTransferFailed(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the block bonus for block producer is updated\\n event BlockProducerBonusPerBlockUpdated(uint256);\\n /// @dev Emitted when the block bonus for bridge operator is updated\\n event BridgeOperatorBonusPerBlockUpdated(uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the block producer at `_block`.\\n */\\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the bridge validator at `_block`.\\n */\\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Receives RON from any address.\\n */\\n function receiveRON() external payable;\\n\\n /**\\n * @dev Returns the last block number that the staking vesting is sent.\\n */\\n function lastBlockSendingBonus() external view returns (uint256);\\n\\n /**\\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n * - The method must be called only once per block.\\n *\\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\\n *\\n * Notes:\\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\\n * will not be reverted, and the underlying nodes does not hang.\\n *\\n * @param _forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\\n * @param _forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\\n *\\n * @return _success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\\n * @return _blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\\n * @return _bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\\n *\\n */\\n function requestBonus(bool _forBlockProducer, bool _forBridgeOperator)\\n external\\n returns (\\n bool _success,\\n uint256 _blockProducerBonus,\\n uint256 _bridgeOperatorBonus\\n );\\n\\n /**\\n * @dev Sets the bonus amount per block for block producer.\\n *\\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\\n\\n /**\\n * @dev Sets the bonus amount per block for bridge operator.\\n *\\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\\n}\\n\",\"keccak256\":\"0x6705fdccf03c4acd34ceb1034c2ab556c901781d6d5597e63f257eafe75cf1ae\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasBridgeTrackingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasBridgeTrackingContract is IHasContract {\\n /// @dev Emitted when the bridge tracking contract is updated.\\n event BridgeTrackingContractUpdated(address);\\n\\n /// @dev Error of method caller must be bridge tracking contract.\\n error ErrCallerMustBeBridgeTrackingContract();\\n\\n /**\\n * @dev Returns the bridge tracking contract.\\n */\\n function bridgeTrackingContract() external view returns (address);\\n\\n /**\\n * @dev Sets the bridge tracking contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `BridgeTrackingContractUpdated`.\\n *\\n */\\n function setBridgeTrackingContract(address) external;\\n}\\n\",\"keccak256\":\"0x2d1b7e356826bfe1c2a3348137d828f46ca931f7c2f48197379ad987e713714b\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasMaintenanceContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasMaintenanceContract is IHasContract {\\n /// @dev Emitted when the maintenance contract is updated.\\n event MaintenanceContractUpdated(address);\\n\\n /// @dev Error of method caller must be maintenance contract.\\n error ErrCallerMustBeMaintenanceContract();\\n\\n /**\\n * @dev Returns the maintenance contract.\\n */\\n function maintenanceContract() external view returns (address);\\n\\n /**\\n * @dev Sets the maintenance contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `MaintenanceContractUpdated`.\\n *\\n */\\n function setMaintenanceContract(address) external;\\n}\\n\",\"keccak256\":\"0x0a0ef6ba14e2929c7c8dda0642a7a831c9997d1b0d049eb83f64dfc21ff0e72e\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasRoninTrustedOrganizationContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasRoninTrustedOrganizationContract is IHasContract {\\n /// @dev Emitted when the ronin trusted organization contract is updated.\\n event RoninTrustedOrganizationContractUpdated(address);\\n\\n /// @dev Error of method caller must be Ronin trusted org contract.\\n error ErrCallerMustBeRoninTrustedOrgContract();\\n\\n /**\\n * @dev Returns the ronin trusted organization contract.\\n */\\n function roninTrustedOrganizationContract() external view returns (address);\\n\\n /**\\n * @dev Sets the ronin trusted organization contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `RoninTrustedOrganizationContractUpdated`.\\n *\\n */\\n function setRoninTrustedOrganizationContract(address) external;\\n}\\n\",\"keccak256\":\"0x7d0a0b1d658e9cf4d69f4934748e0a5c1d22183024d26927f5d621fc61aff0b2\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasSlashIndicatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasSlashIndicatorContract is IHasContract {\\n /// @dev Emitted when the slash indicator contract is updated.\\n event SlashIndicatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be slash indicator contract.\\n error ErrCallerMustBeSlashIndicatorContract();\\n\\n /**\\n * @dev Returns the slash indicator contract.\\n */\\n function slashIndicatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `SlashIndicatorContractUpdated`.\\n *\\n */\\n function setSlashIndicatorContract(address) external;\\n}\\n\",\"keccak256\":\"0xfaaeec87f74039a55fe451c07c341b88794e62a8a331c878a8d9e91f55f1ff45\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasStakingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasStakingContract is IHasContract {\\n /// @dev Emitted when the staking contract is updated.\\n event StakingContractUpdated(address);\\n\\n /// @dev Error of method caller must be staking contract.\\n error ErrCallerMustBeStakingContract();\\n\\n /**\\n * @dev Returns the staking contract.\\n */\\n function stakingContract() external view returns (address);\\n\\n /**\\n * @dev Sets the staking contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `StakingContractUpdated`.\\n *\\n */\\n function setStakingContract(address) external;\\n}\\n\",\"keccak256\":\"0xd5e9b017f7ba0157fa41152a8bb166edbc6ef54a97fa3bb71a2a9b333d846c0b\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasStakingVestingContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasStakingVestingContract is IHasContract {\\n /// @dev Emitted when the staking vesting contract is updated.\\n event StakingVestingContractUpdated(address);\\n\\n /// @dev Error of method caller must be staking vesting contract.\\n error ErrCallerMustBeStakingVestingContract();\\n\\n /**\\n * @dev Returns the staking vesting contract.\\n */\\n function stakingVestingContract() external view returns (address);\\n\\n /**\\n * @dev Sets the staking vesting contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `StakingVestingContractUpdated`.\\n *\\n */\\n function setStakingVestingContract(address) external;\\n}\\n\",\"keccak256\":\"0xfc5f14854b15f81d5b535e4baaeca7cedca69b26813bfc6ade75fdabc4eaffcf\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/PeriodWrapperConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface PeriodWrapperConsumer {\\n struct PeriodWrapper {\\n // Inner value.\\n uint256 inner;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n}\\n\",\"keccak256\":\"0xb6777e3c364306eb8d5355583c1aca44de9d351cb40ddf1cea832206d4aad272\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/IBaseSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseSlash {\\n enum SlashType {\\n UNKNOWN,\\n UNAVAILABILITY_TIER_1,\\n UNAVAILABILITY_TIER_2,\\n DOUBLE_SIGNING,\\n BRIDGE_VOTING,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\\n UNAVAILABILITY_TIER_3\\n }\\n\\n /// @dev Emitted when the validator is slashed.\\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\\n}\\n\",\"keccak256\":\"0x04d449f2852840566dfff4e3673929f6e9b8d9b5fc5b29744bf4f344dc7f9bc0\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ICreditScore.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICreditScore {\\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\\n event CreditScoreConfigsUpdated(\\n uint256 gainCreditScore,\\n uint256 maxCreditScore,\\n uint256 bailOutCostMultiplier,\\n uint256 cutOffPercentageAfterBailout\\n );\\n /// @dev Emitted the credit score of validators is updated.\\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\\n /// @dev Emitted when a validator bailed out of jail.\\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\\n\\n /**\\n * @dev Updates the credit score for the validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\\n\\n /**\\n * @dev Resets the credit score for the revoked validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function execResetCreditScores(address[] calldata _validators) external;\\n\\n /**\\n * @dev A slashed validator use this method to get out of jail.\\n *\\n * Requirements:\\n * - The `_consensusAddr` must be a validator.\\n * - Only validator's admin can call this method.\\n *\\n * Emits the event `BailedOut`.\\n *\\n */\\n function bailOut(address _consensusAddr) external;\\n\\n /**\\n * @dev Sets the configs to credit score.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CreditScoreConfigsUpdated`.\\n *\\n * @param _gainScore The score to gain per period.\\n * @param _maxScore The max number of credit score that a validator can hold.\\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to credit score.\\n *\\n * @return _gainCreditScore The score to gain per period.\\n * @return _maxCreditScore The max number of credit score that a validator can hold.\\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function getCreditScoreConfigs()\\n external\\n view\\n returns (\\n uint256 _gainCreditScore,\\n uint256 _maxCreditScore,\\n uint256 _bailOutCostMultiplier,\\n uint256 _cutOffPercentageAfterBailout\\n );\\n\\n /**\\n * @dev Returns the current credit score of the validator.\\n */\\n function getCreditScore(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the current credit score of a list of validators.\\n */\\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\\n\\n /**\\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0xd5364db88efb971f73aac569e27e5604758a123f28567af757b9933fdddd14f8\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeOperator is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\\n * `getBridgeOperatorSlashingConfigs` for param details.\\n */\\n event BridgeOperatorSlashingConfigsUpdated(\\n uint256 missingVotesRatioTier1,\\n uint256 missingVotesRatioTier2,\\n uint256 jailDurationForMissingVotesRatioTier2,\\n uint256 skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\\n *\\n * Requirements:\\n * - Only validator contract can invoke this method.\\n * - Should be called only at the end of period.\\n * - Should be called only when there is slash of bridge operator.\\n *\\n * Emits the event `Slashed`.\\n */\\n function execSlashBridgeOperator(\\n address _consensusAddr,\\n uint256 _tier,\\n uint256 _period\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to bridge operator slashing.\\n *\\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\\n * block producer will be put in jail if (s)he misses more than this ratio.\\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\\n * its bridge operator is slashed tier-2.\\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\\n * number of votes in the bridge is too small.\\n *\\n */\\n function getBridgeOperatorSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _missingVotesRatioTier1,\\n uint256 _missingVotesRatioTier2,\\n uint256 _jailDurationForMissingVotesRatioTier2,\\n uint256 _skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash bridge operators.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\\n * to 0%-100%.\\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\\n * slashed tier-2.\\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\\n * in the bridge is too small.\\n *\\n */\\n function setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x5c09ac11ead005bfa25ae58e970c441144849b14d58fd5f53fadc3b9be16e5d6\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeVoting is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\\n * details.\\n */\\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Slashes for bridge voter governance.\\n *\\n * Emits the event `Slashed`.\\n */\\n function slashBridgeVoting(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the configs related to bridge voting slashing.\\n *\\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\\n * operators.\\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function getBridgeVotingSlashingConfigs()\\n external\\n view\\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Sets the configs to slash bridge voting.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\\n *\\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\\n * @param _slashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\\n}\\n\",\"keccak256\":\"0x72c3bcfe3c49f946651caa3066bd5296d007871c9a56fa113e2d3c0f3db7eb99\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashDoubleSign is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\\n * for param details.\\n */\\n event DoubleSignSlashingConfigsUpdated(\\n uint256 slashDoubleSignAmount,\\n uint256 doubleSigningJailUntilBlock,\\n uint256 doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Slashes for double signing.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\\n */\\n function slashDoubleSign(\\n address _validatorAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\\n * double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function getDoubleSignSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _slashDoubleSignAmount,\\n uint256 _doubleSigningJailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\\n *\\n * @param _slashAmount The amount of RON to slash double sign.\\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n ) external;\\n}\\n\",\"keccak256\":\"0xe72708c42d468b0c40ffa0c72b3386899f11273e4149425aab490a78d5312222\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashIndicator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashDoubleSign.sol\\\";\\nimport \\\"./ISlashBridgeVoting.sol\\\";\\nimport \\\"./ISlashBridgeOperator.sol\\\";\\nimport \\\"./ISlashUnavailability.sol\\\";\\nimport \\\"./ICreditScore.sol\\\";\\n\\ninterface ISlashIndicator is\\n ISlashDoubleSign,\\n ISlashBridgeVoting,\\n ISlashBridgeOperator,\\n ISlashUnavailability,\\n ICreditScore\\n{}\\n\",\"keccak256\":\"0xe8b8fde3af614735cb304bc1eb82b05d65ede4df804b5d555787e5d5ecb95ec0\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashUnavailability.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashUnavailability is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\\n * for param details.\\n */\\n event UnavailabilitySlashingConfigsUpdated(\\n uint256 unavailabilityTier1Threshold,\\n uint256 unavailabilityTier2Threshold,\\n uint256 slashAmountForUnavailabilityTier2Threshold,\\n uint256 jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Returns the last block that a block producer is slashed for unavailability.\\n */\\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` when the threshold is reached.\\n *\\n */\\n function slashUnavailability(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the current unavailability indicator of a block producer.\\n */\\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\\n * producer when (s)he is slashed with tier-2 or tier-3.\\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\\n * slashed with tier-2 or tier-3.\\n *\\n */\\n function getUnavailabilitySlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _unavailabilityTier1Threshold,\\n uint256 _unavailabilityTier2Threshold,\\n uint256 _slashAmountForUnavailabilityTier2Threshold,\\n uint256 _jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\\n * self-staking if (s)he misses more than this threshold.\\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\\n * is slashed tier-2.\\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\\n *\\n */\\n function setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x92f7d8e9c6f80d4fedab80515c68db0a46cf4f8da143f8d766bf5f7582aa0a21\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IBaseStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseStaking {\\n struct PoolDetail {\\n // Address of the pool i.e. consensus address of the validator\\n address addr;\\n // Pool admin address\\n address admin;\\n // Self-staking amount\\n uint256 stakingAmount;\\n // Total number of RON staking for the pool\\n uint256 stakingTotal;\\n // Mapping from delegator => delegating amount\\n mapping(address => uint256) delegatingAmount;\\n // Mapping from delegator => the last timestamp that delegator staked\\n mapping(address => uint256) lastDelegatingTimestamp;\\n }\\n\\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\\n event WaitingSecsToRevokeUpdated(uint256 secs);\\n\\n /// @dev Error of cannot transfer RON.\\n error ErrCannotTransferRON();\\n /// @dev Error of receiving zero message value.\\n error ErrZeroValue();\\n /// @dev Error of pool admin is not allowed to call.\\n error ErrPoolAdminForbidden();\\n /// @dev Error of no one is allowed to call but the pool's admin.\\n error ErrOnlyPoolAdminAllowed();\\n /// @dev Error of admin of any active pool cannot delegate.\\n error ErrAdminOfAnyActivePoolForbidden(address admin);\\n /// @dev Error of querying inactive pool.\\n error ErrInactivePool(address poolAddr);\\n /// @dev Error of length of input arrays are not of the same.\\n error ErrInvalidArrays();\\n\\n /**\\n * @dev Returns whether the `_poolAdminAddr` is currently active.\\n */\\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the consensus address corresponding to the pool admin.\\n */\\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\\n\\n /**\\n * @dev Returns the staking pool detail.\\n */\\n function getPoolDetail(address)\\n external\\n view\\n returns (\\n address _admin,\\n uint256 _stakingAmount,\\n uint256 _stakingTotal\\n );\\n\\n /**\\n * @dev Returns the self-staking amounts of the pools.\\n */\\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n */\\n function cooldownSecsToUndelegate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\\n */\\n function waitingSecsToRevoke() external view returns (uint256);\\n\\n /**\\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CooldownSecsToUndelegateUpdated`.\\n *\\n */\\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\\n\\n /**\\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `WaitingSecsToRevokeUpdated`.\\n *\\n */\\n function setWaitingSecsToRevoke(uint256 _secs) external;\\n}\\n\",\"keccak256\":\"0x008b3d42a3104820de7b7edb5ea4b21c75d4417767fc0791f89f00ac9a2cce8d\",\"license\":\"MIT\"},\"contracts/interfaces/staking/ICandidateStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface ICandidateStaking is IRewardPool {\\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\\n event MinValidatorStakingAmountUpdated(uint256 threshold);\\n /// @dev Emitted when the commission rate range is updated.\\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\\n\\n /// @dev Emitted when the pool admin staked for themself.\\n event Staked(address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\\n event Unstaked(address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Emitted when the validator pool is approved.\\n event PoolApproved(address indexed validator, address indexed admin);\\n /// @dev Emitted when the validator pool is deprecated.\\n event PoolsDeprecated(address[] validator);\\n /// @dev Emitted when the staking amount transfer failed.\\n event StakingAmountTransferFailed(\\n address indexed validator,\\n address indexed admin,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\\n event StakingAmountDeductFailed(\\n address indexed validator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Error of cannot transfer RON to specified target.\\n error ErrCannotInitTransferRON(address addr, string extraInfo);\\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\\n error ErrThreeInteractionAddrsNotEqual();\\n /// @dev Error of three operation addresses must be distinct in applying for validator candidate.\\n error ErrThreeOperationAddrsNotDistinct();\\n /// @dev Error of unstaking zero amount.\\n error ErrUnstakeZeroAmount();\\n /// @dev Error of invalid staking amount left after deducted.\\n error ErrStakingAmountLeft();\\n /// @dev Error of insufficient staking amount for unstaking.\\n error ErrInsufficientStakingAmount();\\n /// @dev Error of unstaking too early.\\n error ErrUnstakeTooEarly();\\n /// @dev Error of setting commission rate exceeds max allowed.\\n error ErrInvalidCommissionRate();\\n\\n /**\\n * @dev Returns the minimum threshold for being a validator candidate.\\n */\\n function minValidatorStakingAmount() external view returns (uint256);\\n\\n /**\\n * @dev Returns the commission rate range that the candidate can set.\\n */\\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\\n\\n /**\\n * @dev Sets the minimum threshold for being a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinValidatorStakingAmountUpdated` event.\\n *\\n */\\n function setMinValidatorStakingAmount(uint256) external;\\n\\n /**\\n * @dev Sets the commission rate range that a candidate can set.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `CommissionRateRangeUpdated` event.\\n *\\n */\\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\\n\\n /**\\n * @dev Proposes a candidate to become a validator.\\n *\\n * Requirements:\\n * - The method caller is able to receive RON.\\n * - The treasury is able to receive RON.\\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\\n *\\n * Emits the event `PoolApproved`.\\n *\\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\\n * to its candidate, e.g. scheduling maintenance.\\n *\\n */\\n function applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external payable;\\n\\n /**\\n * @dev Deprecates the pool.\\n * - Deduct self-staking amount of the pool admin to zero.\\n * - Transfer the deducted amount to the pool admin.\\n * - Deactivate the pool admin address in the mapping of active pool admins\\n *\\n * Requirements:\\n * - The method caller is validator contract.\\n *\\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\\n *\\n */\\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\\n\\n /**\\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `msg.value` is larger than 0.\\n *\\n * Emits the event `Staked`.\\n *\\n */\\n function stake(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function unstake(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdated`.\\n *\\n */\\n function requestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestRenounce(address _consensusAddr) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestEmergencyExit(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x5681cd641c0014aa2cc0ae336e110ebd9a5b28419ae387acd720683ba54ca89f\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IDelegatorStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface IDelegatorStaking is IRewardPool {\\n /// @dev Emitted when the delegator staked for a validator candidate.\\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the delegator unstaked from a validator candidate.\\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Error of undelegating zero amount.\\n error ErrUndelegateZeroAmount();\\n /// @dev Error of undelegating insufficient amount.\\n error ErrInsufficientDelegatingAmount();\\n /// @dev Error of undelegating too early.\\n error ErrUndelegateTooEarly();\\n\\n /**\\n * @dev Stakes for a validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Delegated` event.\\n *\\n */\\n function delegate(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Undelegated` event.\\n *\\n */\\n function undelegate(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Bulk unstakes from a list of candidates.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the events `Undelegated`.\\n *\\n */\\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\\n\\n /**\\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `Undelegated` event and the `Delegated` event.\\n *\\n */\\n function redelegate(\\n address _consensusAddrSrc,\\n address _consensusAddrDst,\\n uint256 _amount\\n ) external;\\n\\n /**\\n * @dev Returns the claimable reward of the user `_user`.\\n */\\n function getRewards(address _user, address[] calldata _poolAddrList)\\n external\\n view\\n returns (uint256[] memory _rewards);\\n\\n /**\\n * @dev Claims the reward of method caller.\\n *\\n * Emits the `RewardClaimed` event.\\n *\\n */\\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\\n\\n /**\\n * @dev Claims the rewards and delegates them to the consensus address.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `RewardClaimed` event and the `Delegated` event.\\n *\\n */\\n function delegateRewards(address[] calldata _consensusAddrList, address _consensusAddrDst)\\n external\\n returns (uint256 _amount);\\n}\\n\",\"keccak256\":\"0x5ce840a920ed06139f9e33d306c8ee50b2a81e4bd2ac6ed24b47297c348576b8\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IRewardPool.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/consumers/PeriodWrapperConsumer.sol\\\";\\n\\ninterface IRewardPool is PeriodWrapperConsumer {\\n struct UserRewardFields {\\n // Recorded reward amount.\\n uint256 debited;\\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\\n uint256 aRps;\\n // Lowest staking amount in the period.\\n uint256 lowestAmount;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n\\n struct PoolFields {\\n // Accumulated of the amount rewards per share (one unit staking).\\n uint256 aRps;\\n // The staking total to share reward of the current period.\\n PeriodWrapper shares;\\n }\\n\\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\\n /// @dev Emitted when the user claimed their reward\\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\\n\\n /// @dev Emitted when the pool shares are updated\\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\\n /// @dev Emitted when the pools are updated\\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\\n /// @dev Emitted when the contract fails when updating the pools\\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\\n /// @dev Emitted when the contract fails when updating the pools that already set\\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\\n\\n /// @dev Error of invalid pool share.\\n error ErrInvalidPoolShare();\\n\\n /**\\n * @dev Returns the reward amount that user claimable.\\n */\\n function getReward(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amount of an user.\\n */\\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amounts of the users.\\n */\\n function getManyStakingAmounts(address[] calldata _poolAddrs, address[] calldata _userList)\\n external\\n view\\n returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total staking amount of all users for a pool.\\n */\\n function getStakingTotal(address _poolAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\\n */\\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\\n}\\n\",\"keccak256\":\"0x92315ca9d6d93f55a7752adf2567adb86745f708198bfcd74b9a626b6570208f\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseStaking.sol\\\";\\nimport \\\"./ICandidateStaking.sol\\\";\\nimport \\\"./IDelegatorStaking.sol\\\";\\n\\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\\n /**\\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\\n *\\n * Note: This method should be called once at the period ending.\\n *\\n */\\n function execRecordRewards(\\n address[] calldata _consensusAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) external payable;\\n\\n /**\\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function execDeductStakingAmount(address _consensusAddr, uint256 _amount)\\n external\\n returns (uint256 _actualDeductingAmount);\\n}\\n\",\"keccak256\":\"0xb7942c5032c16ea567ac0bfc07ecacd84840d6de134735ea538aa22fc6da05a5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/BridgeOperatorsBallot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\n\\nlibrary BridgeOperatorsBallot {\\n struct BridgeOperatorSet {\\n uint256 period;\\n uint256 epoch;\\n address[] operators;\\n }\\n\\n // keccak256(\\\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\\\");\\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\\n\\n /**\\n * @dev Verifies whether the ballot is valid or not.\\n *\\n * Requirements:\\n * - The ballot is not for an empty operator set.\\n * - The operator address list is in order.\\n *\\n */\\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\\n require(_ballot.operators.length > 0, \\\"BridgeOperatorsBallot: invalid array length\\\");\\n address _addr = _ballot.operators[0];\\n for (uint _i = 1; _i < _ballot.operators.length; _i++) {\\n require(_addr < _ballot.operators[_i], \\\"BridgeOperatorsBallot: invalid order of bridge operators\\\");\\n _addr = _ballot.operators[_i];\\n }\\n }\\n\\n /**\\n * @dev Returns hash of the ballot.\\n */\\n function hash(BridgeOperatorSet calldata _ballot) internal pure returns (bytes32) {\\n bytes32 _operatorsHash;\\n address[] memory _operators = _ballot.operators;\\n\\n assembly {\\n _operatorsHash := keccak256(add(_operators, 32), mul(mload(_operators), 32))\\n }\\n\\n return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\\n }\\n}\\n\",\"keccak256\":\"0x986425ebae2dcfcfa266c9ca825232ff300ec8ce796e8975da6714d87e921793\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(\\n uint256 c,\\n uint256 a,\\n uint256 b\\n ) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(\\n uint256 x1,\\n uint256 x2,\\n uint256 y1,\\n uint256 y2\\n ) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(\\n uint256 a,\\n uint256 b,\\n uint256 upperbound\\n ) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xf719e74bc39be7aceb4e5cc455260f81b2b21e83aa693e0b50c390c9909e08c4\",\"license\":\"UNLICENSED\"},\"contracts/precompile-usages/PCUPickValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\\n /// @dev Gets the address of the precompile of picking validator set\\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\\n return address(0x68);\\n }\\n\\n /**\\n * @dev Sorts and arranges to return a new validator set.\\n *\\n * Note: The recover process is done by pre-compiled contract. This function is marked as\\n * virtual for implementing mocking contract for testing purpose.\\n */\\n function _pcPickValidatorSet(\\n address[] memory _candidates,\\n uint256[] memory _weights,\\n uint256[] memory _trustedWeights,\\n uint256 _maxValidatorNumber,\\n uint256 _maxPrioritizedValidatorNumber\\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\\n address _smc = precompilePickValidatorSetAddress();\\n bytes memory _payload = abi.encodeWithSignature(\\n \\\"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\\\",\\n _candidates,\\n _weights,\\n _trustedWeights,\\n _maxValidatorNumber,\\n _maxPrioritizedValidatorNumber\\n );\\n bool _success = true;\\n\\n uint256 _payloadLength = _payload.length;\\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\\n\\n assembly {\\n let _payloadStart := add(_payload, 0x20)\\n\\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\\n _success := 0\\n }\\n\\n if iszero(returndatasize()) {\\n _success := 0\\n }\\n\\n _result := add(_result, 0x20)\\n }\\n\\n if (!_success) revert ErrCallPrecompiled();\\n\\n _newValidatorCount = _result.length;\\n }\\n}\\n\",\"keccak256\":\"0xcb57a021897a773d11be9d98a195e0653f2124b7e95e84c4832b57d9d36d67e1\",\"license\":\"MIT\"},\"contracts/precompile-usages/PCUSortValidators.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PCUSortValidators is PrecompiledUsage {\\n /// @dev Gets the address of the precompile of sorting validators\\n function precompileSortValidatorsAddress() public view virtual returns (address) {\\n return address(0x66);\\n }\\n\\n /**\\n * @dev Sorts candidates descending by their weights by calling precompile contract.\\n *\\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\\n */\\n function _pcSortCandidates(address[] memory _candidates, uint256[] memory _weights)\\n internal\\n view\\n virtual\\n returns (address[] memory _result)\\n {\\n address _smc = precompileSortValidatorsAddress();\\n bool _success = true;\\n\\n bytes memory _payload = abi.encodeWithSignature(\\\"sortValidators(address[],uint256[])\\\", _candidates, _weights);\\n uint256 _payloadLength = _payload.length;\\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\\n\\n assembly {\\n let _payloadStart := add(_payload, 0x20)\\n\\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\\n _success := 0\\n }\\n\\n if iszero(returndatasize()) {\\n _success := 0\\n }\\n\\n _result := add(_result, 0x20)\\n }\\n\\n if (!_success) revert ErrCallPrecompiled();\\n }\\n}\\n\",\"keccak256\":\"0xc779a5a5e29fb4416450b2eb6608a09e2cf63f6d9af5b2c1eec130dd16b0d22a\",\"license\":\"MIT\"},\"contracts/precompile-usages/PrecompiledUsage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PrecompiledUsage {\\n /// @dev Error of call to precompile fails.\\n error ErrCallPrecompiled();\\n}\\n\",\"keccak256\":\"0x76facc3f3a8dd573c826bbbfedaa5cd8ef30963fbabd8c163c0c72b6efea5551\",\"license\":\"MIT\"},\"contracts/ronin/validator/CandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/collections/HasStakingContract.sol\\\";\\nimport \\\"../../extensions/consumers/GlobalConfigConsumer.sol\\\";\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../interfaces/validator/ICandidateManager.sol\\\";\\nimport \\\"../../interfaces/staking/IStaking.sol\\\";\\n\\nabstract contract CandidateManager is ICandidateManager, PercentageConsumer, GlobalConfigConsumer, HasStakingContract {\\n /// @dev Maximum number of validator candidate\\n uint256 private _maxValidatorCandidate;\\n\\n /// @dev The validator candidate array\\n address[] internal _candidates;\\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\\n mapping(address => uint256) internal _candidateIndex;\\n /// @dev Mapping from candidate consensus address => their info\\n mapping(address => ValidatorCandidate) internal _candidateInfo;\\n\\n /**\\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\\n * Value of 1 means the change gets affected at the beginning of the following day.\\n **/\\n uint256 internal _minEffectiveDaysOnwards;\\n /// @dev Mapping from candidate consensus address => schedule commission change.\\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[48] private ______gap;\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function maxValidatorCandidate() public view override returns (uint256) {\\n return _maxValidatorCandidate;\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function minEffectiveDaysOnwards() external view override returns (uint256) {\\n return _minEffectiveDaysOnwards;\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\\n _setMaxValidatorCandidate(_number);\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\\n _setMinEffectiveDaysOnwards(_numOfDays);\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function execApplyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external override onlyStakingContract {\\n uint256 _length = _candidates.length;\\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\\n\\n for (uint _i; _i < _candidates.length; _i++) {\\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\\n if (_bridgeOperatorAddr == existentInfo.bridgeOperatorAddr) revert ErrExistentBridgeOperator(_bridgeOperatorAddr);\\n }\\n\\n _candidateIndex[_consensusAddr] = ~_length;\\n _candidates.push(_consensusAddr);\\n\\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\\n _info.admin = _candidateAdmin;\\n _info.consensusAddr = _consensusAddr;\\n _info.treasuryAddr = _treasuryAddr;\\n _info.bridgeOperatorAddr = _bridgeOperatorAddr;\\n _info.commissionRate = _commissionRate;\\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin, _bridgeOperatorAddr);\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function execRequestRenounceCandidate(address _consensusAddr, uint256 _secsLeft)\\n external\\n override\\n onlyStakingContract\\n {\\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\\n\\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external override onlyStakingContract {\\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\\n revert ErrAlreadyRequestedUpdatingCommissionRate();\\n }\\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\\n\\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\\n _schedule.effectiveTimestamp = _effectiveTimestamp;\\n _schedule.commissionRate = _commissionRate;\\n\\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function isValidatorCandidate(address _addr) public view override returns (bool) {\\n return _candidateIndex[_addr] != 0;\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\\n _list = new ValidatorCandidate[](_candidates.length);\\n for (uint _i; _i < _list.length; _i++) {\\n _list[_i] = _candidateInfo[_candidates[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\\n return _candidateInfo[_candidate];\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function getValidatorCandidates() public view override returns (address[] memory) {\\n return _candidates;\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\\n return _candidateCommissionChangeSchedule[_candidate];\\n }\\n\\n /**\\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\\n * or the ones who requested to renounce their candidate role.\\n *\\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\\n *\\n */\\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\\n IStaking _staking = _stakingContract;\\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\\n\\n uint256 _length = _candidates.length;\\n uint256 _unsatisfiedCount;\\n _unsatisfiedCandidates = new address[](_length);\\n\\n {\\n uint256 _i;\\n address _addr;\\n ValidatorCandidate storage _info;\\n while (_i < _length) {\\n _addr = _candidates[_i];\\n _info = _candidateInfo[_addr];\\n\\n // Checks for under-balance status of candidates\\n bool _hasTopupDeadline = _info.topupDeadline != 0;\\n if (_selfStakings[_i] < _minStakingAmount) {\\n // Updates deadline on the first time unsatisfied the staking amount condition\\n if (!_hasTopupDeadline) {\\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\\n _info.topupDeadline = _topupDeadline;\\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\\n }\\n } else if (_hasTopupDeadline) {\\n // Removes the deadline if the staking amount condition is satisfied\\n delete _info.topupDeadline;\\n emit CandidateTopupDeadlineUpdated(_addr, 0);\\n }\\n\\n // Removes unsastisfied candidates\\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\\n _emergencyExitLockedFundReleased(_addr);\\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\\n if (_revokingActivated || _topupDeadlineMissed) {\\n _selfStakings[_i] = _selfStakings[--_length];\\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\\n _removeCandidate(_addr);\\n continue;\\n }\\n\\n // Checks for schedule of commission change and updates commission rate\\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\\n delete _candidateCommissionChangeSchedule[_addr];\\n _info.commissionRate = _commisionRate;\\n emit CommissionRateUpdated(_addr, _commisionRate);\\n }\\n\\n _i++;\\n }\\n }\\n\\n assembly {\\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\\n }\\n\\n if (_unsatisfiedCount > 0) {\\n emit CandidatesRevoked(_unsatisfiedCandidates);\\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\\n }\\n }\\n\\n /**\\n * @inheritdoc ICandidateManager\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\\n return _candidateInfo[_candidate].admin == _admin;\\n }\\n\\n /**\\n * @dev Override `ValidatorInfoStorage-_bridgeOperatorOf`.\\n */\\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address) {\\n return _candidateInfo[_consensusAddr].bridgeOperatorAddr;\\n }\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\\n _maxValidatorCandidate = _threshold;\\n emit MaxValidatorCandidateUpdated(_threshold);\\n }\\n\\n /**\\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\\n _minEffectiveDaysOnwards = _numOfDays;\\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\\n }\\n\\n /**\\n * @dev Removes the candidate.\\n */\\n function _removeCandidate(address _addr) internal virtual {\\n uint256 _idx = _candidateIndex[_addr];\\n if (_idx == 0) {\\n return;\\n }\\n\\n delete _candidateInfo[_addr];\\n delete _candidateIndex[_addr];\\n delete _candidateCommissionChangeSchedule[_addr];\\n\\n address _lastCandidate = _candidates[_candidates.length - 1];\\n if (_lastCandidate != _addr) {\\n _candidateIndex[_lastCandidate] = _idx;\\n _candidates[~_idx] = _lastCandidate;\\n }\\n\\n _candidates.pop();\\n }\\n\\n /**\\n * @dev Sets timestamp to revoke a candidate.\\n */\\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\\n _candidate.revokingTimestamp = _timestamp;\\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\\n }\\n\\n /**\\n * @dev Returns a flag indicating whether the fund is unlocked.\\n */\\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\\n\\n /**\\n * @dev Returns whether the consensus address is a trusted org or not.\\n */\\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\\n}\\n\",\"keccak256\":\"0x118e406abfbaba67fdb5a282740674f4e2442f55fe182fee6d0bd82ea8d7a8e7\",\"license\":\"MIT\"},\"contracts/ronin/validator/CoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/collections/HasBridgeTrackingContract.sol\\\";\\nimport \\\"../../extensions/collections/HasMaintenanceContract.sol\\\";\\nimport \\\"../../extensions/collections/HasSlashIndicatorContract.sol\\\";\\nimport \\\"../../extensions/collections/HasStakingVestingContract.sol\\\";\\nimport \\\"../../extensions/RONTransferHelper.sol\\\";\\nimport \\\"../../interfaces/validator/ICoinbaseExecution.sol\\\";\\nimport \\\"../../libraries/EnumFlags.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"../../precompile-usages/PCUSortValidators.sol\\\";\\nimport \\\"../../precompile-usages/PCUPickValidatorSet.sol\\\";\\nimport \\\"./storage-fragments/CommonStorage.sol\\\";\\nimport \\\"./CandidateManager.sol\\\";\\nimport \\\"./EmergencyExit.sol\\\";\\n\\nabstract contract CoinbaseExecution is\\n ICoinbaseExecution,\\n RONTransferHelper,\\n PCUSortValidators,\\n PCUPickValidatorSet,\\n HasStakingVestingContract,\\n HasBridgeTrackingContract,\\n HasMaintenanceContract,\\n HasSlashIndicatorContract,\\n EmergencyExit\\n{\\n using EnumFlags for EnumFlags.ValidatorFlag;\\n\\n modifier onlyCoinbase() {\\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\\n _;\\n }\\n\\n modifier whenEpochEnding() {\\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\\n _;\\n }\\n\\n modifier oncePerEpoch() {\\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\\n _lastUpdatedBlock = block.number;\\n _;\\n }\\n\\n /**\\n * @inheritdoc ICoinbaseExecution\\n */\\n function submitBlockReward() external payable override onlyCoinbase {\\n bool _requestForBlockProducer = isBlockProducer(msg.sender) &&\\n !_jailed(msg.sender) &&\\n !_miningRewardDeprecated(msg.sender, currentPeriod());\\n\\n (, uint256 _blockProducerBonus, uint256 _bridgeOperatorBonus) = _stakingVestingContract.requestBonus(\\n _requestForBlockProducer,\\n true // _requestForBridgeOperator\\n );\\n\\n _totalBridgeReward += _bridgeOperatorBonus;\\n\\n // Deprecates reward for non-validator or slashed validator\\n if (!_requestForBlockProducer) {\\n _totalDeprecatedReward += msg.value;\\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\\n return;\\n }\\n\\n emit BlockRewardSubmitted(msg.sender, msg.value, _blockProducerBonus);\\n\\n uint256 _period = currentPeriod();\\n uint256 _reward = msg.value + _blockProducerBonus;\\n uint256 _cutOffReward;\\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][_period]) {\\n (, , , uint256 _cutOffPercentage) = _slashIndicatorContract.getCreditScoreConfigs();\\n _cutOffReward = (_reward * _cutOffPercentage) / _MAX_PERCENTAGE;\\n _totalDeprecatedReward += _cutOffReward;\\n emit BlockRewardDeprecated(msg.sender, _cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\\n }\\n\\n _reward -= _cutOffReward;\\n (uint256 _minRate, uint256 _maxRate) = _stakingContract.getCommissionRateRange();\\n uint256 _rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, _maxRate), _minRate);\\n uint256 _miningAmount = (_rate * _reward) / _MAX_PERCENTAGE;\\n _miningReward[msg.sender] += _miningAmount;\\n\\n uint256 _delegatingAmount = _reward - _miningAmount;\\n _delegatingReward[msg.sender] += _delegatingAmount;\\n }\\n\\n /**\\n * @inheritdoc ICoinbaseExecution\\n */\\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\\n uint256 _newPeriod = _computePeriod(block.timestamp);\\n bool _periodEnding = _isPeriodEnding(_newPeriod);\\n\\n (address[] memory _currentValidators, , ) = getValidators();\\n address[] memory _revokedCandidates;\\n uint256 _epoch = epochOf(block.number);\\n uint256 _nextEpoch = _epoch + 1;\\n uint256 _lastPeriod = currentPeriod();\\n\\n if (_periodEnding) {\\n _syncBridgeOperatingReward(_lastPeriod, _currentValidators);\\n (\\n uint256 _totalDelegatingReward,\\n uint256[] memory _delegatingRewards\\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\\n _tryRecycleLockedFundsFromEmergencyExits();\\n _recycleDeprecatedRewards();\\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\\n if (_revokedCandidates.length > 0) {\\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\\n }\\n _currentPeriodStartAtBlock = block.number + 1;\\n }\\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\\n _periodOf[_nextEpoch] = _newPeriod;\\n _lastUpdatedPeriod = _newPeriod;\\n }\\n\\n /**\\n * @dev This loop over the all current validators to sync the bridge operating reward.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _syncBridgeOperatingReward(uint256 _lastPeriod, address[] memory _currentValidators) internal {\\n uint256 _totalBridgeBallots = _bridgeTrackingContract.totalBallots(_lastPeriod);\\n uint256 _totalBridgeVotes = _bridgeTrackingContract.totalVotes(_lastPeriod);\\n uint256[] memory _bridgeBallots = _bridgeTrackingContract.getManyTotalBallots(\\n _lastPeriod,\\n getBridgeOperatorsOf(_currentValidators)\\n );\\n\\n if (\\n !_validateBridgeTrackingResponse(_totalBridgeBallots, _totalBridgeVotes, _bridgeBallots) || _totalBridgeVotes == 0\\n ) {\\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\\n for (uint256 _i; _i < _currentValidators.length; _i++) {\\n _bridgeOperatingReward[_currentValidators[_i]] = _totalBridgeReward / _currentValidators.length;\\n }\\n return;\\n }\\n\\n (\\n uint256 _missingVotesRatioTier1,\\n uint256 _missingVotesRatioTier2,\\n uint256 _jailDurationForMissingVotesRatioTier2,\\n uint256 _skipBridgeOperatorSlashingThreshold\\n ) = _slashIndicatorContract.getBridgeOperatorSlashingConfigs();\\n\\n // Slashes the bridge reward if the total of votes exceeds the slashing threshold.\\n bool _shouldSlash = _totalBridgeVotes > _skipBridgeOperatorSlashingThreshold;\\n for (uint256 _i; _i < _currentValidators.length; _i++) {\\n // Shares the bridge operators reward proportionally.\\n _bridgeOperatingReward[_currentValidators[_i]] = (_totalBridgeReward * _bridgeBallots[_i]) / _totalBridgeBallots;\\n if (_shouldSlash) {\\n _slashBridgeOperatorBasedOnPerformance(\\n _lastPeriod,\\n _currentValidators[_i],\\n _MAX_PERCENTAGE - (_bridgeBallots[_i] * _MAX_PERCENTAGE) / _totalBridgeVotes,\\n _jailDurationForMissingVotesRatioTier2,\\n _missingVotesRatioTier1,\\n _missingVotesRatioTier2\\n );\\n }\\n }\\n }\\n\\n /**\\n * @dev Returns whether the responses from bridge tracking are correct.\\n */\\n function _validateBridgeTrackingResponse(\\n uint256 _totalBridgeBallots,\\n uint256 _totalBridgeVotes,\\n uint256[] memory _bridgeBallots\\n ) private returns (bool _valid) {\\n _valid = true;\\n uint256 _sumBallots;\\n for (uint _i; _i < _bridgeBallots.length; _i++) {\\n if (_bridgeBallots[_i] > _totalBridgeVotes) {\\n _valid = false;\\n break;\\n }\\n _sumBallots += _bridgeBallots[_i];\\n }\\n _valid = _valid && (_sumBallots <= _totalBridgeBallots);\\n if (!_valid) {\\n emit BridgeTrackingIncorrectlyResponded();\\n }\\n }\\n\\n /**\\n * @dev Slashes the validator on the corresponding bridge operator performance. Updates the status of the deprecated reward. Not update the reward amount.\\n *\\n * Consider validating the bridge tracking response by using the method `_validateBridgeTrackingResponse` before calling this function.\\n */\\n function _slashBridgeOperatorBasedOnPerformance(\\n uint256 _period,\\n address _validator,\\n uint256 _missedRatio,\\n uint256 _jailDurationTier2,\\n uint256 _ratioTier1,\\n uint256 _ratioTier2\\n ) internal {\\n if (_missedRatio >= _ratioTier2) {\\n _bridgeRewardDeprecatedAtPeriod[_validator][_period] = true;\\n _miningRewardDeprecatedAtPeriod[_validator][_period] = true;\\n\\n uint256 _newJailUntilBlock = Math.addIfNonZero(block.number, _jailDurationTier2);\\n _blockProducerJailedBlock[_validator] = Math.max(_newJailUntilBlock, _blockProducerJailedBlock[_validator]);\\n _cannotBailoutUntilBlock[_validator] = Math.max(_newJailUntilBlock, _cannotBailoutUntilBlock[_validator]);\\n\\n _slashIndicatorContract.execSlashBridgeOperator(_validator, 2, _period);\\n emit ValidatorPunished(_validator, _period, _blockProducerJailedBlock[_validator], 0, true, true);\\n } else if (_missedRatio >= _ratioTier1) {\\n _bridgeRewardDeprecatedAtPeriod[_validator][_period] = true;\\n _slashIndicatorContract.execSlashBridgeOperator(_validator, 1, _period);\\n emit ValidatorPunished(_validator, _period, _blockProducerJailedBlock[_validator], 0, false, true);\\n }\\n }\\n\\n /**\\n * @dev This loops over all current validators to:\\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\\n * - Update the total deprecated reward if the two previous conditions do not sastify.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\\n uint256 _lastPeriod,\\n address[] memory _currentValidators\\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\\n address _consensusAddr;\\n address payable _treasury;\\n _delegatingRewards = new uint256[](_currentValidators.length);\\n for (uint _i; _i < _currentValidators.length; _i++) {\\n _consensusAddr = _currentValidators[_i];\\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\\n\\n if (!_bridgeRewardDeprecated(_consensusAddr, _lastPeriod)) {\\n _distributeBridgeOperatingReward(_consensusAddr, _candidateInfo[_consensusAddr].bridgeOperatorAddr, _treasury);\\n } else {\\n _totalDeprecatedReward += _bridgeOperatingReward[_consensusAddr];\\n }\\n\\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\\n _distributeMiningReward(_consensusAddr, _treasury);\\n } else {\\n _totalDeprecatedReward += _miningReward[_consensusAddr] + _delegatingReward[_consensusAddr];\\n }\\n\\n delete _delegatingReward[_consensusAddr];\\n delete _miningReward[_consensusAddr];\\n delete _bridgeOperatingReward[_consensusAddr];\\n }\\n delete _totalBridgeReward;\\n }\\n\\n /**\\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\\n *\\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\\n uint256 _amount = _miningReward[_consensusAddr];\\n if (_amount > 0) {\\n if (_unsafeSendRON(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\\n return;\\n }\\n\\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\\n }\\n }\\n\\n /**\\n * @dev Distribute bonus of staking vesting for the bridge operator.\\n *\\n * Emits the `BridgeOperatorRewardDistributed` once the reward is distributed successfully.\\n * Emits the `BridgeOperatorRewardDistributionFailed` once the contract fails to distribute reward.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _distributeBridgeOperatingReward(\\n address _consensusAddr,\\n address _bridgeOperator,\\n address payable _treasury\\n ) private {\\n uint256 _amount = _bridgeOperatingReward[_consensusAddr];\\n if (_amount > 0) {\\n if (_unsafeSendRON(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\\n emit BridgeOperatorRewardDistributed(_consensusAddr, _bridgeOperator, _treasury, _amount);\\n return;\\n }\\n\\n emit BridgeOperatorRewardDistributionFailed(\\n _consensusAddr,\\n _bridgeOperator,\\n _treasury,\\n _amount,\\n address(this).balance\\n );\\n }\\n }\\n\\n /**\\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\\n *\\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _settleAndTransferDelegatingRewards(\\n uint256 _period,\\n address[] memory _currentValidators,\\n uint256 _totalDelegatingReward,\\n uint256[] memory _delegatingRewards\\n ) private {\\n IStaking _staking = _stakingContract;\\n if (_totalDelegatingReward > 0) {\\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\\n return;\\n }\\n\\n emit StakingRewardDistributionFailed(\\n _totalDelegatingReward,\\n _currentValidators,\\n _delegatingRewards,\\n address(this).balance\\n );\\n }\\n }\\n\\n /**\\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\\n * to the staking vesting contract\\n *\\n * Note: This method should be called once in the end of each period.\\n */\\n function _recycleDeprecatedRewards() private {\\n uint256 _withdrawAmount = _totalDeprecatedReward;\\n\\n if (_withdrawAmount != 0) {\\n address _withdrawTarget = stakingVestingContract();\\n\\n delete _totalDeprecatedReward;\\n\\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\\n );\\n\\n if (_success) {\\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\\n } else {\\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\\n }\\n }\\n }\\n\\n /**\\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\\n *\\n * Emits the `ValidatorSetUpdated` event.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _syncValidatorSet(uint256 _newPeriod)\\n private\\n returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates)\\n {\\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\\n uint256[] memory _weights = _stakingContract.getManyStakingTotals(_candidates);\\n uint256[] memory _trustedWeights = _roninTrustedOrganizationContract.getConsensusWeights(_candidates);\\n uint256 _newValidatorCount;\\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\\n _candidates,\\n _weights,\\n _trustedWeights,\\n _maxValidatorNumber,\\n _maxPrioritizedValidatorNumber\\n );\\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\\n }\\n\\n /**\\n * @dev Private helper function helps writing the new validator set into the contract storage.\\n *\\n * Emits the `ValidatorSetUpdated` event.\\n *\\n * Note: This method should be called once in the end of each period.\\n *\\n */\\n function _setNewValidatorSet(\\n address[] memory _newValidators,\\n uint256 _newValidatorCount,\\n uint256 _newPeriod\\n ) private {\\n // Remove exceeding validators in the current set\\n for (uint256 _i = _newValidatorCount; _i < validatorCount; _i++) {\\n delete _validatorMap[_validators[_i]];\\n delete _validators[_i];\\n }\\n\\n // Remove flag for all validator in the current set\\n for (uint _i; _i < _newValidatorCount; _i++) {\\n delete _validatorMap[_validators[_i]];\\n }\\n\\n // Update new validator set and set flag correspondingly.\\n for (uint256 _i; _i < _newValidatorCount; _i++) {\\n address _newValidator = _newValidators[_i];\\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\\n _validators[_i] = _newValidator;\\n }\\n\\n validatorCount = _newValidatorCount;\\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\\n }\\n\\n /**\\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\\n *\\n * Requirements:\\n * - This method is called at the end of each epoch\\n *\\n * Emits the `BlockProducerSetUpdated` event.\\n * Emits the `BridgeOperatorSetUpdated` event.\\n *\\n */\\n function _revampRoles(\\n uint256 _newPeriod,\\n uint256 _nextEpoch,\\n address[] memory _currentValidators\\n ) private {\\n bool[] memory _maintainedList = _maintenanceContract.checkManyMaintained(_currentValidators, block.number + 1);\\n\\n for (uint _i; _i < _currentValidators.length; _i++) {\\n address _validator = _currentValidators[_i];\\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\\n bool _isProducerBefore = isBlockProducer(_validator);\\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\\n _maintainedList[_i] ||\\n _emergencyExitRequested);\\n\\n if (!_isProducerBefore && _isProducerAfter) {\\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\\n } else if (_isProducerBefore && !_isProducerAfter) {\\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\\n }\\n\\n bool _isBridgeOperatorBefore = isOperatingBridge(_validator);\\n bool _isBridgeOperatorAfter = !_emergencyExitRequested;\\n if (!_isBridgeOperatorBefore && _isBridgeOperatorAfter) {\\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BridgeOperator);\\n } else if (_isBridgeOperatorBefore && !_isBridgeOperatorAfter) {\\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BridgeOperator);\\n }\\n }\\n\\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\\n emit BridgeOperatorSetUpdated(_newPeriod, _nextEpoch, getBridgeOperators());\\n }\\n\\n /**\\n * @dev Override `CandidateManager-_isTrustedOrg`.\\n */\\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\\n return _roninTrustedOrganizationContract.getConsensusWeight(_consensusAddr) > 0;\\n }\\n}\\n\",\"keccak256\":\"0x9d66bb0bb44607da8b24cbd5f65c65c148c8363d2615486651d2d328bef0e23a\",\"license\":\"MIT\"},\"contracts/ronin/validator/EmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/RONTransferHelper.sol\\\";\\nimport \\\"../../interfaces/IRoninGovernanceAdmin.sol\\\";\\nimport \\\"../../interfaces/validator/IEmergencyExit.sol\\\";\\nimport \\\"./storage-fragments/CommonStorage.sol\\\";\\nimport \\\"./CandidateManager.sol\\\";\\n\\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function emergencyExitLockedAmount() external view returns (uint256) {\\n return _emergencyExitLockedAmount;\\n }\\n\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function emergencyExpiryDuration() external view returns (uint256) {\\n return _emergencyExpiryDuration;\\n }\\n\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external onlyStakingContract {\\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\\n\\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\\n _bridgeRewardDeprecatedAtPeriod[_consensusAddr][currentPeriod()] = true;\\n\\n uint256 _deductedAmount = _stakingContract.execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\\n if (_deductedAmount > 0) {\\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\\n _lockedConsensusList.push(_consensusAddr);\\n _info.lockedAmount = _deductedAmount;\\n _info.recyclingAt = _recyclingAt;\\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\\n _consensusAddr,\\n _candidateInfo[_consensusAddr].treasuryAddr,\\n block.timestamp,\\n _recyclingAt\\n );\\n }\\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\\n }\\n\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\\n }\\n\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\\n }\\n\\n /**\\n * @inheritdoc IEmergencyExit\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient)\\n external\\n onlyAdmin\\n {\\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\\n return;\\n }\\n\\n uint256 _length = _lockedConsensusList.length;\\n uint256 _index = _length;\\n\\n for (uint _i; _i < _length; _i++) {\\n if (_lockedConsensusList[_i] == _consensusAddr) {\\n _index = _i;\\n break;\\n }\\n }\\n\\n // The locked amount might be recycled\\n if (_index == _length) {\\n return;\\n }\\n\\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\\n if (_amount > 0) {\\n delete _exitInfo[_consensusAddr];\\n if (_length > 1) {\\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\\n }\\n _lockedConsensusList.pop();\\n\\n _lockedFundReleased[_consensusAddr] = true;\\n if (_unsafeSendRON(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\\n return;\\n }\\n\\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\\n }\\n }\\n\\n /**\\n * @dev Tries to recycle the locked funds from emergency exit requests.\\n */\\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\\n uint256 _length = _lockedConsensusList.length;\\n\\n uint256 _i;\\n address _addr;\\n EmergencyExitInfo storage _info;\\n\\n while (_i < _length) {\\n _addr = _lockedConsensusList[_i];\\n _info = _exitInfo[_addr];\\n\\n if (_info.recyclingAt <= block.timestamp) {\\n _totalDeprecatedReward += _info.lockedAmount;\\n\\n delete _exitInfo[_addr];\\n if (--_length > 0) {\\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\\n }\\n _lockedConsensusList.pop();\\n continue;\\n }\\n\\n _i++;\\n }\\n }\\n\\n /**\\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\\n */\\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\\n return _lockedFundReleased[_consensusAddr];\\n }\\n\\n /**\\n * @dev Override `CandidateManager-_removeCandidate`.\\n */\\n function _removeCandidate(address _consensusAddr) internal override {\\n delete _lockedFundReleased[_consensusAddr];\\n super._removeCandidate(_consensusAddr);\\n }\\n\\n /**\\n * @dev Override `ValidatorInfoStorage-_bridgeOperatorOf`.\\n */\\n function _bridgeOperatorOf(address _consensusAddr)\\n internal\\n view\\n virtual\\n override(CandidateManager, ValidatorInfoStorage)\\n returns (address)\\n {\\n return CandidateManager._bridgeOperatorOf(_consensusAddr);\\n }\\n\\n /**\\n * @dev See `setEmergencyExitLockedAmount.\\n */\\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\\n _emergencyExitLockedAmount = _amount;\\n emit EmergencyExitLockedAmountUpdated(_amount);\\n }\\n\\n /**\\n * @dev See `setEmergencyExpiryDuration`.\\n */\\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\\n _emergencyExpiryDuration = _duration;\\n emit EmergencyExpiryDurationUpdated(_duration);\\n }\\n}\\n\",\"keccak256\":\"0x829dd3adae7a2171205dacc768d47f398be52669de1bb32ed3f8b91db6fc8885\",\"license\":\"MIT\"},\"contracts/ronin/validator/RoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"./CoinbaseExecution.sol\\\";\\nimport \\\"./SlashingExecution.sol\\\";\\n\\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\\n constructor() {\\n _disableInitializers();\\n }\\n\\n fallback() external payable {\\n _fallback();\\n }\\n\\n receive() external payable {\\n _fallback();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __slashIndicatorContract,\\n address __stakingContract,\\n address __stakingVestingContract,\\n address __maintenanceContract,\\n address __roninTrustedOrganizationContract,\\n address __bridgeTrackingContract,\\n uint256 __maxValidatorNumber,\\n uint256 __maxValidatorCandidate,\\n uint256 __maxPrioritizedValidatorNumber,\\n uint256 __minEffectiveDaysOnwards,\\n uint256 __numberOfBlocksInEpoch,\\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\\n uint256[2] calldata __emergencyExitConfigs\\n ) external initializer {\\n _setSlashIndicatorContract(__slashIndicatorContract);\\n _setStakingContract(__stakingContract);\\n _setStakingVestingContract(__stakingVestingContract);\\n _setMaintenanceContract(__maintenanceContract);\\n _setBridgeTrackingContract(__bridgeTrackingContract);\\n _setRoninTrustedOrganizationContract(__roninTrustedOrganizationContract);\\n _setMaxValidatorNumber(__maxValidatorNumber);\\n _setMaxValidatorCandidate(__maxValidatorCandidate);\\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\\n }\\n\\n /**\\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\\n * deducting amount on slashing).\\n */\\n function _fallback() internal view {\\n if (msg.sender != stakingVestingContract() && msg.sender != stakingContract()) revert ErrUnauthorizedReceiveRON();\\n }\\n\\n /**\\n * @dev Override `ValidatorInfoStorage-_bridgeOperatorOf`.\\n */\\n function _bridgeOperatorOf(address _consensusAddr)\\n internal\\n view\\n override(EmergencyExit, ValidatorInfoStorage)\\n returns (address)\\n {\\n return super._bridgeOperatorOf(_consensusAddr);\\n }\\n}\\n\",\"keccak256\":\"0xd7a2ac4d3a2c8edbd1bbfb1ef3549ef0a019b4c9b4f1c12f1fd07b116b1adab3\",\"license\":\"MIT\"},\"contracts/ronin/validator/SlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/collections/HasSlashIndicatorContract.sol\\\";\\nimport \\\"../../extensions/collections/HasStakingContract.sol\\\";\\nimport \\\"../../interfaces/validator/ISlashingExecution.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"./storage-fragments/CommonStorage.sol\\\";\\n\\nabstract contract SlashingExecution is\\n ISlashingExecution,\\n HasSlashIndicatorContract,\\n HasStakingContract,\\n CommonStorage\\n{\\n /**\\n * @inheritdoc ISlashingExecution\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external override onlySlashIndicatorContract {\\n uint256 _period = currentPeriod();\\n _miningRewardDeprecatedAtPeriod[_validatorAddr][_period] = true;\\n\\n _totalDeprecatedReward += _miningReward[_validatorAddr] + _delegatingReward[_validatorAddr];\\n\\n delete _miningReward[_validatorAddr];\\n delete _delegatingReward[_validatorAddr];\\n\\n _blockProducerJailedBlock[_validatorAddr] = Math.max(_newJailedUntil, _blockProducerJailedBlock[_validatorAddr]);\\n\\n if (_slashAmount > 0) {\\n uint256 _actualAmount = _stakingContract.execDeductStakingAmount(_validatorAddr, _slashAmount);\\n _totalDeprecatedReward += _actualAmount;\\n }\\n\\n if (_cannotBailout) {\\n _cannotBailoutUntilBlock[_validatorAddr] = Math.max(_newJailedUntil, _cannotBailoutUntilBlock[_validatorAddr]);\\n }\\n\\n emit ValidatorPunished(\\n _validatorAddr,\\n _period,\\n _blockProducerJailedBlock[_validatorAddr],\\n _slashAmount,\\n true,\\n false\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashingExecution\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external override onlySlashIndicatorContract {\\n if (block.number <= _cannotBailoutUntilBlock[_validatorAddr]) revert ErrCannotBailout(_validatorAddr);\\n\\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\\n // removed previously in the `slash` function.\\n _miningRewardBailoutCutOffAtPeriod[_validatorAddr][_period] = true;\\n _miningRewardDeprecatedAtPeriod[_validatorAddr][_period] = false;\\n _blockProducerJailedBlock[_validatorAddr] = block.number - 1;\\n\\n emit ValidatorUnjailed(_validatorAddr, _period);\\n }\\n}\\n\",\"keccak256\":\"0xf10b8566c1397e3dc86c6c16dcd20bf91011726b01dbff7da3a9d9a59bdee9b0\",\"license\":\"MIT\"},\"contracts/ronin/validator/storage-fragments/CommonStorage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../interfaces/validator/info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./JailingStorage.sol\\\";\\nimport \\\"./TimingStorage.sol\\\";\\nimport \\\"./ValidatorInfoStorage.sol\\\";\\n\\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorage {\\n /// @dev Mapping from consensus address => pending reward from producing block\\n mapping(address => uint256) internal _miningReward;\\n /// @dev Mapping from consensus address => pending reward from delegating\\n mapping(address => uint256) internal _delegatingReward;\\n\\n /// @dev The total reward for bridge operators\\n uint256 internal _totalBridgeReward;\\n /// @dev Mapping from consensus address => pending reward for being bridge operator\\n mapping(address => uint256) internal _bridgeOperatingReward;\\n\\n /// @dev The deprecated reward that has not been withdrawn by admin\\n uint256 internal _totalDeprecatedReward;\\n\\n /// @dev The amount of RON to lock from a consensus address.\\n uint256 internal _emergencyExitLockedAmount;\\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\\n uint256 internal _emergencyExpiryDuration;\\n /// @dev The address list of consensus addresses that being locked fund.\\n address[] internal _lockedConsensusList;\\n /// @dev Mapping from consensus => request exist info\\n mapping(address => EmergencyExitInfo) internal _exitInfo;\\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\\n mapping(address => bool) internal _lockedFundReleased;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[44] private ______gap;\\n\\n /**\\n * @inheritdoc ICommonInfo\\n */\\n function getEmergencyExitInfo(address _consensusAddr)\\n external\\n view\\n override\\n returns (EmergencyExitInfo memory _info)\\n {\\n _info = _exitInfo[_consensusAddr];\\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\\n }\\n\\n /**\\n * @inheritdoc ICommonInfo\\n */\\n function totalDeprecatedReward() external view override returns (uint256) {\\n return _totalDeprecatedReward;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function epochOf(uint256 _block)\\n public\\n view\\n virtual\\n override(ITimingInfo, JailingStorage, TimingStorage)\\n returns (uint256)\\n {\\n return TimingStorage.epochOf(_block);\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\\n return TimingStorage.currentPeriod();\\n }\\n}\\n\",\"keccak256\":\"0x7372a3febdddcd1fa0fdfd06eba11c58d1c3113ea1b408c0ab13b99eeeeb7b22\",\"license\":\"MIT\"},\"contracts/ronin/validator/storage-fragments/JailingStorage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../interfaces/validator/info-fragments/IJailingInfo.sol\\\";\\nimport \\\"./TimingStorage.sol\\\";\\n\\nabstract contract JailingStorage is IJailingInfo {\\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\\n mapping(address => mapping(uint256 => bool)) internal _bridgeRewardDeprecatedAtPeriod;\\n\\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\\n mapping(address => uint256) internal _blockProducerJailedBlock;\\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[48] private ______gap;\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkJailed(address _addr) external view override returns (bool) {\\n return checkJailedAtBlock(_addr, block.number);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n override\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n )\\n {\\n return getJailedTimeLeftAtBlock(_addr, block.number);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\\n return _jailedAtBlock(_addr, _blockNum);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n public\\n view\\n override\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n )\\n {\\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\\n if (_jailedBlock < _blockNum) {\\n return (false, 0, 0);\\n }\\n\\n isJailed_ = true;\\n blockLeft_ = _jailedBlock - _blockNum + 1;\\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\\n _result = new bool[](_addrList.length);\\n for (uint256 _i; _i < _addrList.length; _i++) {\\n _result[_i] = _jailed(_addrList[_i]);\\n }\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\\n uint256 _period = currentPeriod();\\n return _miningRewardDeprecated(_blockProducer, _period);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period)\\n external\\n view\\n override\\n returns (bool _result)\\n {\\n return _miningRewardDeprecated(_blockProducer, _period);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n *\\n * @dev Because the information of deprecating bridge reward of a period is only determined at the end of that period, this\\n * method will return the deprecating info of the latest period. A method for querying that info of current period is no need.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr)\\n external\\n view\\n override\\n returns (bool _result)\\n {\\n uint256 _period = currentPeriod() - 1;\\n return _bridgeRewardDeprecated(_consensusAddr, _period);\\n }\\n\\n /**\\n * @inheritdoc IJailingInfo\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n override\\n returns (bool _result)\\n {\\n return _bridgeRewardDeprecated(_consensusAddr, _period);\\n }\\n\\n /**\\n * @dev See `ITimingInfo-epochOf`\\n */\\n function epochOf(uint256 _block) public view virtual returns (uint256);\\n\\n /**\\n * @dev See `ITimingInfo-currentPeriod`\\n */\\n function currentPeriod() public view virtual returns (uint256);\\n\\n /**\\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\\n */\\n function _jailed(address _validatorAddr) internal view returns (bool) {\\n return _jailedAtBlock(_validatorAddr, block.number);\\n }\\n\\n /**\\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\\n */\\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\\n }\\n\\n /**\\n * @dev Returns whether the block producer has no pending reward in that period.\\n */\\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\\n }\\n\\n /**\\n * @dev Returns whether the bridge operator has no pending reward in the period.\\n */\\n function _bridgeRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\\n return _bridgeRewardDeprecatedAtPeriod[_validatorAddr][_period];\\n }\\n}\\n\",\"keccak256\":\"0x14ae5cc1f190f1b3e4517677b013638afc39a35d538303b8f0280fe1a52042c6\",\"license\":\"MIT\"},\"contracts/ronin/validator/storage-fragments/TimingStorage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../extensions/consumers/GlobalConfigConsumer.sol\\\";\\nimport \\\"../../../interfaces/validator/info-fragments/ITimingInfo.sol\\\";\\n\\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\\n /// @dev The number of blocks in a epoch\\n uint256 internal _numberOfBlocksInEpoch;\\n /// @dev The last updated block\\n uint256 internal _lastUpdatedBlock;\\n /// @dev The last updated period\\n uint256 internal _lastUpdatedPeriod;\\n /// @dev The starting block of the last updated period\\n uint256 internal _currentPeriodStartAtBlock;\\n\\n /// @dev Mapping from epoch index => period index\\n mapping(uint256 => uint256) internal _periodOf;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[49] private ______gap;\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function getLastUpdatedBlock() external view override returns (uint256) {\\n return _lastUpdatedBlock;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\\n return _block / _numberOfBlocksInEpoch + 1;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function isPeriodEnding() external view override returns (bool) {\\n return _isPeriodEnding(_computePeriod(block.timestamp));\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function currentPeriod() public view virtual override returns (uint256) {\\n return _lastUpdatedPeriod;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function currentPeriodStartAtBlock() public view override returns (uint256) {\\n return _currentPeriodStartAtBlock;\\n }\\n\\n /**\\n * @inheritdoc ITimingInfo\\n */\\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\\n return _numberOfBlocksInEpoch;\\n }\\n\\n /**\\n * @dev See `ITimingInfo-isPeriodEnding`\\n */\\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\\n return _newPeriod > _lastUpdatedPeriod;\\n }\\n\\n /**\\n * @dev Returns the calculated period.\\n */\\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\\n return _timestamp / PERIOD_DURATION;\\n }\\n}\\n\",\"keccak256\":\"0xc545f119b8b8978d793b62f2495dc2d49c3f416791459b9833bdc65f4dae8e7f\",\"license\":\"MIT\"},\"contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\nimport \\\"../../../extensions/collections/HasRoninTrustedOrganizationContract.sol\\\";\\nimport \\\"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\\\";\\n\\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasRoninTrustedOrganizationContract {\\n using EnumFlags for EnumFlags.ValidatorFlag;\\n\\n /// @dev The maximum number of validator.\\n uint256 internal _maxValidatorNumber;\\n\\n /// @dev The total of validators\\n uint256 public validatorCount;\\n /// @dev Mapping from validator index => validator address\\n mapping(uint256 => address) internal _validators;\\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\\n /// @dev The number of slot that is reserved for prioritized validators\\n uint256 internal _maxPrioritizedValidatorNumber;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function getValidators()\\n public\\n view\\n override\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n )\\n {\\n _validatorList = new address[](validatorCount);\\n _bridgeOperators = new address[](validatorCount);\\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\\n for (uint _i; _i < _validatorList.length; _i++) {\\n address _validator = _validators[_i];\\n _validatorList[_i] = _validator;\\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\\n _flags[_i] = _validatorMap[_validator];\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function isValidator(address _addr) public view override returns (bool) {\\n return !_validatorMap[_addr].isNone();\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function getBlockProducers() public view override returns (address[] memory _result) {\\n _result = new address[](validatorCount);\\n uint256 _count = 0;\\n for (uint _i; _i < _result.length; _i++) {\\n if (isBlockProducer(_validators[_i])) {\\n _result[_count++] = _validators[_i];\\n }\\n }\\n\\n assembly {\\n mstore(_result, _count)\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function isBlockProducer(address _addr) public view override returns (bool) {\\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function totalBlockProducers() external view returns (uint256 _total) {\\n for (uint _i; _i < validatorCount; _i++) {\\n if (isBlockProducer(_validators[_i])) {\\n _total++;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function getBridgeOperators() public view override returns (address[] memory _result) {\\n _result = new address[](validatorCount);\\n uint256 _count = 0;\\n for (uint _i; _i < _result.length; _i++) {\\n if (isOperatingBridge(_validators[_i])) {\\n _result[_count++] = _bridgeOperatorOf(_validators[_i]);\\n }\\n }\\n\\n assembly {\\n mstore(_result, _count)\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs)\\n public\\n view\\n override\\n returns (address[] memory _result)\\n {\\n _result = new address[](_validatorAddrs.length);\\n for (uint _i; _i < _result.length; _i++) {\\n _result[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\\n for (uint _i; _i < validatorCount; _i++) {\\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\\n _isOperator = true;\\n break;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.BridgeOperator);\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\\n return _maxValidatorNumber;\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\\n return _maxPrioritizedValidatorNumber;\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function totalBridgeOperators() public view returns (uint256 _total) {\\n for (uint _i; _i < validatorCount; _i++) {\\n if (isOperatingBridge(_validators[_i])) {\\n _total++;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\\n _setMaxValidatorNumber(_max);\\n }\\n\\n /**\\n * @inheritdoc IValidatorInfo\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\\n _setMaxPrioritizedValidatorNumber(_number);\\n }\\n\\n /**\\n * @dev Returns the bridge operator of a consensus address.\\n */\\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\\n\\n /**\\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\\n */\\n function _setMaxValidatorNumber(uint256 _number) internal {\\n _maxValidatorNumber = _number;\\n emit MaxValidatorNumberUpdated(_number);\\n }\\n\\n /**\\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\\n */\\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\\n _maxPrioritizedValidatorNumber = _number;\\n emit MaxPrioritizedValidatorNumberUpdated(_number);\\n }\\n}\\n\",\"keccak256\":\"0x19dca6ad64bd68923a8eaa9983ccfe0adb8cd7ad5d94b4ba708c35483adc430e\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x60806040523480156200001157600080fd5b506200001c62000022565b620000e4565b600054610100900460ff16156200008f5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff9081161015620000e2576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b615ffb80620000f46000396000f3fe6080604052600436106103455760003560e01c8063038278841461035c57806304d971ab1461038557806306040618146103b55780630f43a677146103ca5780631104e528146103e057806311662dc2146104005780631196ab661461043d57806315b5ebde1461045d5780631ab4a34c1461047d5780631f6288011461049d578063217f35c2146104bd57806323c65eb0146104d257806328bde1e1146104f25780632924de711461051f578063297a8fca1461053f5780632bcf3d15146105545780632d784a98146105745780632f78204c146105a157806331a8aef5146105c15780633529214b146105e1578063367ec12b146106035780633b3159b6146106235780634244d4c9146106375780634493421e14610664578063468c96ae1461068257806346fe9311146106b957806349096d26146106d95780634d8df063146106ee5780634de2b7351461070e5780634ee4d72b1461073b5780634f2a693f1461075057806352091f17146107705780635248184a146107785780635511cde11461079a578063562d5304146107b85780635a08482d146107cd578063605239a1146107e257806365244ece146107f75780636558954f146108175780636611f8431461082e578063690b75361461084e5780636aa1c2ef1461086357806372e46810146108785780637593ff7114610880578063823a7b9c146108a0578063873a5a70146108c057806387c891bd146108e05780638d559c38146108f557806396585fc2146109095780639b19dbfd146109295780639c8d98da1461093e5780639dd373b91461095e5780639e94b9ec1461097e578063a0c3f2d214610993578063a3d545f5146109b3578063a66c0f77146109d3578063a7c2f119146109e8578063ad29578314610a08578063b405aaf214610a28578063b5e337de14610a48578063b7ab4db514610a68578063ba77b06c14610a8c578063c3c8b5d614610aa1578063c94aaa0214610ac1578063cba44de914610ae1578063d09f1ab414610af6578063d2cb215e14610b0b578063d5a0744f14610b29578063dd716ad314610b49578063e5125a1d14610b69578063edb194bb14610b89578063ee99205c14610beb578063eeb629a814610c00578063facd743b14610c1557610354565b3661035457610352610c35565b005b610352610c35565b34801561036857600080fd5b506103726104b081565b6040519081526020015b60405180910390f35b34801561039157600080fd5b506103a56103a0366004615439565b610c9a565b604051901515815260200161037c565b3480156103c157600080fd5b50610372610cc1565b3480156103d657600080fd5b5061037260aa5481565b3480156103ec57600080fd5b506103526103fb366004615472565b610cd1565b34801561040c57600080fd5b5061042061041b3660046154d6565b610f5c565b60408051931515845260208401929092529082015260600161037c565b34801561044957600080fd5b50610352610458366004615502565b610fdf565b34801561046957600080fd5b506103526104783660046154d6565b611023565b34801561048957600080fd5b506103a561049836600461551b565b61113f565b3480156104a957600080fd5b506103a56104b836600461551b565b611169565b3480156104c957600080fd5b506103a56111a3565b3480156104de57600080fd5b506103a56104ed3660046154d6565b6111b8565b3480156104fe57600080fd5b5061051261050d36600461551b565b6111c4565b60405161037c919061558c565b34801561052b57600080fd5b506103a561053a36600461551b565b611267565b34801561054b57600080fd5b50600454610372565b34801561056057600080fd5b5061035261056f36600461551b565b611273565b34801561058057600080fd5b5061059461058f36600461551b565b6112df565b60405161037c919061559a565b3480156105ad57600080fd5b506103526105bc3660046155bf565b611341565b3480156105cd57600080fd5b506103a56105dc3660046154d6565b61155d565b3480156105ed57600080fd5b506105f6611569565b60405161037c9190615609565b34801561060f57600080fd5b5061035261061e36600461562e565b611578565b34801561062f57600080fd5b5060686105f6565b34801561064357600080fd5b5061065761065236600461575d565b611703565b60405161037c919061583f565b34801561067057600080fd5b50606e546001600160a01b03166105f6565b34801561068e57600080fd5b506106a261069d366004615502565b6117ba565b60408051921515835260208301919091520161037c565b3480156106c557600080fd5b506103526106d436600461551b565b6117f8565b3480156106e557600080fd5b50610657611864565b3480156106fa57600080fd5b50610352610709366004615502565b61194d565b34801561071a57600080fd5b5061072e610729366004615852565b61198e565b60405161037c91906158c6565b34801561074757600080fd5b5060e454610372565b34801561075c57600080fd5b5061035261076b366004615502565b611a49565b610352611a8a565b34801561078457600080fd5b5061078d611e49565b60405161037c919061590c565b3480156107a657600080fd5b5060a8546001600160a01b03166105f6565b3480156107c457600080fd5b50610372611f79565b3480156107d957600080fd5b506105f6611fcd565b3480156107ee57600080fd5b50607254610372565b34801561080357600080fd5b506103a561081236600461551b565b611fdc565b34801561082357600080fd5b506103726201518081565b34801561083a57600080fd5b50610352610849366004615502565b612010565b34801561085a57600080fd5b5060e554610372565b34801561086f57600080fd5b50600154610372565b610352612051565b34801561088c57600080fd5b506103a561089b366004615502565b6122b1565b3480156108ac57600080fd5b506103526108bb366004615502565b6122d5565b3480156108cc57600080fd5b506103a56108db36600461551b565b612316565b3480156108ec57600080fd5b50600254610372565b34801561090157600080fd5b5060666105f6565b34801561091557600080fd5b5061042061092436600461551b565b61232d565b34801561093557600080fd5b50610657612349565b34801561094a57600080fd5b5061035261095936600461551b565b612435565b34801561096a57600080fd5b5061035261097936600461551b565b6124a1565b34801561098a57600080fd5b5061037261250d565b34801561099f57600080fd5b506103a56109ae36600461551b565b612561565b3480156109bf57600080fd5b506103726109ce366004615502565b61257e565b3480156109df57600080fd5b5060e654610372565b3480156109f457600080fd5b50610352610a033660046154d6565b612589565b348015610a1457600080fd5b50610352610a2336600461551b565b612835565b348015610a3457600080fd5b506103a5610a4336600461551b565b6128a1565b348015610a5457600080fd5b50610352610a6336600461551b565b612926565b348015610a7457600080fd5b50610a7d612992565b60405161037c93929190615964565b348015610a9857600080fd5b50610657612b70565b348015610aad57600080fd5b50610352610abc366004615439565b612bd2565b348015610acd57600080fd5b50610352610adc366004615502565b612e55565b348015610aed57600080fd5b50607654610372565b348015610b0257600080fd5b5060a954610372565b348015610b1757600080fd5b50606f546001600160a01b03166105f6565b348015610b3557600080fd5b506103a5610b443660046154d6565b612e96565b348015610b5557600080fd5b50610352610b643660046154d6565b612ea2565b348015610b7557600080fd5b50610352610b843660046159dd565b612f4c565b348015610b9557600080fd5b50610594610ba436600461551b565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b348015610bf757600080fd5b506105f661307f565b348015610c0c57600080fd5b5060ad54610372565b348015610c2157600080fd5b506103a5610c3036600461551b565b61308e565b610c3d611569565b6001600160a01b0316336001600160a01b031614158015610c775750610c6161307f565b6001600160a01b0316336001600160a01b031614155b15610c985760405160016234baed60e01b0319815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610ccc60035490565b905090565b33610cda61307f565b6001600160a01b031614610d0157604051638aaf4a0760e01b815260040160405180910390fd5b6073546072548110610d2657604051638616841b60e01b815260040160405180910390fd5b610d2f85612561565b15610d4d57604051638ad9cdf960e01b815260040160405180910390fd5b612710821115610d7057604051631b8454a360e21b815260040160405180910390fd5b60005b607354811015610e6b5760006075600060738481548110610d9657610d96615a12565b60009182526020808320909101546001600160a01b03908116845290830193909352604090910190208054909250811690891603610df2578760405163fc3d8c7560e01b8152600401610de99190615609565b60405180910390fd5b60028101546001600160a01b0390811690871603610e255785604051632d33a7e760e11b8152600401610de99190615609565b60038101546001600160a01b0390811690861603610e5857846040516350e1263b60e01b8152600401610de99190615609565b5080610e6381615a3e565b915050610d73565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b03199081168717909155607590935292819020805483168c87169081178255938101805484168617905560028101805484168b8816908117909155600382018054909416968a1696909617909255600482018790555190939192907fd690f592ed983cfbc05717fbcf06c4e10ae328432c309fe49246cf4a4be69fcd90610f4b908990615609565b60405180910390a450505050505050565b6001600160a01b0382166000908152603a60205260408120548190819084811015610f9257600080600093509350935050610fd8565b60019350610fa08582615a57565b610fab906001615a6a565b9250610fb68561257e565b610fbf8261257e565b610fc99190615a57565b610fd4906001615a6a565b9150505b9250925092565b610fe76130cb565b6001600160a01b0316336001600160a01b0316146110175760405162461bcd60e51b8152600401610de990615a7d565b611020816130f9565b50565b3361102c611fcd565b6001600160a01b031614611053576040516328b9c24b60e21b815260040160405180910390fd5b6001600160a01b0382166000908152603c6020526040902054431161108d57816040516353e0424d60e01b8152600401610de99190615609565b6001600160a01b038216600081815260386020908152604080832085845282528083208054600160ff1991821681179092559484526037835281842086855290925290912080549092169091556110e49043615a57565b6001600160a01b0383166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e906111339084815260200190565b60405180910390a25050565b600080600161114c610cc1565b6111569190615a57565b90506111628382613157565b9392505050565b6001600160a01b038116600090815260ac6020526040812054610cbb9060029060ff16600381111561119d5761119d61594e565b90613182565b6000610ccc6111b1426131b5565b6003541090565b600061116283836131c4565b6111cc6153e8565b6111d582612561565b6111f25760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610cbb82436111b8565b61127b6130cb565b6001600160a01b0316336001600160a01b0316146112ab5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b6000036112d657604051637bcd509160e01b815260040160405180910390fd5b611020816131e4565b604080518082018252600080825260209182018190526001600160a01b038416815260e88252828120835180850190945280548452600101549183018290520361133c576040516370fdd4f160e11b815260040160405180910390fd5b919050565b3361134a611fcd565b6001600160a01b031614611371576040516328b9c24b60e21b815260040160405180910390fd5b600061137b610cc1565b6001600160a01b03861660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e0909152919020549192506113c991615a6a565b60e460008282546113da9190615a6a565b90915550506001600160a01b038516600090815260e06020908152604080832083905560e18252808320839055603a90915290205461141a90859061322f565b6001600160a01b0386166000908152603a602052604090205582156114ca5760715460405163138ac02f60e11b81526000916001600160a01b031690632715805e9061146c9089908890600401615abf565b6020604051808303816000875af115801561148b573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114af9190615ad8565b90508060e460008282546114c39190615a6a565b9091555050505b811561150e576001600160a01b0385166000908152603c60205260409020546114f490859061322f565b6001600160a01b0386166000908152603c60205260409020555b6001600160a01b0385166000818152603a6020526040808220549051849392600080516020615fa68339815191529261154e929091899160019190615af1565b60405180910390a35050505050565b60006111628383613246565b606d546001600160a01b031690565b600054610100900460ff16158080156115985750600054600160ff909116105b806115b25750303b1580156115b2575060005460ff166001145b6116155760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610de9565b6000805460ff191660011790558015611638576000805461ff0019166101001790555b6116418d6131e4565b61164a8c613271565b6116538b6132bc565b61165c8a613307565b61166588613352565b61166e8961339d565b611677876133e8565b6116808661341d565b61168985613452565b611692846130f9565b61169c82356134aa565b6116a960208301356134df565b600183905580156116f4576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050505050565b606081516001600160401b0381111561171e5761171e6156f4565b604051908082528060200260200182016040528015611747578160200160208202803683370190505b50905060005b81518110156117b45761177883828151811061176b5761176b615a12565b6020026020010151613514565b82828151811061178a5761178a615a12565b6001600160a01b0390921660209283029190910190910152806117ac81615a3e565b91505061174d565b50919050565b6000806117c64361257e565b831115806117e1575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b6118006130cb565b6001600160a01b0316336001600160a01b0316146118305760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361185b57604051637bcd509160e01b815260040160405180910390fd5b61102081613307565b606060aa546001600160401b03811115611880576118806156f4565b6040519080825280602002602001820160405280156118a9578160200160208202803683370190505b5090506000805b825181101561194757600081815260ab60205260409020546118da906001600160a01b0316611fdc565b1561193557600081815260ab60205260409020546001600160a01b0316838361190281615a3e565b94508151811061191457611914615a12565b60200260200101906001600160a01b031690816001600160a01b0316815250505b8061193f81615a3e565b9150506118b0565b50815290565b6119556130cb565b6001600160a01b0316336001600160a01b0316146119855760405162461bcd60e51b8152600401610de990615a7d565b611020816134df565b6060816001600160401b038111156119a8576119a86156f4565b6040519080825280602002602001820160405280156119d1578160200160208202803683370190505b50905060005b82811015611a4257611a0e8484838181106119f4576119f4615a12565b9050602002016020810190611a09919061551b565b61351f565b828281518110611a2057611a20615a12565b9115156020928302919091019091015280611a3a81615a3e565b9150506119d7565b5092915050565b611a516130cb565b6001600160a01b0316336001600160a01b031614611a815760405162461bcd60e51b8152600401610de990615a7d565b6110208161341d565b334114611aaa576040516309f358fd60e01b815260040160405180910390fd5b6000611ab533611fdc565b8015611ac75750611ac53361351f565b155b8015611ae15750611adf33611ada610cc1565b613246565b155b606d54604051630634f5b960e01b815282151560048201526001602482015291925060009182916001600160a01b031690630634f5b9906044016060604051808303816000875af1158015611b3a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b5e9190615b10565b92509250508060e26000828254611b759190615a6a565b90915550839050611bc7573460e46000828254611b929190615a6a565b90915550506040513390600080516020615f8683398151915290611bba903490600190615b47565b60405180910390a2505050565b336001600160a01b03167f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b13484604051611c02929190615b6b565b60405180910390a26000611c14610cc1565b90506000611c228434615a6a565b3360009081526038602090815260408083208684529091528120549192509060ff1615611d1b576070546040805163631c8fd160e11b815290516000926001600160a01b03169163c6391fa29160048083019260809291908290030181865afa158015611c93573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611cb79190615b79565b93505050506127108184611ccb9190615baf565b611cd59190615bdc565b91508160e46000828254611ce99190615a6a565b90915550506040513390600080516020615f8683398151915290611d11908590600290615b47565b60405180910390a2505b611d258183615a57565b60715460408051632298690160e11b8152815193955060009384936001600160a01b031692634530d20292600480820193918290030181865afa158015611d70573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d949190615bf0565b3360009081526075602052604081206004015492945090925090611dc290611dbc908461352b565b8461322f565b90506000612710611dd38784615baf565b611ddd9190615bdc565b33600090815260e06020526040812080549293508392909190611e01908490615a6a565b9091555060009050611e138288615a57565b33600090815260e16020526040812080549293508392909190611e37908490615a6a565b90915550505050505050505050505050565b6073546060906001600160401b03811115611e6657611e666156f4565b604051908082528060200260200182016040528015611e9f57816020015b611e8c6153e8565b815260200190600190039081611e845790505b50905060005b8151811015611f75576075600060738381548110611ec557611ec5615a12565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c08201528251839083908110611f5757611f57615a12565b60200260200101819052508080611f6d90615a3e565b915050611ea5565b5090565b6000805b60aa54811015611f7557600081815260ab6020526040902054611fa8906001600160a01b0316611169565b15611fbb5781611fb781615a3e565b9250505b80611fc581615a3e565b915050611f7d565b6070546001600160a01b031690565b6001600160a01b038116600090815260ac6020526040812054610cbb9060019060ff16600381111561119d5761119d61594e565b6120186130cb565b6001600160a01b0316336001600160a01b0316146120485760405162461bcd60e51b8152600401610de990615a7d565b611020816134aa565b334114612071576040516309f358fd60e01b815260040160405180910390fd5b61207a436122b1565b61209757604051636c74eecf60e01b815260040160405180910390fd5b6120a04361257e565b6120ab60025461257e565b106120c957604051632458f64160e01b815260040160405180910390fd5b4360025560006120d8426131b5565b905060006120e7826003541090565b905060006120f3612992565b50509050606060006121044361257e565b90506000612113826001615a6a565b9050600061211f610cc1565b9050851561224b57612131818661353a565b60008061213e83886138c5565b9150915061214e83888484613af7565b612156613c00565b61215e613d5b565b607054604051631da0214360e21b81526001600160a01b0390911690637680850c90612190908a908790600401615c14565b600060405180830381600087803b1580156121aa57600080fd5b505af11580156121be573d6000803e3d6000fd5b505050506121cb89613e7d565b805191985096501561223a576070546040516303e1697b60e11b81526001600160a01b03909116906307c2d2f69061220790899060040161583f565b600060405180830381600087803b15801561222157600080fd5b505af1158015612235573d6000803e3d6000fd5b505050505b612245436001615a6a565b60045550505b612256878387614008565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce78860405161228b911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b6000600180546122c19190615a57565b6001546122ce9084615c36565b1492915050565b6122dd6130cb565b6001600160a01b0316336001600160a01b03161461230d5760405162461bcd60e51b8152600401610de990615a7d565b611020816133e8565b600080612321610cc1565b90506111628382613246565b600080600061233c8443610f5c565b9250925092509193909250565b606060aa546001600160401b03811115612365576123656156f4565b60405190808252806020026020018201604052801561238e578160200160208202803683370190505b5090506000805b825181101561194757600081815260ab60205260409020546123bf906001600160a01b0316611169565b1561242357600081815260ab60205260409020546123e5906001600160a01b0316613514565b83836123f081615a3e565b94508151811061240257612402615a12565b60200260200101906001600160a01b031690816001600160a01b0316815250505b8061242d81615a3e565b915050612395565b61243d6130cb565b6001600160a01b0316336001600160a01b03161461246d5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361249857604051637bcd509160e01b815260040160405180910390fd5b61102081613352565b6124a96130cb565b6001600160a01b0316336001600160a01b0316146124d95760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361250457604051637bcd509160e01b815260040160405180910390fd5b61102081613271565b6000805b60aa54811015611f7557600081815260ab602052604090205461253c906001600160a01b0316611fdc565b1561254f578161254b81615a3e565b9250505b8061255981615a3e565b915050612511565b6001600160a01b0316600090815260746020526040902054151590565b6000610cbb826143d8565b3361259261307f565b6001600160a01b0316146125b957604051638aaf4a0760e01b815260040160405180910390fd5b6001600160a01b038216600090815260e8602052604090206001810154156125f45760405163057aab3160e31b815260040160405180910390fd5b60006126008342615a6a565b6001600160a01b038516600090815260756020526040902090915061262590826143f3565b6001600160a01b0384166000908152603b6020908152604080832084905560399091528120600191612655610cc1565b8152602081019190915260409081016000908120805460ff19169315159390931790925560715460e554915163138ac02f60e11b81526001600160a01b0390911691632715805e916126ab918991600401615abf565b6020604051808303816000875af11580156126ca573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906126ee9190615ad8565b905080156127eb57600060e654426127069190615a6a565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038a16179055838655850181905590506127646130cb565b6001600160a01b0387811660008181526075602052604090819020600201549051630a2fae5760e41b81526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b1580156127d157600080fd5b505af11580156127e5573d6000803e3d6000fd5b50505050505b846001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c48260405161282691815260200190565b60405180910390a25050505050565b61283d6130cb565b6001600160a01b0316336001600160a01b03161461286d5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361289857604051637bcd509160e01b815260040160405180910390fd5b611020816132bc565b6000805b60aa548110156117b457600081815260ab60205260409020546001600160a01b03808516916128d49116613514565b6001600160a01b03161480156129065750600081815260ab6020526040902054612906906001600160a01b0316611169565b1561291457600191506117b4565b8061291e81615a3e565b9150506128a5565b61292e6130cb565b6001600160a01b0316336001600160a01b03161461295e5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361298957604051637bcd509160e01b815260040160405180910390fd5b6110208161339d565b606080606060aa546001600160401b038111156129b1576129b16156f4565b6040519080825280602002602001820160405280156129da578160200160208202803683370190505b50925060aa546001600160401b038111156129f7576129f76156f4565b604051908082528060200260200182016040528015612a20578160200160208202803683370190505b50915060aa546001600160401b03811115612a3d57612a3d6156f4565b604051908082528060200260200182016040528015612a66578160200160208202803683370190505b50905060005b8351811015612b6a57600081815260ab602052604090205484516001600160a01b03909116908190869084908110612aa657612aa6615a12565b60200260200101906001600160a01b031690816001600160a01b031681525050612acf81613514565b848381518110612ae157612ae1615a12565b6001600160a01b03928316602091820292909201810191909152908216600090815260ac9091526040902054835160ff90911690849084908110612b2757612b27615a12565b60200260200101906003811115612b4057612b4061594e565b90816003811115612b5357612b5361594e565b905250819050612b6281615a3e565b915050612a6c565b50909192565b60606073805480602002602001604051908101604052809291908181526020018280548015612bc857602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311612baa575b5050505050905090565b612bda6130cb565b6001600160a01b0316336001600160a01b031614612c0a5760405162461bcd60e51b8152600401610de990615a7d565b6001600160a01b038216600090815260e8602052604090206001015415612e515760e7548060005b82811015612c8b57846001600160a01b031660e78281548110612c5757612c57615a12565b6000918252602090912001546001600160a01b031603612c7957809150612c8b565b80612c8381615a3e565b915050612c32565b50818103612c995750505050565b6001600160a01b038416600090815260e860205260409020548015612e4d576001600160a01b038516600090815260e860205260408120818155600190810191909155831115612d5b5760e7612cf0600185615a57565b81548110612d0057612d00615a12565b60009182526020909120015460e780546001600160a01b039092169184908110612d2c57612d2c615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480612d6c57612d6c615c4a565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff19166001179055612dbe84826104b061446f565b15612e0857836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e48360405161154e91815260200190565b836001600160a01b0316856001600160a01b03167f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a1834760405161154e929190615b6b565b5050505b5050565b612e5d6130cb565b6001600160a01b0316336001600160a01b031614612e8d5760405162461bcd60e51b8152600401610de990615a7d565b61102081613452565b60006111628383613157565b33612eab61307f565b6001600160a01b031614612ed257604051638aaf4a0760e01b815260040160405180910390fd5b612edb826144cf565b15612ef95760405163030081e760e01b815260040160405180910390fd5b6001600160a01b0382166000908152607560205260409020600581015415612f345760405163fab9167360e01b815260040160405180910390fd5b612f4781612f428442615a6a565b6143f3565b505050565b33612f5561307f565b6001600160a01b031614612f7c57604051638aaf4a0760e01b815260040160405180910390fd5b6001600160a01b03831660009081526077602052604090205415612fb357604051632f32dcdd60e11b815260040160405180910390fd5b612710811115612fd657604051631b8454a360e21b815260040160405180910390fd5b607654821015612ff95760405163fa0ae69360e01b815260040160405180910390fd5b6001600160a01b03831660009081526077602052604081209062015180846130218242615bdc565b61302b9190615a6a565b6130359190615baf565b808355600183018490556040519091506001600160a01b038616907f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f21906128269084908790615b6b565b6071546001600160a01b031690565b6001600160a01b038116600090815260ac60205260408120546130c49060ff1660038111156130bf576130bf61594e565b61454c565b1592915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600181101561311b576040516317b8970f60e01b815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a25267906020015b60405180910390a150565b6001600160a01b03919091166000908152603960209081526040808320938352929052205460ff1690565b60008160038111156131965761319661594e565b8360038111156131a8576131a861594e565b1660ff1615159392505050565b6000610cbb6201518083615bdc565b6001600160a01b03919091166000908152603a6020526040902054101590565b607080546001600160a01b0319166001600160a01b0383161790556040517faa5b07dd43aa44c69b70a6a2b9c3fcfed12b6e5f6323596ba7ac91035ab80a4f9061314c908390615609565b60008183101561323f5781611162565b5090919050565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b607180546001600160a01b0319166001600160a01b0383161790556040517f6397f5b135542bb3f477cb346cfab5abdec1251d08dc8f8d4efb4ffe122ea0bf9061314c908390615609565b606d80546001600160a01b0319166001600160a01b0383161790556040517fc328090a37d855191ab58469296f98f87a851ca57d5cdfd1e9ac3c83e9e7096d9061314c908390615609565b606f80546001600160a01b0319166001600160a01b0383161790556040517f31a33f126a5bae3c5bdf6cfc2cd6dcfffe2fe9634bdb09e21c44762993889e3b9061314c908390615609565b606e80546001600160a01b0319166001600160a01b0383161790556040517f034c8da497df28467c79ddadbba1cc3cdd41f510ea73faae271e6f16a61116219061314c908390615609565b60a880546001600160a01b0319166001600160a01b0383161790556040517ffd6f5f93d69a07c593a09be0b208bff13ab4ffd6017df3b33433d63bdc59b4d79061314c908390615609565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b59060200161314c565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab49060200161314c565b60a954811115613475576040516355408ce960e11b815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e9060200161314c565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a9060200161314c565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b9060200161314c565b6000610cbb8261456a565b6000610cbb82436131c4565b600081831061323f5781611162565b606e5460405163889998ef60e01b8152600481018490526000916001600160a01b03169063889998ef90602401602060405180830381865afa158015613584573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906135a89190615ad8565b606e5460405163033cdc2b60e31b8152600481018690529192506000916001600160a01b03909116906319e6e15890602401602060405180830381865afa1580156135f7573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061361b9190615ad8565b606e549091506000906001600160a01b031663f67e81528661363c87611703565b6040518363ffffffff1660e01b8152600401613659929190615c60565b600060405180830381865afa158015613676573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261369e9190810190615c81565b90506136ab83838361458f565b15806136b5575081155b156137325760005b845181101561372a57845160e2546136d59190615bdc565b60e360008784815181106136eb576136eb615a12565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002081905550808061372290615a3e565b9150506136bd565b505050505050565b600080600080607060009054906101000a90046001600160a01b03166001600160a01b0316631079402a6040518163ffffffff1660e01b8152600401608060405180830381865afa15801561378b573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906137af9190615b79565b9296509094509250905080861160005b89518110156138b857888782815181106137db576137db615a12565b602002602001015160e2546137f09190615baf565b6137fa9190615bdc565b60e360008c848151811061381057613810615a12565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020016000208190555081156138a6576138a68b8b838151811061385857613858615a12565b60200260200101518a6127108b868151811061387657613876615a12565b60200260200101516138889190615baf565b6138929190615bdc565b61389e90612710615a57565b878a8a614648565b806138b081615a3e565b9150506137bf565b5050505050505050505050565b6000606060008084516001600160401b038111156138e5576138e56156f4565b60405190808252806020026020018201604052801561390e578160200160208202803683370190505b50925060005b8551811015613ae75785818151811061392f5761392f615a12565b6020908102919091018101516001600160a01b03808216600090815260759093526040909220600201549094501691506139698388613157565b61399c576001600160a01b0380841660009081526075602052604090206003015461399791859116846148a8565b6139ce565b6001600160a01b038316600090815260e3602052604081205460e48054919290916139c8908490615a6a565b90915550505b6139d78361351f565b1580156139eb57506139e98388613246565b155b15613a5f576001600160a01b038316600090815260e16020526040902054613a139086615a6a565b6001600160a01b038416600090815260e16020526040902054855191965090859083908110613a4457613a44615a12565b602002602001018181525050613a5a8383614985565b613aa5565b6001600160a01b038316600090815260e1602090815260408083205460e090925290912054613a8e9190615a6a565b60e46000828254613a9f9190615a6a565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e390915281205580613adf81615a3e565b915050613914565b5060e26000905550509250929050565b6071546001600160a01b03168215612e4d57613b138184614a4d565b15613bbb5760405163566bce2360e11b81526001600160a01b0382169063acd79c4690613b4890879086908a90600401615d36565b600060405180830381600087803b158015613b6257600080fd5b505af1158015613b76573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d087838584604051613bad93929190615d6c565b60405180910390a150613bfa565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f8983858447604051613bf09493929190615da1565b60405180910390a1505b50505050565b60e754600080805b83831015613bfa5760e78381548110613c2357613c23615a12565b60009182526020808320909101546001600160a01b031680835260e89091526040909120600181015491935091504210613d4957805460e48054600090613c6b908490615a6a565b90915550506001600160a01b038216600090815260e860205260408120818155600101819055613c9a85615dde565b9450841115613d115760e78481548110613cb657613cb6615a12565b60009182526020909120015460e780546001600160a01b039092169185908110613ce257613ce2615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480613d2257613d22615c4a565b600082815260209020810160001990810180546001600160a01b0319169055019055613c08565b82613d5381615a3e565b935050613c08565b60e4548015611020576000613d6e611569565b600060e481905560408051600481526024810182526020810180516001600160e01b03166359f778df60e01b179052905192935090916001600160a01b038416918591613dbb9190615df5565b60006040518083038185875af1925050503d8060008114613df8576040519150601f19603f3d011682016040523d82523d6000602084013e613dfd565b606091505b505090508015613e4257816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051611bba91815260200190565b816001600160a01b03167fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b738447604051611bba929190615b6b565b606080613e8983614aa9565b6071546040516391f8723f60e01b81529192506000916001600160a01b03909116906391f8723f90613ec090607390600401615e24565b600060405180830381865afa158015613edd573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613f059190810190615c81565b60a854604051632907e73160e11b81529192506000916001600160a01b039091169063520fce6290613f3c90607390600401615e24565b600060405180830381865afa158015613f59573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613f819190810190615c81565b90506000613ff06073805480602002602001604051908101604052809291908181526020018280548015613fde57602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311613fc0575b5050505050848460a95460ad54614f9c565b9095509050614000858288615066565b505050915091565b606f546000906001600160a01b031663fdadda8183614028436001615a6a565b6040518363ffffffff1660e01b8152600401614045929190615c14565b600060405180830381865afa158015614062573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261408a9190810190615e68565b905060005b82518110156143515760008382815181106140ac576140ac615a12565b6020908102919091018101516001600160a01b0381166000908152603b9092526040822054909250421115906140e183611fdc565b905060006140f9846140f4436001615a6a565b6131c4565b8061411a575085858151811061411157614111615a12565b60200260200101515b806141225750825b159050811580156141305750805b156141ab576001600160a01b038416600090815260ac602052604090205461416f9060019060ff1660038111156141695761416961594e565b906151c4565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156141a1576141a161594e565b021790555061422d565b8180156141b6575080155b1561422d576001600160a01b038416600090815260ac60205260409020546141f59060019060ff1660038111156141ef576141ef61594e565b906151ff565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156142275761422761594e565b02179055505b600061423885611169565b90508315811580156142475750805b156142bc576001600160a01b038616600090815260ac60205260409020546142809060029060ff1660038111156141695761416961594e565b6001600160a01b038716600090815260ac60205260409020805460ff191660018360038111156142b2576142b261594e565b0217905550614338565b8180156142c7575080155b15614338576001600160a01b038616600090815260ac60205260409020546143009060029060ff1660038111156141ef576141ef61594e565b6001600160a01b038716600090815260ac60205260409020805460ff191660018360038111156143325761433261594e565b02179055505b505050505050808061434990615a3e565b91505061408f565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b8261437d611864565b60405161438a919061583f565b60405180910390a382847f773d1888df530d69716b183a92450d45f97fba49f2a4bb34fae3b23da0e2cc6f6143bd612349565b6040516143ca919061583f565b60405180910390a350505050565b6000600154826143e89190615bdc565b610cbb906001615a6a565b600182015461440a906001600160a01b0316612561565b6144275760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e790602001611133565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146144bf576040519150601f19603f3d011682016040523d82523d6000602084013e6144c4565b606091505b509095945050505050565b60a85460405163107fbb4760e21b815260009182916001600160a01b03909116906341feed1c90614504908690600401615609565b602060405180830381865afa158015614521573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906145459190615ad8565b1192915050565b60008160038111156145605761456061594e565b60ff161592915050565b6001600160a01b03808216600090815260756020526040812060030154909116610cbb565b60016000805b835181101561460157848482815181106145b1576145b1615a12565b602002602001015111156145c85760009250614601565b8381815181106145da576145da615a12565b6020026020010151826145ed9190615a6a565b9150806145f981615a3e565b915050614595565b5081801561460f5750848111155b915081614640576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a15b509392505050565b8084106147c4576001600160a01b03851660008181526039602090815260408083208a845282528083208054600160ff199182168117909255948452603783528184208b855290925282208054909316179091556146a6438561523b565b6001600160a01b0387166000908152603a60205260409020549091506146cd90829061322f565b6001600160a01b0387166000908152603a6020908152604080832093909355603c905220546146fd90829061322f565b6001600160a01b038088166000908152603c60205260409081902092909255607054915163c008ce3960e01b815291169063c008ce39906147479089906002908c90600401615ef6565b600060405180830381600087803b15801561476157600080fd5b505af1158015614775573d6000803e3d6000fd5b5050506001600160a01b0387166000818152603a60205260408082205490518b9450600080516020615fa6833981519152926147b692916001908190615af1565b60405180910390a35061372a565b81841061372a576001600160a01b0380861660009081526039602090815260408083208a845290915290819020805460ff19166001908117909155607054915163c008ce3960e01b8152919092169163c008ce39916148299189918b90600401615ef6565b600060405180830381600087803b15801561484357600080fd5b505af1158015614857573d6000803e3d6000fd5b5050506001600160a01b0386166000818152603a60205260408082205490518a9450600080516020615fa68339815191529261489892918190600190615af1565b60405180910390a3505050505050565b6001600160a01b038316600090815260e360205260409020548015613bfa576148d482826104b061446f565b1561493657816001600160a01b0316836001600160a01b0316856001600160a01b03167f72a57dc38837a1cba7881b7b1a5594d9e6b65cec6a985b54e2cee3e89369691c8460405161492891815260200190565b60405180910390a450505050565b816001600160a01b0316836001600160a01b0316856001600160a01b03167fd35d76d87d51ed89407fc7ceaaccf32cf72784b94530892ce33546540e141b728447604051614928929190615b6b565b6001600160a01b038216600090815260e060205260409020548015612f47576149b182826104b061446f565b15614a0857816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec836040516149fb91815260200190565b60405180910390a3505050565b816001600160a01b0316836001600160a01b03167f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e83476040516149fb929190615b6b565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114614a9a576040519150601f19603f3d011682016040523d82523d6000602084013e614a9f565b606091505b5090949350505050565b6071546040805163af24542960e01b815290516060926001600160a01b031691600091839163af2454299160048083019260209291908290030181865afa158015614af8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190614b1c9190615ad8565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015614b5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190614b829190615ad8565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b8152600401614bb39190615e24565b600060405180830381865afa158015614bd0573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052614bf89190810190615c81565b6073549091506000816001600160401b03811115614c1857614c186156f4565b604051908082528060200260200182016040528015614c41578160200160208202803683370190505b50965060008060005b84831015614eed5760738381548110614c6557614c65615a12565b60009182526020808320909101546001600160a01b031680835260759091526040909120600681015488519294509092501515908890889086908110614cad57614cad615a12565b60200260200101511015614d095780614d04576000614ccc8a42615a6a565b600684018190556040518181529091506001600160a01b03851690600080516020615f668339815191529060200160405180910390a2505b614d4a565b8015614d4a578160060160009055826001600160a01b0316600080516020615f668339815191526000604051614d4191815260200190565b60405180910390a25b60008260050154600014158015614d65575042836005015411155b80614d8857506001600160a01b038416600090815260e9602052604090205460ff165b905060008360060154600014158015614da5575042846006015411155b90508180614db05750805b15614e465788614dbf89615dde565b98508881518110614dd257614dd2615a12565b6020026020010151898781518110614dec57614dec615a12565b6020908102919091010152848d88614e0381615a3e565b995081518110614e1557614e15615a12565b60200260200101906001600160a01b031690816001600160a01b031681525050614e3e85615256565b505050614c4a565b6001600160a01b0385166000908152607760205260409020548015801590614e6e5750428111155b15614ed7576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b86614ee181615a3e565b97505050505050614c4a565b5050508087528015614f91577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c9187604051614f28919061583f565b60405180910390a160405163e22d1c9d60e01b81526001600160a01b0387169063e22d1c9d90614f5e908a908c90600401615c14565b600060405180830381600087803b158015614f7857600080fd5b505af1158015614f8c573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401614fc0959493929190615f17565b60408051601f19818403018152919052602080820180516001600160e01b0316633bca0a8960e11b17905281518b51929350600192909160009161500391615baf565b61500e906040615a6a565b90506020840181888483895afa61502457600093505b503d61502f57600092505b6020870196508261505357604051630fc2632160e01b815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa548110156150c457600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b0319169055806150bc81615a3e565b915050615068565b5060005b8281101561510e57600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff191690558061510681615a3e565b9150506150c8565b5060005b8281101561518c57600084828151811061512e5761512e615a12565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b0319169091179055508061518481615a3e565b915050615112565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051611bba919061583f565b60008160038111156151d8576151d861594e565b8360038111156151ea576151ea61594e565b1760ff1660038111156111625761116261594e565b60008160038111156152135761521361594e565b198360038111156152265761522661594e565b1660ff1660038111156111625761116261594e565b60008160000361524c576000611162565b6111628284615a6a565b6001600160a01b038116600090815260e960209081526040808320805460ff19169055607490915281205461102091839190819003615293575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b03199081168255600180830180548316905560028301805483169055600383018054909216909155600482018590556005820185905560069091018490556074835281842084905560779092528220828155810182905560738054909161531d91615a57565b8154811061532d5761532d615a12565b6000918252602090912001546001600160a01b039081169150831681146153b0576001600160a01b038116600090815260746020526040902082905560738054829190841990811061538157615381615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60738054806153c1576153c1615c4a565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6040805160e081018252600080825260208201819052918101829052606081018290526080810182905260a0810182905260c081019190915290565b6001600160a01b038116811461102057600080fd5b6000806040838503121561544c57600080fd5b823561545781615424565b9150602083013561546781615424565b809150509250929050565b600080600080600060a0868803121561548a57600080fd5b853561549581615424565b945060208601356154a581615424565b935060408601356154b581615424565b925060608601356154c581615424565b949793965091946080013592915050565b600080604083850312156154e957600080fd5b82356154f481615424565b946020939093013593505050565b60006020828403121561551457600080fd5b5035919050565b60006020828403121561552d57600080fd5b813561116281615424565b60018060a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b60e08101610cbb8284615538565b815181526020808301519082015260408101610cbb565b801515811461102057600080fd5b600080600080608085870312156155d557600080fd5b84356155e081615424565b9350602085013592506040850135915060608501356155fe816155b1565b939692955090935050565b6001600160a01b0391909116815260200190565b8060408101831015610cbb57600080fd5b6000806000806000806000806000806000806101a08d8f03121561565157600080fd5b8c3561565c81615424565b9b5060208d013561566c81615424565b9a5060408d013561567c81615424565b995060608d013561568c81615424565b985060808d013561569c81615424565b975060a08d01356156ac81615424565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d013591506156e28e6101608f0161561d565b90509295989b509295989b509295989b565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b0381118282101715615732576157326156f4565b604052919050565b60006001600160401b03821115615753576157536156f4565b5060051b60200190565b6000602080838503121561577057600080fd5b82356001600160401b0381111561578657600080fd5b8301601f8101851361579757600080fd5b80356157aa6157a58261573a565b61570a565b81815260059190911b820183019083810190878311156157c957600080fd5b928401925b828410156157f05783356157e181615424565b825292840192908401906157ce565b979650505050505050565b600081518084526020808501945080840160005b838110156158345781516001600160a01b03168752958201959082019060010161580f565b509495945050505050565b60208152600061116260208301846157fb565b6000806020838503121561586557600080fd5b82356001600160401b038082111561587c57600080fd5b818501915085601f83011261589057600080fd5b81358181111561589f57600080fd5b8660208260051b85010111156158b457600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b818110156159005783511515835292840192918401916001016158e2565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b818110156159005761593b838551615538565b9284019260e09290920191600101615928565b634e487b7160e01b600052602160045260246000fd5b60608152600061597760608301866157fb565b60208382038185015261598a82876157fb565b8481036040860152855180825282870193509082019060005b818110156159cf578451600481106159bd576159bd61594e565b835293830193918301916001016159a3565b509098975050505050505050565b6000806000606084860312156159f257600080fd5b83356159fd81615424565b95602085013595506040909401359392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201615a5057615a50615a28565b5060010190565b81810381811115610cbb57610cbb615a28565b80820180821115610cbb57610cbb615a28565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b6001600160a01b03929092168252602082015260400190565b600060208284031215615aea57600080fd5b5051919050565b9384526020840192909252151560408301521515606082015260800190565b600080600060608486031215615b2557600080fd5b8351615b30816155b1565b602085015160409095015190969495509392505050565b8281526040810160038310615b5e57615b5e61594e565b8260208301529392505050565b918252602082015260400190565b60008060008060808587031215615b8f57600080fd5b505082516020840151604085015160609095015191969095509092509050565b8082028115828204841417610cbb57610cbb615a28565b634e487b7160e01b600052601260045260246000fd5b600082615beb57615beb615bc6565b500490565b60008060408385031215615c0357600080fd5b505080516020909101519092909150565b604081526000615c2760408301856157fb565b90508260208301529392505050565b600082615c4557615c45615bc6565b500690565b634e487b7160e01b600052603160045260246000fd5b828152604060208201526000615c7960408301846157fb565b949350505050565b60006020808385031215615c9457600080fd5b82516001600160401b03811115615caa57600080fd5b8301601f81018513615cbb57600080fd5b8051615cc96157a58261573a565b81815260059190911b82018301908381019087831115615ce857600080fd5b928401925b828410156157f057835182529284019290840190615ced565b600081518084526020808501945080840160005b8381101561583457815187529582019590820190600101615d1a565b606081526000615d4960608301866157fb565b8281036020840152615d5b8186615d06565b915050826040830152949350505050565b838152606060208201526000615d8560608301856157fb565b8281036040840152615d978185615d06565b9695505050505050565b848152608060208201526000615dba60808301866157fb565b8281036040840152615dcc8186615d06565b91505082606083015295945050505050565b600081615ded57615ded615a28565b506000190190565b6000825160005b81811015615e165760208186018101518583015201615dfc565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b818110156159005783546001600160a01b031683526001938401939285019201615e43565b60006020808385031215615e7b57600080fd5b82516001600160401b03811115615e9157600080fd5b8301601f81018513615ea257600080fd5b8051615eb06157a58261573a565b81815260059190911b82018301908381019087831115615ecf57600080fd5b928401925b828410156157f0578351615ee7816155b1565b82529284019290840190615ed4565b6001600160a01b039390931683526020830191909152604082015260600190565b60a081526000615f2a60a08301886157fb565b8281036020840152615f3c8188615d06565b90508281036040840152615f508187615d06565b6060840195909552505060800152939250505056fe88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342754042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68aa2646970667358221220a1eb2c9a0a4cbc889fd4810519c15ef9865e041ad7aa23ef79fce6ce5a27a4c564736f6c63430008110033", - "deployedBytecode": "0x6080604052600436106103455760003560e01c8063038278841461035c57806304d971ab1461038557806306040618146103b55780630f43a677146103ca5780631104e528146103e057806311662dc2146104005780631196ab661461043d57806315b5ebde1461045d5780631ab4a34c1461047d5780631f6288011461049d578063217f35c2146104bd57806323c65eb0146104d257806328bde1e1146104f25780632924de711461051f578063297a8fca1461053f5780632bcf3d15146105545780632d784a98146105745780632f78204c146105a157806331a8aef5146105c15780633529214b146105e1578063367ec12b146106035780633b3159b6146106235780634244d4c9146106375780634493421e14610664578063468c96ae1461068257806346fe9311146106b957806349096d26146106d95780634d8df063146106ee5780634de2b7351461070e5780634ee4d72b1461073b5780634f2a693f1461075057806352091f17146107705780635248184a146107785780635511cde11461079a578063562d5304146107b85780635a08482d146107cd578063605239a1146107e257806365244ece146107f75780636558954f146108175780636611f8431461082e578063690b75361461084e5780636aa1c2ef1461086357806372e46810146108785780637593ff7114610880578063823a7b9c146108a0578063873a5a70146108c057806387c891bd146108e05780638d559c38146108f557806396585fc2146109095780639b19dbfd146109295780639c8d98da1461093e5780639dd373b91461095e5780639e94b9ec1461097e578063a0c3f2d214610993578063a3d545f5146109b3578063a66c0f77146109d3578063a7c2f119146109e8578063ad29578314610a08578063b405aaf214610a28578063b5e337de14610a48578063b7ab4db514610a68578063ba77b06c14610a8c578063c3c8b5d614610aa1578063c94aaa0214610ac1578063cba44de914610ae1578063d09f1ab414610af6578063d2cb215e14610b0b578063d5a0744f14610b29578063dd716ad314610b49578063e5125a1d14610b69578063edb194bb14610b89578063ee99205c14610beb578063eeb629a814610c00578063facd743b14610c1557610354565b3661035457610352610c35565b005b610352610c35565b34801561036857600080fd5b506103726104b081565b6040519081526020015b60405180910390f35b34801561039157600080fd5b506103a56103a0366004615439565b610c9a565b604051901515815260200161037c565b3480156103c157600080fd5b50610372610cc1565b3480156103d657600080fd5b5061037260aa5481565b3480156103ec57600080fd5b506103526103fb366004615472565b610cd1565b34801561040c57600080fd5b5061042061041b3660046154d6565b610f5c565b60408051931515845260208401929092529082015260600161037c565b34801561044957600080fd5b50610352610458366004615502565b610fdf565b34801561046957600080fd5b506103526104783660046154d6565b611023565b34801561048957600080fd5b506103a561049836600461551b565b61113f565b3480156104a957600080fd5b506103a56104b836600461551b565b611169565b3480156104c957600080fd5b506103a56111a3565b3480156104de57600080fd5b506103a56104ed3660046154d6565b6111b8565b3480156104fe57600080fd5b5061051261050d36600461551b565b6111c4565b60405161037c919061558c565b34801561052b57600080fd5b506103a561053a36600461551b565b611267565b34801561054b57600080fd5b50600454610372565b34801561056057600080fd5b5061035261056f36600461551b565b611273565b34801561058057600080fd5b5061059461058f36600461551b565b6112df565b60405161037c919061559a565b3480156105ad57600080fd5b506103526105bc3660046155bf565b611341565b3480156105cd57600080fd5b506103a56105dc3660046154d6565b61155d565b3480156105ed57600080fd5b506105f6611569565b60405161037c9190615609565b34801561060f57600080fd5b5061035261061e36600461562e565b611578565b34801561062f57600080fd5b5060686105f6565b34801561064357600080fd5b5061065761065236600461575d565b611703565b60405161037c919061583f565b34801561067057600080fd5b50606e546001600160a01b03166105f6565b34801561068e57600080fd5b506106a261069d366004615502565b6117ba565b60408051921515835260208301919091520161037c565b3480156106c557600080fd5b506103526106d436600461551b565b6117f8565b3480156106e557600080fd5b50610657611864565b3480156106fa57600080fd5b50610352610709366004615502565b61194d565b34801561071a57600080fd5b5061072e610729366004615852565b61198e565b60405161037c91906158c6565b34801561074757600080fd5b5060e454610372565b34801561075c57600080fd5b5061035261076b366004615502565b611a49565b610352611a8a565b34801561078457600080fd5b5061078d611e49565b60405161037c919061590c565b3480156107a657600080fd5b5060a8546001600160a01b03166105f6565b3480156107c457600080fd5b50610372611f79565b3480156107d957600080fd5b506105f6611fcd565b3480156107ee57600080fd5b50607254610372565b34801561080357600080fd5b506103a561081236600461551b565b611fdc565b34801561082357600080fd5b506103726201518081565b34801561083a57600080fd5b50610352610849366004615502565b612010565b34801561085a57600080fd5b5060e554610372565b34801561086f57600080fd5b50600154610372565b610352612051565b34801561088c57600080fd5b506103a561089b366004615502565b6122b1565b3480156108ac57600080fd5b506103526108bb366004615502565b6122d5565b3480156108cc57600080fd5b506103a56108db36600461551b565b612316565b3480156108ec57600080fd5b50600254610372565b34801561090157600080fd5b5060666105f6565b34801561091557600080fd5b5061042061092436600461551b565b61232d565b34801561093557600080fd5b50610657612349565b34801561094a57600080fd5b5061035261095936600461551b565b612435565b34801561096a57600080fd5b5061035261097936600461551b565b6124a1565b34801561098a57600080fd5b5061037261250d565b34801561099f57600080fd5b506103a56109ae36600461551b565b612561565b3480156109bf57600080fd5b506103726109ce366004615502565b61257e565b3480156109df57600080fd5b5060e654610372565b3480156109f457600080fd5b50610352610a033660046154d6565b612589565b348015610a1457600080fd5b50610352610a2336600461551b565b612835565b348015610a3457600080fd5b506103a5610a4336600461551b565b6128a1565b348015610a5457600080fd5b50610352610a6336600461551b565b612926565b348015610a7457600080fd5b50610a7d612992565b60405161037c93929190615964565b348015610a9857600080fd5b50610657612b70565b348015610aad57600080fd5b50610352610abc366004615439565b612bd2565b348015610acd57600080fd5b50610352610adc366004615502565b612e55565b348015610aed57600080fd5b50607654610372565b348015610b0257600080fd5b5060a954610372565b348015610b1757600080fd5b50606f546001600160a01b03166105f6565b348015610b3557600080fd5b506103a5610b443660046154d6565b612e96565b348015610b5557600080fd5b50610352610b643660046154d6565b612ea2565b348015610b7557600080fd5b50610352610b843660046159dd565b612f4c565b348015610b9557600080fd5b50610594610ba436600461551b565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b348015610bf757600080fd5b506105f661307f565b348015610c0c57600080fd5b5060ad54610372565b348015610c2157600080fd5b506103a5610c3036600461551b565b61308e565b610c3d611569565b6001600160a01b0316336001600160a01b031614158015610c775750610c6161307f565b6001600160a01b0316336001600160a01b031614155b15610c985760405160016234baed60e01b0319815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610ccc60035490565b905090565b33610cda61307f565b6001600160a01b031614610d0157604051638aaf4a0760e01b815260040160405180910390fd5b6073546072548110610d2657604051638616841b60e01b815260040160405180910390fd5b610d2f85612561565b15610d4d57604051638ad9cdf960e01b815260040160405180910390fd5b612710821115610d7057604051631b8454a360e21b815260040160405180910390fd5b60005b607354811015610e6b5760006075600060738481548110610d9657610d96615a12565b60009182526020808320909101546001600160a01b03908116845290830193909352604090910190208054909250811690891603610df2578760405163fc3d8c7560e01b8152600401610de99190615609565b60405180910390fd5b60028101546001600160a01b0390811690871603610e255785604051632d33a7e760e11b8152600401610de99190615609565b60038101546001600160a01b0390811690861603610e5857846040516350e1263b60e01b8152600401610de99190615609565b5080610e6381615a3e565b915050610d73565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b03199081168717909155607590935292819020805483168c87169081178255938101805484168617905560028101805484168b8816908117909155600382018054909416968a1696909617909255600482018790555190939192907fd690f592ed983cfbc05717fbcf06c4e10ae328432c309fe49246cf4a4be69fcd90610f4b908990615609565b60405180910390a450505050505050565b6001600160a01b0382166000908152603a60205260408120548190819084811015610f9257600080600093509350935050610fd8565b60019350610fa08582615a57565b610fab906001615a6a565b9250610fb68561257e565b610fbf8261257e565b610fc99190615a57565b610fd4906001615a6a565b9150505b9250925092565b610fe76130cb565b6001600160a01b0316336001600160a01b0316146110175760405162461bcd60e51b8152600401610de990615a7d565b611020816130f9565b50565b3361102c611fcd565b6001600160a01b031614611053576040516328b9c24b60e21b815260040160405180910390fd5b6001600160a01b0382166000908152603c6020526040902054431161108d57816040516353e0424d60e01b8152600401610de99190615609565b6001600160a01b038216600081815260386020908152604080832085845282528083208054600160ff1991821681179092559484526037835281842086855290925290912080549092169091556110e49043615a57565b6001600160a01b0383166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e906111339084815260200190565b60405180910390a25050565b600080600161114c610cc1565b6111569190615a57565b90506111628382613157565b9392505050565b6001600160a01b038116600090815260ac6020526040812054610cbb9060029060ff16600381111561119d5761119d61594e565b90613182565b6000610ccc6111b1426131b5565b6003541090565b600061116283836131c4565b6111cc6153e8565b6111d582612561565b6111f25760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610cbb82436111b8565b61127b6130cb565b6001600160a01b0316336001600160a01b0316146112ab5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b6000036112d657604051637bcd509160e01b815260040160405180910390fd5b611020816131e4565b604080518082018252600080825260209182018190526001600160a01b038416815260e88252828120835180850190945280548452600101549183018290520361133c576040516370fdd4f160e11b815260040160405180910390fd5b919050565b3361134a611fcd565b6001600160a01b031614611371576040516328b9c24b60e21b815260040160405180910390fd5b600061137b610cc1565b6001600160a01b03861660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e0909152919020549192506113c991615a6a565b60e460008282546113da9190615a6a565b90915550506001600160a01b038516600090815260e06020908152604080832083905560e18252808320839055603a90915290205461141a90859061322f565b6001600160a01b0386166000908152603a602052604090205582156114ca5760715460405163138ac02f60e11b81526000916001600160a01b031690632715805e9061146c9089908890600401615abf565b6020604051808303816000875af115801561148b573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114af9190615ad8565b90508060e460008282546114c39190615a6a565b9091555050505b811561150e576001600160a01b0385166000908152603c60205260409020546114f490859061322f565b6001600160a01b0386166000908152603c60205260409020555b6001600160a01b0385166000818152603a6020526040808220549051849392600080516020615fa68339815191529261154e929091899160019190615af1565b60405180910390a35050505050565b60006111628383613246565b606d546001600160a01b031690565b600054610100900460ff16158080156115985750600054600160ff909116105b806115b25750303b1580156115b2575060005460ff166001145b6116155760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610de9565b6000805460ff191660011790558015611638576000805461ff0019166101001790555b6116418d6131e4565b61164a8c613271565b6116538b6132bc565b61165c8a613307565b61166588613352565b61166e8961339d565b611677876133e8565b6116808661341d565b61168985613452565b611692846130f9565b61169c82356134aa565b6116a960208301356134df565b600183905580156116f4576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050505050565b606081516001600160401b0381111561171e5761171e6156f4565b604051908082528060200260200182016040528015611747578160200160208202803683370190505b50905060005b81518110156117b45761177883828151811061176b5761176b615a12565b6020026020010151613514565b82828151811061178a5761178a615a12565b6001600160a01b0390921660209283029190910190910152806117ac81615a3e565b91505061174d565b50919050565b6000806117c64361257e565b831115806117e1575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b6118006130cb565b6001600160a01b0316336001600160a01b0316146118305760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361185b57604051637bcd509160e01b815260040160405180910390fd5b61102081613307565b606060aa546001600160401b03811115611880576118806156f4565b6040519080825280602002602001820160405280156118a9578160200160208202803683370190505b5090506000805b825181101561194757600081815260ab60205260409020546118da906001600160a01b0316611fdc565b1561193557600081815260ab60205260409020546001600160a01b0316838361190281615a3e565b94508151811061191457611914615a12565b60200260200101906001600160a01b031690816001600160a01b0316815250505b8061193f81615a3e565b9150506118b0565b50815290565b6119556130cb565b6001600160a01b0316336001600160a01b0316146119855760405162461bcd60e51b8152600401610de990615a7d565b611020816134df565b6060816001600160401b038111156119a8576119a86156f4565b6040519080825280602002602001820160405280156119d1578160200160208202803683370190505b50905060005b82811015611a4257611a0e8484838181106119f4576119f4615a12565b9050602002016020810190611a09919061551b565b61351f565b828281518110611a2057611a20615a12565b9115156020928302919091019091015280611a3a81615a3e565b9150506119d7565b5092915050565b611a516130cb565b6001600160a01b0316336001600160a01b031614611a815760405162461bcd60e51b8152600401610de990615a7d565b6110208161341d565b334114611aaa576040516309f358fd60e01b815260040160405180910390fd5b6000611ab533611fdc565b8015611ac75750611ac53361351f565b155b8015611ae15750611adf33611ada610cc1565b613246565b155b606d54604051630634f5b960e01b815282151560048201526001602482015291925060009182916001600160a01b031690630634f5b9906044016060604051808303816000875af1158015611b3a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611b5e9190615b10565b92509250508060e26000828254611b759190615a6a565b90915550839050611bc7573460e46000828254611b929190615a6a565b90915550506040513390600080516020615f8683398151915290611bba903490600190615b47565b60405180910390a2505050565b336001600160a01b03167f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b13484604051611c02929190615b6b565b60405180910390a26000611c14610cc1565b90506000611c228434615a6a565b3360009081526038602090815260408083208684529091528120549192509060ff1615611d1b576070546040805163631c8fd160e11b815290516000926001600160a01b03169163c6391fa29160048083019260809291908290030181865afa158015611c93573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611cb79190615b79565b93505050506127108184611ccb9190615baf565b611cd59190615bdc565b91508160e46000828254611ce99190615a6a565b90915550506040513390600080516020615f8683398151915290611d11908590600290615b47565b60405180910390a2505b611d258183615a57565b60715460408051632298690160e11b8152815193955060009384936001600160a01b031692634530d20292600480820193918290030181865afa158015611d70573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d949190615bf0565b3360009081526075602052604081206004015492945090925090611dc290611dbc908461352b565b8461322f565b90506000612710611dd38784615baf565b611ddd9190615bdc565b33600090815260e06020526040812080549293508392909190611e01908490615a6a565b9091555060009050611e138288615a57565b33600090815260e16020526040812080549293508392909190611e37908490615a6a565b90915550505050505050505050505050565b6073546060906001600160401b03811115611e6657611e666156f4565b604051908082528060200260200182016040528015611e9f57816020015b611e8c6153e8565b815260200190600190039081611e845790505b50905060005b8151811015611f75576075600060738381548110611ec557611ec5615a12565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c08201528251839083908110611f5757611f57615a12565b60200260200101819052508080611f6d90615a3e565b915050611ea5565b5090565b6000805b60aa54811015611f7557600081815260ab6020526040902054611fa8906001600160a01b0316611169565b15611fbb5781611fb781615a3e565b9250505b80611fc581615a3e565b915050611f7d565b6070546001600160a01b031690565b6001600160a01b038116600090815260ac6020526040812054610cbb9060019060ff16600381111561119d5761119d61594e565b6120186130cb565b6001600160a01b0316336001600160a01b0316146120485760405162461bcd60e51b8152600401610de990615a7d565b611020816134aa565b334114612071576040516309f358fd60e01b815260040160405180910390fd5b61207a436122b1565b61209757604051636c74eecf60e01b815260040160405180910390fd5b6120a04361257e565b6120ab60025461257e565b106120c957604051632458f64160e01b815260040160405180910390fd5b4360025560006120d8426131b5565b905060006120e7826003541090565b905060006120f3612992565b50509050606060006121044361257e565b90506000612113826001615a6a565b9050600061211f610cc1565b9050851561224b57612131818661353a565b60008061213e83886138c5565b9150915061214e83888484613af7565b612156613c00565b61215e613d5b565b607054604051631da0214360e21b81526001600160a01b0390911690637680850c90612190908a908790600401615c14565b600060405180830381600087803b1580156121aa57600080fd5b505af11580156121be573d6000803e3d6000fd5b505050506121cb89613e7d565b805191985096501561223a576070546040516303e1697b60e11b81526001600160a01b03909116906307c2d2f69061220790899060040161583f565b600060405180830381600087803b15801561222157600080fd5b505af1158015612235573d6000803e3d6000fd5b505050505b612245436001615a6a565b60045550505b612256878387614008565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce78860405161228b911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b6000600180546122c19190615a57565b6001546122ce9084615c36565b1492915050565b6122dd6130cb565b6001600160a01b0316336001600160a01b03161461230d5760405162461bcd60e51b8152600401610de990615a7d565b611020816133e8565b600080612321610cc1565b90506111628382613246565b600080600061233c8443610f5c565b9250925092509193909250565b606060aa546001600160401b03811115612365576123656156f4565b60405190808252806020026020018201604052801561238e578160200160208202803683370190505b5090506000805b825181101561194757600081815260ab60205260409020546123bf906001600160a01b0316611169565b1561242357600081815260ab60205260409020546123e5906001600160a01b0316613514565b83836123f081615a3e565b94508151811061240257612402615a12565b60200260200101906001600160a01b031690816001600160a01b0316815250505b8061242d81615a3e565b915050612395565b61243d6130cb565b6001600160a01b0316336001600160a01b03161461246d5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361249857604051637bcd509160e01b815260040160405180910390fd5b61102081613352565b6124a96130cb565b6001600160a01b0316336001600160a01b0316146124d95760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361250457604051637bcd509160e01b815260040160405180910390fd5b61102081613271565b6000805b60aa54811015611f7557600081815260ab602052604090205461253c906001600160a01b0316611fdc565b1561254f578161254b81615a3e565b9250505b8061255981615a3e565b915050612511565b6001600160a01b0316600090815260746020526040902054151590565b6000610cbb826143d8565b3361259261307f565b6001600160a01b0316146125b957604051638aaf4a0760e01b815260040160405180910390fd5b6001600160a01b038216600090815260e8602052604090206001810154156125f45760405163057aab3160e31b815260040160405180910390fd5b60006126008342615a6a565b6001600160a01b038516600090815260756020526040902090915061262590826143f3565b6001600160a01b0384166000908152603b6020908152604080832084905560399091528120600191612655610cc1565b8152602081019190915260409081016000908120805460ff19169315159390931790925560715460e554915163138ac02f60e11b81526001600160a01b0390911691632715805e916126ab918991600401615abf565b6020604051808303816000875af11580156126ca573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906126ee9190615ad8565b905080156127eb57600060e654426127069190615a6a565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038a16179055838655850181905590506127646130cb565b6001600160a01b0387811660008181526075602052604090819020600201549051630a2fae5760e41b81526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b1580156127d157600080fd5b505af11580156127e5573d6000803e3d6000fd5b50505050505b846001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c48260405161282691815260200190565b60405180910390a25050505050565b61283d6130cb565b6001600160a01b0316336001600160a01b03161461286d5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361289857604051637bcd509160e01b815260040160405180910390fd5b611020816132bc565b6000805b60aa548110156117b457600081815260ab60205260409020546001600160a01b03808516916128d49116613514565b6001600160a01b03161480156129065750600081815260ab6020526040902054612906906001600160a01b0316611169565b1561291457600191506117b4565b8061291e81615a3e565b9150506128a5565b61292e6130cb565b6001600160a01b0316336001600160a01b03161461295e5760405162461bcd60e51b8152600401610de990615a7d565b806001600160a01b03163b60000361298957604051637bcd509160e01b815260040160405180910390fd5b6110208161339d565b606080606060aa546001600160401b038111156129b1576129b16156f4565b6040519080825280602002602001820160405280156129da578160200160208202803683370190505b50925060aa546001600160401b038111156129f7576129f76156f4565b604051908082528060200260200182016040528015612a20578160200160208202803683370190505b50915060aa546001600160401b03811115612a3d57612a3d6156f4565b604051908082528060200260200182016040528015612a66578160200160208202803683370190505b50905060005b8351811015612b6a57600081815260ab602052604090205484516001600160a01b03909116908190869084908110612aa657612aa6615a12565b60200260200101906001600160a01b031690816001600160a01b031681525050612acf81613514565b848381518110612ae157612ae1615a12565b6001600160a01b03928316602091820292909201810191909152908216600090815260ac9091526040902054835160ff90911690849084908110612b2757612b27615a12565b60200260200101906003811115612b4057612b4061594e565b90816003811115612b5357612b5361594e565b905250819050612b6281615a3e565b915050612a6c565b50909192565b60606073805480602002602001604051908101604052809291908181526020018280548015612bc857602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311612baa575b5050505050905090565b612bda6130cb565b6001600160a01b0316336001600160a01b031614612c0a5760405162461bcd60e51b8152600401610de990615a7d565b6001600160a01b038216600090815260e8602052604090206001015415612e515760e7548060005b82811015612c8b57846001600160a01b031660e78281548110612c5757612c57615a12565b6000918252602090912001546001600160a01b031603612c7957809150612c8b565b80612c8381615a3e565b915050612c32565b50818103612c995750505050565b6001600160a01b038416600090815260e860205260409020548015612e4d576001600160a01b038516600090815260e860205260408120818155600190810191909155831115612d5b5760e7612cf0600185615a57565b81548110612d0057612d00615a12565b60009182526020909120015460e780546001600160a01b039092169184908110612d2c57612d2c615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480612d6c57612d6c615c4a565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff19166001179055612dbe84826104b061446f565b15612e0857836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e48360405161154e91815260200190565b836001600160a01b0316856001600160a01b03167f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a1834760405161154e929190615b6b565b5050505b5050565b612e5d6130cb565b6001600160a01b0316336001600160a01b031614612e8d5760405162461bcd60e51b8152600401610de990615a7d565b61102081613452565b60006111628383613157565b33612eab61307f565b6001600160a01b031614612ed257604051638aaf4a0760e01b815260040160405180910390fd5b612edb826144cf565b15612ef95760405163030081e760e01b815260040160405180910390fd5b6001600160a01b0382166000908152607560205260409020600581015415612f345760405163fab9167360e01b815260040160405180910390fd5b612f4781612f428442615a6a565b6143f3565b505050565b33612f5561307f565b6001600160a01b031614612f7c57604051638aaf4a0760e01b815260040160405180910390fd5b6001600160a01b03831660009081526077602052604090205415612fb357604051632f32dcdd60e11b815260040160405180910390fd5b612710811115612fd657604051631b8454a360e21b815260040160405180910390fd5b607654821015612ff95760405163fa0ae69360e01b815260040160405180910390fd5b6001600160a01b03831660009081526077602052604081209062015180846130218242615bdc565b61302b9190615a6a565b6130359190615baf565b808355600183018490556040519091506001600160a01b038616907f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f21906128269084908790615b6b565b6071546001600160a01b031690565b6001600160a01b038116600090815260ac60205260408120546130c49060ff1660038111156130bf576130bf61594e565b61454c565b1592915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b600181101561311b576040516317b8970f60e01b815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a25267906020015b60405180910390a150565b6001600160a01b03919091166000908152603960209081526040808320938352929052205460ff1690565b60008160038111156131965761319661594e565b8360038111156131a8576131a861594e565b1660ff1615159392505050565b6000610cbb6201518083615bdc565b6001600160a01b03919091166000908152603a6020526040902054101590565b607080546001600160a01b0319166001600160a01b0383161790556040517faa5b07dd43aa44c69b70a6a2b9c3fcfed12b6e5f6323596ba7ac91035ab80a4f9061314c908390615609565b60008183101561323f5781611162565b5090919050565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b607180546001600160a01b0319166001600160a01b0383161790556040517f6397f5b135542bb3f477cb346cfab5abdec1251d08dc8f8d4efb4ffe122ea0bf9061314c908390615609565b606d80546001600160a01b0319166001600160a01b0383161790556040517fc328090a37d855191ab58469296f98f87a851ca57d5cdfd1e9ac3c83e9e7096d9061314c908390615609565b606f80546001600160a01b0319166001600160a01b0383161790556040517f31a33f126a5bae3c5bdf6cfc2cd6dcfffe2fe9634bdb09e21c44762993889e3b9061314c908390615609565b606e80546001600160a01b0319166001600160a01b0383161790556040517f034c8da497df28467c79ddadbba1cc3cdd41f510ea73faae271e6f16a61116219061314c908390615609565b60a880546001600160a01b0319166001600160a01b0383161790556040517ffd6f5f93d69a07c593a09be0b208bff13ab4ffd6017df3b33433d63bdc59b4d79061314c908390615609565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b59060200161314c565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab49060200161314c565b60a954811115613475576040516355408ce960e11b815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e9060200161314c565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a9060200161314c565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b9060200161314c565b6000610cbb8261456a565b6000610cbb82436131c4565b600081831061323f5781611162565b606e5460405163889998ef60e01b8152600481018490526000916001600160a01b03169063889998ef90602401602060405180830381865afa158015613584573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906135a89190615ad8565b606e5460405163033cdc2b60e31b8152600481018690529192506000916001600160a01b03909116906319e6e15890602401602060405180830381865afa1580156135f7573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061361b9190615ad8565b606e549091506000906001600160a01b031663f67e81528661363c87611703565b6040518363ffffffff1660e01b8152600401613659929190615c60565b600060405180830381865afa158015613676573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261369e9190810190615c81565b90506136ab83838361458f565b15806136b5575081155b156137325760005b845181101561372a57845160e2546136d59190615bdc565b60e360008784815181106136eb576136eb615a12565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002081905550808061372290615a3e565b9150506136bd565b505050505050565b600080600080607060009054906101000a90046001600160a01b03166001600160a01b0316631079402a6040518163ffffffff1660e01b8152600401608060405180830381865afa15801561378b573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906137af9190615b79565b9296509094509250905080861160005b89518110156138b857888782815181106137db576137db615a12565b602002602001015160e2546137f09190615baf565b6137fa9190615bdc565b60e360008c848151811061381057613810615a12565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020016000208190555081156138a6576138a68b8b838151811061385857613858615a12565b60200260200101518a6127108b868151811061387657613876615a12565b60200260200101516138889190615baf565b6138929190615bdc565b61389e90612710615a57565b878a8a614648565b806138b081615a3e565b9150506137bf565b5050505050505050505050565b6000606060008084516001600160401b038111156138e5576138e56156f4565b60405190808252806020026020018201604052801561390e578160200160208202803683370190505b50925060005b8551811015613ae75785818151811061392f5761392f615a12565b6020908102919091018101516001600160a01b03808216600090815260759093526040909220600201549094501691506139698388613157565b61399c576001600160a01b0380841660009081526075602052604090206003015461399791859116846148a8565b6139ce565b6001600160a01b038316600090815260e3602052604081205460e48054919290916139c8908490615a6a565b90915550505b6139d78361351f565b1580156139eb57506139e98388613246565b155b15613a5f576001600160a01b038316600090815260e16020526040902054613a139086615a6a565b6001600160a01b038416600090815260e16020526040902054855191965090859083908110613a4457613a44615a12565b602002602001018181525050613a5a8383614985565b613aa5565b6001600160a01b038316600090815260e1602090815260408083205460e090925290912054613a8e9190615a6a565b60e46000828254613a9f9190615a6a565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e390915281205580613adf81615a3e565b915050613914565b5060e26000905550509250929050565b6071546001600160a01b03168215612e4d57613b138184614a4d565b15613bbb5760405163566bce2360e11b81526001600160a01b0382169063acd79c4690613b4890879086908a90600401615d36565b600060405180830381600087803b158015613b6257600080fd5b505af1158015613b76573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d087838584604051613bad93929190615d6c565b60405180910390a150613bfa565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f8983858447604051613bf09493929190615da1565b60405180910390a1505b50505050565b60e754600080805b83831015613bfa5760e78381548110613c2357613c23615a12565b60009182526020808320909101546001600160a01b031680835260e89091526040909120600181015491935091504210613d4957805460e48054600090613c6b908490615a6a565b90915550506001600160a01b038216600090815260e860205260408120818155600101819055613c9a85615dde565b9450841115613d115760e78481548110613cb657613cb6615a12565b60009182526020909120015460e780546001600160a01b039092169185908110613ce257613ce2615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480613d2257613d22615c4a565b600082815260209020810160001990810180546001600160a01b0319169055019055613c08565b82613d5381615a3e565b935050613c08565b60e4548015611020576000613d6e611569565b600060e481905560408051600481526024810182526020810180516001600160e01b03166359f778df60e01b179052905192935090916001600160a01b038416918591613dbb9190615df5565b60006040518083038185875af1925050503d8060008114613df8576040519150601f19603f3d011682016040523d82523d6000602084013e613dfd565b606091505b505090508015613e4257816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051611bba91815260200190565b816001600160a01b03167fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b738447604051611bba929190615b6b565b606080613e8983614aa9565b6071546040516391f8723f60e01b81529192506000916001600160a01b03909116906391f8723f90613ec090607390600401615e24565b600060405180830381865afa158015613edd573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613f059190810190615c81565b60a854604051632907e73160e11b81529192506000916001600160a01b039091169063520fce6290613f3c90607390600401615e24565b600060405180830381865afa158015613f59573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613f819190810190615c81565b90506000613ff06073805480602002602001604051908101604052809291908181526020018280548015613fde57602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311613fc0575b5050505050848460a95460ad54614f9c565b9095509050614000858288615066565b505050915091565b606f546000906001600160a01b031663fdadda8183614028436001615a6a565b6040518363ffffffff1660e01b8152600401614045929190615c14565b600060405180830381865afa158015614062573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261408a9190810190615e68565b905060005b82518110156143515760008382815181106140ac576140ac615a12565b6020908102919091018101516001600160a01b0381166000908152603b9092526040822054909250421115906140e183611fdc565b905060006140f9846140f4436001615a6a565b6131c4565b8061411a575085858151811061411157614111615a12565b60200260200101515b806141225750825b159050811580156141305750805b156141ab576001600160a01b038416600090815260ac602052604090205461416f9060019060ff1660038111156141695761416961594e565b906151c4565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156141a1576141a161594e565b021790555061422d565b8180156141b6575080155b1561422d576001600160a01b038416600090815260ac60205260409020546141f59060019060ff1660038111156141ef576141ef61594e565b906151ff565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156142275761422761594e565b02179055505b600061423885611169565b90508315811580156142475750805b156142bc576001600160a01b038616600090815260ac60205260409020546142809060029060ff1660038111156141695761416961594e565b6001600160a01b038716600090815260ac60205260409020805460ff191660018360038111156142b2576142b261594e565b0217905550614338565b8180156142c7575080155b15614338576001600160a01b038616600090815260ac60205260409020546143009060029060ff1660038111156141ef576141ef61594e565b6001600160a01b038716600090815260ac60205260409020805460ff191660018360038111156143325761433261594e565b02179055505b505050505050808061434990615a3e565b91505061408f565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b8261437d611864565b60405161438a919061583f565b60405180910390a382847f773d1888df530d69716b183a92450d45f97fba49f2a4bb34fae3b23da0e2cc6f6143bd612349565b6040516143ca919061583f565b60405180910390a350505050565b6000600154826143e89190615bdc565b610cbb906001615a6a565b600182015461440a906001600160a01b0316612561565b6144275760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e790602001611133565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146144bf576040519150601f19603f3d011682016040523d82523d6000602084013e6144c4565b606091505b509095945050505050565b60a85460405163107fbb4760e21b815260009182916001600160a01b03909116906341feed1c90614504908690600401615609565b602060405180830381865afa158015614521573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906145459190615ad8565b1192915050565b60008160038111156145605761456061594e565b60ff161592915050565b6001600160a01b03808216600090815260756020526040812060030154909116610cbb565b60016000805b835181101561460157848482815181106145b1576145b1615a12565b602002602001015111156145c85760009250614601565b8381815181106145da576145da615a12565b6020026020010151826145ed9190615a6a565b9150806145f981615a3e565b915050614595565b5081801561460f5750848111155b915081614640576040517f64ba7143ea5a17abea37667aa9ae137e3afba5033c5f504770c02829c128189c90600090a15b509392505050565b8084106147c4576001600160a01b03851660008181526039602090815260408083208a845282528083208054600160ff199182168117909255948452603783528184208b855290925282208054909316179091556146a6438561523b565b6001600160a01b0387166000908152603a60205260409020549091506146cd90829061322f565b6001600160a01b0387166000908152603a6020908152604080832093909355603c905220546146fd90829061322f565b6001600160a01b038088166000908152603c60205260409081902092909255607054915163c008ce3960e01b815291169063c008ce39906147479089906002908c90600401615ef6565b600060405180830381600087803b15801561476157600080fd5b505af1158015614775573d6000803e3d6000fd5b5050506001600160a01b0387166000818152603a60205260408082205490518b9450600080516020615fa6833981519152926147b692916001908190615af1565b60405180910390a35061372a565b81841061372a576001600160a01b0380861660009081526039602090815260408083208a845290915290819020805460ff19166001908117909155607054915163c008ce3960e01b8152919092169163c008ce39916148299189918b90600401615ef6565b600060405180830381600087803b15801561484357600080fd5b505af1158015614857573d6000803e3d6000fd5b5050506001600160a01b0386166000818152603a60205260408082205490518a9450600080516020615fa68339815191529261489892918190600190615af1565b60405180910390a3505050505050565b6001600160a01b038316600090815260e360205260409020548015613bfa576148d482826104b061446f565b1561493657816001600160a01b0316836001600160a01b0316856001600160a01b03167f72a57dc38837a1cba7881b7b1a5594d9e6b65cec6a985b54e2cee3e89369691c8460405161492891815260200190565b60405180910390a450505050565b816001600160a01b0316836001600160a01b0316856001600160a01b03167fd35d76d87d51ed89407fc7ceaaccf32cf72784b94530892ce33546540e141b728447604051614928929190615b6b565b6001600160a01b038216600090815260e060205260409020548015612f47576149b182826104b061446f565b15614a0857816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec836040516149fb91815260200190565b60405180910390a3505050565b816001600160a01b0316836001600160a01b03167f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e83476040516149fb929190615b6b565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114614a9a576040519150601f19603f3d011682016040523d82523d6000602084013e614a9f565b606091505b5090949350505050565b6071546040805163af24542960e01b815290516060926001600160a01b031691600091839163af2454299160048083019260209291908290030181865afa158015614af8573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190614b1c9190615ad8565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015614b5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190614b829190615ad8565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b8152600401614bb39190615e24565b600060405180830381865afa158015614bd0573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052614bf89190810190615c81565b6073549091506000816001600160401b03811115614c1857614c186156f4565b604051908082528060200260200182016040528015614c41578160200160208202803683370190505b50965060008060005b84831015614eed5760738381548110614c6557614c65615a12565b60009182526020808320909101546001600160a01b031680835260759091526040909120600681015488519294509092501515908890889086908110614cad57614cad615a12565b60200260200101511015614d095780614d04576000614ccc8a42615a6a565b600684018190556040518181529091506001600160a01b03851690600080516020615f668339815191529060200160405180910390a2505b614d4a565b8015614d4a578160060160009055826001600160a01b0316600080516020615f668339815191526000604051614d4191815260200190565b60405180910390a25b60008260050154600014158015614d65575042836005015411155b80614d8857506001600160a01b038416600090815260e9602052604090205460ff165b905060008360060154600014158015614da5575042846006015411155b90508180614db05750805b15614e465788614dbf89615dde565b98508881518110614dd257614dd2615a12565b6020026020010151898781518110614dec57614dec615a12565b6020908102919091010152848d88614e0381615a3e565b995081518110614e1557614e15615a12565b60200260200101906001600160a01b031690816001600160a01b031681525050614e3e85615256565b505050614c4a565b6001600160a01b0385166000908152607760205260409020548015801590614e6e5750428111155b15614ed7576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b86614ee181615a3e565b97505050505050614c4a565b5050508087528015614f91577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c9187604051614f28919061583f565b60405180910390a160405163e22d1c9d60e01b81526001600160a01b0387169063e22d1c9d90614f5e908a908c90600401615c14565b600060405180830381600087803b158015614f7857600080fd5b505af1158015614f8c573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401614fc0959493929190615f17565b60408051601f19818403018152919052602080820180516001600160e01b0316633bca0a8960e11b17905281518b51929350600192909160009161500391615baf565b61500e906040615a6a565b90506020840181888483895afa61502457600093505b503d61502f57600092505b6020870196508261505357604051630fc2632160e01b815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa548110156150c457600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b0319169055806150bc81615a3e565b915050615068565b5060005b8281101561510e57600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff191690558061510681615a3e565b9150506150c8565b5060005b8281101561518c57600084828151811061512e5761512e615a12565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b0319169091179055508061518481615a3e565b915050615112565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051611bba919061583f565b60008160038111156151d8576151d861594e565b8360038111156151ea576151ea61594e565b1760ff1660038111156111625761116261594e565b60008160038111156152135761521361594e565b198360038111156152265761522661594e565b1660ff1660038111156111625761116261594e565b60008160000361524c576000611162565b6111628284615a6a565b6001600160a01b038116600090815260e960209081526040808320805460ff19169055607490915281205461102091839190819003615293575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b03199081168255600180830180548316905560028301805483169055600383018054909216909155600482018590556005820185905560069091018490556074835281842084905560779092528220828155810182905560738054909161531d91615a57565b8154811061532d5761532d615a12565b6000918252602090912001546001600160a01b039081169150831681146153b0576001600160a01b038116600090815260746020526040902082905560738054829190841990811061538157615381615a12565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60738054806153c1576153c1615c4a565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6040805160e081018252600080825260208201819052918101829052606081018290526080810182905260a0810182905260c081019190915290565b6001600160a01b038116811461102057600080fd5b6000806040838503121561544c57600080fd5b823561545781615424565b9150602083013561546781615424565b809150509250929050565b600080600080600060a0868803121561548a57600080fd5b853561549581615424565b945060208601356154a581615424565b935060408601356154b581615424565b925060608601356154c581615424565b949793965091946080013592915050565b600080604083850312156154e957600080fd5b82356154f481615424565b946020939093013593505050565b60006020828403121561551457600080fd5b5035919050565b60006020828403121561552d57600080fd5b813561116281615424565b60018060a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b60e08101610cbb8284615538565b815181526020808301519082015260408101610cbb565b801515811461102057600080fd5b600080600080608085870312156155d557600080fd5b84356155e081615424565b9350602085013592506040850135915060608501356155fe816155b1565b939692955090935050565b6001600160a01b0391909116815260200190565b8060408101831015610cbb57600080fd5b6000806000806000806000806000806000806101a08d8f03121561565157600080fd5b8c3561565c81615424565b9b5060208d013561566c81615424565b9a5060408d013561567c81615424565b995060608d013561568c81615424565b985060808d013561569c81615424565b975060a08d01356156ac81615424565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d013591506156e28e6101608f0161561d565b90509295989b509295989b509295989b565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f191681016001600160401b0381118282101715615732576157326156f4565b604052919050565b60006001600160401b03821115615753576157536156f4565b5060051b60200190565b6000602080838503121561577057600080fd5b82356001600160401b0381111561578657600080fd5b8301601f8101851361579757600080fd5b80356157aa6157a58261573a565b61570a565b81815260059190911b820183019083810190878311156157c957600080fd5b928401925b828410156157f05783356157e181615424565b825292840192908401906157ce565b979650505050505050565b600081518084526020808501945080840160005b838110156158345781516001600160a01b03168752958201959082019060010161580f565b509495945050505050565b60208152600061116260208301846157fb565b6000806020838503121561586557600080fd5b82356001600160401b038082111561587c57600080fd5b818501915085601f83011261589057600080fd5b81358181111561589f57600080fd5b8660208260051b85010111156158b457600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b818110156159005783511515835292840192918401916001016158e2565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b818110156159005761593b838551615538565b9284019260e09290920191600101615928565b634e487b7160e01b600052602160045260246000fd5b60608152600061597760608301866157fb565b60208382038185015261598a82876157fb565b8481036040860152855180825282870193509082019060005b818110156159cf578451600481106159bd576159bd61594e565b835293830193918301916001016159a3565b509098975050505050505050565b6000806000606084860312156159f257600080fd5b83356159fd81615424565b95602085013595506040909401359392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201615a5057615a50615a28565b5060010190565b81810381811115610cbb57610cbb615a28565b80820180821115610cbb57610cbb615a28565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b6001600160a01b03929092168252602082015260400190565b600060208284031215615aea57600080fd5b5051919050565b9384526020840192909252151560408301521515606082015260800190565b600080600060608486031215615b2557600080fd5b8351615b30816155b1565b602085015160409095015190969495509392505050565b8281526040810160038310615b5e57615b5e61594e565b8260208301529392505050565b918252602082015260400190565b60008060008060808587031215615b8f57600080fd5b505082516020840151604085015160609095015191969095509092509050565b8082028115828204841417610cbb57610cbb615a28565b634e487b7160e01b600052601260045260246000fd5b600082615beb57615beb615bc6565b500490565b60008060408385031215615c0357600080fd5b505080516020909101519092909150565b604081526000615c2760408301856157fb565b90508260208301529392505050565b600082615c4557615c45615bc6565b500690565b634e487b7160e01b600052603160045260246000fd5b828152604060208201526000615c7960408301846157fb565b949350505050565b60006020808385031215615c9457600080fd5b82516001600160401b03811115615caa57600080fd5b8301601f81018513615cbb57600080fd5b8051615cc96157a58261573a565b81815260059190911b82018301908381019087831115615ce857600080fd5b928401925b828410156157f057835182529284019290840190615ced565b600081518084526020808501945080840160005b8381101561583457815187529582019590820190600101615d1a565b606081526000615d4960608301866157fb565b8281036020840152615d5b8186615d06565b915050826040830152949350505050565b838152606060208201526000615d8560608301856157fb565b8281036040840152615d978185615d06565b9695505050505050565b848152608060208201526000615dba60808301866157fb565b8281036040840152615dcc8186615d06565b91505082606083015295945050505050565b600081615ded57615ded615a28565b506000190190565b6000825160005b81811015615e165760208186018101518583015201615dfc565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b818110156159005783546001600160a01b031683526001938401939285019201615e43565b60006020808385031215615e7b57600080fd5b82516001600160401b03811115615e9157600080fd5b8301601f81018513615ea257600080fd5b8051615eb06157a58261573a565b81815260059190911b82018301908381019087831115615ecf57600080fd5b928401925b828410156157f0578351615ee7816155b1565b82529284019290840190615ed4565b6001600160a01b039390931683526020830191909152604082015260600190565b60a081526000615f2a60a08301886157fb565b8281036020840152615f3c8188615d06565b90508281036040840152615f508187615d06565b6060840195909552505060800152939250505056fe88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342754042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68aa2646970667358221220a1eb2c9a0a4cbc889fd4810519c15ef9865e041ad7aa23ef79fce6ce5a27a4c564736f6c63430008110033", - "devdoc": { - "errors": { - "ErrAlreadyRequestedEmergencyExit()": [ - { - "details": "Error of already requested emergency exit before." - } - ], - "ErrAlreadyRequestedRevokingCandidate()": [ - { - "details": "Error of already requested revoking candidate before." - } - ], - "ErrAlreadyRequestedUpdatingCommissionRate()": [ - { - "details": "Error of commission change schedule exists." - } - ], - "ErrAlreadyWrappedEpoch()": [ - { - "details": "Error of query for already wrapped up epoch" - } - ], - "ErrAtEndOfEpochOnly()": [ - { - "details": "Error of only allowed at the end of epoch" - } - ], - "ErrCallPrecompiled()": [ - { - "details": "Error of call to precompile fails." - } - ], - "ErrCallerMustBeBridgeTrackingContract()": [ - { - "details": "Error of method caller must be bridge tracking contract." - } - ], - "ErrCallerMustBeCoinbase()": [ - { - "details": "Error of method caller must be coinbase" - } - ], - "ErrCallerMustBeMaintenanceContract()": [ - { - "details": "Error of method caller must be maintenance contract." - } - ], - "ErrCallerMustBeRoninTrustedOrgContract()": [ - { - "details": "Error of method caller must be Ronin trusted org contract." - } - ], - "ErrCallerMustBeSlashIndicatorContract()": [ - { - "details": "Error of method caller must be slash indicator contract." - } - ], - "ErrCallerMustBeStakingContract()": [ - { - "details": "Error of method caller must be staking contract." - } - ], - "ErrCallerMustBeStakingVestingContract()": [ - { - "details": "Error of method caller must be staking vesting contract." - } - ], - "ErrCannotBailout(address)": [ - { - "details": "Error of cannot bailout due to high tier slash." - } - ], - "ErrExceedsMaxNumberOfCandidate()": [ - { - "details": "Error of exceeding maximum number of candidates." - } - ], - "ErrExistentBridgeOperator(address)": [ - { - "details": "Error of bridge operator already exists." - } - ], - "ErrExistentCandidate()": [ - { - "details": "Error of querying for already existent candidate." - } - ], - "ErrExistentCandidateAdmin(address)": [ - { - "details": "Error of candidate admin already exists." - } - ], - "ErrExistentTreasury(address)": [ - { - "details": "Error of treasury already exists." - } - ], - "ErrInsufficientBalance()": [ - { - "details": "Error of sender has insufficient balance." - } - ], - "ErrInvalidCommissionRate()": [ - { - "details": "Error of invalid commission rate." - } - ], - "ErrInvalidEffectiveDaysOnwards()": [ - { - "details": "Error of invalid effective days onwards." - } - ], - "ErrInvalidMaxPrioritizedValidatorNumber()": [ - { - "details": "Error of number of prioritized greater than number of max validators." - } - ], - "ErrInvalidMinEffectiveDaysOnwards()": [ - { - "details": "Error of invalid min effective days onwards." - } - ], - "ErrNonExistentCandidate()": [ - { - "details": "Error of querying for non-existent candidate." - } - ], - "ErrRecipientRevert()": [ - { - "details": "Error of recipient not accepting RON when transfer RON." - } - ], - "ErrTrustedOrgCannotRenounce()": [ - { - "details": "Error of trusted org cannot renounce." - } - ], - "ErrUnauthorizedReceiveRON()": [ - { - "details": "Error thrown when receives RON from neither staking vesting contract nor staking contract" - } - ], - "ErrZeroCodeContract()": [ - { - "details": "Error of set to non-contract." - } - ], - "NonExistentRecyclingInfo()": [ - { - "details": "Error thrown when queries for a non existent info." - } - ] - }, - "kind": "dev", - "methods": { - "bridgeTrackingContract()": { - "details": "Returns the bridge tracking contract." - }, - "checkBridgeRewardDeprecatedAtLatestPeriod(address)": { - "details": "Because the information of deprecating bridge reward of a period is only determined at the end of that period, this method will return the deprecating info of the latest period. A method for querying that info of current period is no need." - }, - "checkBridgeRewardDeprecatedAtPeriod(address,uint256)": { - "details": "Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`." - }, - "checkJailed(address)": { - "details": "Returns whether the validator are put in jail (cannot join the set of validators) during the current period." - }, - "checkJailedAtBlock(address,uint256)": { - "details": "Returns whether the validator are put in jail (cannot join the set of validators) at a specific block." - }, - "checkManyJailed(address[])": { - "details": "Returns whether the validators are put in jail (cannot join the set of validators) during the current period." - }, - "checkMiningRewardDeprecated(address)": { - "details": "Returns whether the incoming reward of the block producer is deprecated during the current period." - }, - "checkMiningRewardDeprecatedAtPeriod(address,uint256)": { - "details": "Returns whether the incoming reward of the block producer is deprecated during a specific period." - }, - "currentPeriod()": { - "details": "Returns the period index from the current block." - }, - "currentPeriodStartAtBlock()": { - "details": "Returns the block number that the current period starts at." - }, - "emergencyExitLockedAmount()": { - "details": "Returns the amount of RON to lock from a consensus address." - }, - "emergencyExpiryDuration()": { - "details": "Returns the duration that an emergency request is expired and the fund will be recycled." - }, - "epochEndingAt(uint256)": { - "details": "Returns whether the epoch ending is at the block number `_block`." - }, - "epochOf(uint256)": { - "details": "Returns the epoch index from the block number." - }, - "execApplyValidatorCandidate(address,address,address,address,uint256)": { - "details": "Grants a validator candidate. Requirements: - The method caller is staking contract. Emits the event `CandidateGranted`." - }, - "execBailOut(address,uint256)": { - "details": "Finalize the bailout request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorUnjailed`." - }, - "execEmergencyExit(address,uint256)": { - "details": "Fallback function of `IStaking-requestEmergencyExit`. Requirements: - The method caller is staking contract." - }, - "execReleaseLockedFundForEmergencyExitRequest(address,address)": { - "details": "Unlocks fund for emergency exit request. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked. Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock." - }, - "execRequestRenounceCandidate(address,uint256)": { - "details": "Requests to revoke a validator candidate in next `_secsLeft` seconds. Requirements: - The method caller is staking contract. Emits the event `CandidateRevokingTimestampUpdated`." - }, - "execRequestUpdateCommissionRate(address,uint256,uint256)": { - "details": "Fallback function of `CandidateStaking-requestUpdateCommissionRate`. Requirements: - The method caller is the staking contract. - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards - The `_rate` must be in range of [0_00; 100_00]. Emits the event `CommissionRateUpdateScheduled`." - }, - "execSlash(address,uint256,uint256,bool)": { - "details": "Finalize the slash request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorPunished`." - }, - "getBlockProducers()": { - "details": "Returns the current block producer list." - }, - "getBridgeOperators()": { - "details": "Returns the current bridge operator list." - }, - "getBridgeOperatorsOf(address[])": { - "details": "Returns the bridge operator list corresponding to validator address list." - }, - "getCandidateInfo(address)": { - "details": "Returns the info of a candidate." - }, - "getCandidateInfos()": { - "details": "Returns all candidate info." - }, - "getCommissionChangeSchedule(address)": { - "details": "Returns the schedule of changing commission rate of a candidate address." - }, - "getEmergencyExitInfo(address)": { - "details": "Returns the emergency exit request." - }, - "getJailedTimeLeft(address)": { - "details": "Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail." - }, - "getJailedTimeLeftAtBlock(address,uint256)": { - "details": "Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail." - }, - "getLastUpdatedBlock()": { - "details": "Returns the block that validator set was updated." - }, - "getValidatorCandidates()": { - "details": "Returns the validator candidate." - }, - "getValidators()": { - "details": "Returns the current validator list." - }, - "initialize(address,address,address,address,address,address,uint256,uint256,uint256,uint256,uint256,uint256[2])": { - "details": "Initializes the contract storage." - }, - "isBlockProducer(address)": { - "details": "Returns whether the address is block producer or not." - }, - "isBridgeOperator(address)": { - "details": "Returns whether the address is bridge operator." - }, - "isCandidateAdmin(address,address)": { - "details": "Returns whether the address is the candidate admin." - }, - "isOperatingBridge(address)": { - "details": "Returns whether the consensus address is operating the bridge or not." - }, - "isPeriodEnding()": { - "details": "Returns whether the period ending at the current block number." - }, - "isValidator(address)": { - "details": "Returns whether the address is either a bridge operator or a block producer." - }, - "isValidatorCandidate(address)": { - "details": "Returns whether the address is a validator (candidate)." - }, - "maintenanceContract()": { - "details": "Returns the maintenance contract." - }, - "maxPrioritizedValidatorNumber()": { - "details": "Returns the number of reserved slots for prioritized validators." - }, - "maxValidatorCandidate()": { - "details": "Returns the maximum number of validator candidate." - }, - "maxValidatorNumber()": { - "details": "Returns the maximum number of validators in the epoch." - }, - "minEffectiveDaysOnwards()": { - "details": "Returns the minimum number of days to the effective date of commission rate change." - }, - "numberOfBlocksInEpoch()": { - "details": "Returns the number of blocks in a epoch." - }, - "precompilePickValidatorSetAddress()": { - "details": "Gets the address of the precompile of picking validator set" - }, - "precompileSortValidatorsAddress()": { - "details": "Gets the address of the precompile of sorting validators" - }, - "roninTrustedOrganizationContract()": { - "details": "Returns the ronin trusted organization contract." - }, - "setBridgeTrackingContract(address)": { - "details": "Sets the bridge tracking contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `BridgeTrackingContractUpdated`." - }, - "setEmergencyExitLockedAmount(uint256)": { - "details": "Sets the amount of RON to lock from a consensus address. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedAmountUpdated`." - }, - "setEmergencyExpiryDuration(uint256)": { - "details": "Sets the duration that an emergency request is expired and the fund will be recycled. Requirements: - The method caller is admin. Emits the event `EmergencyExpiryDurationUpdated`." - }, - "setMaintenanceContract(address)": { - "details": "Sets the maintenance contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `MaintenanceContractUpdated`." - }, - "setMaxPrioritizedValidatorNumber(uint256)": { - "details": "Updates the number of reserved slots for prioritized validators Requirements: - The method caller is admin Emits the event `MaxPrioritizedValidatorNumberUpdated`" - }, - "setMaxValidatorCandidate(uint256)": { - "details": "Sets the maximum number of validator candidate. Requirements: - The method caller is admin. Emits the `MaxValidatorCandidateUpdated` event." - }, - "setMaxValidatorNumber(uint256)": { - "details": "Updates the max validator number Requirements: - The method caller is admin Emits the event `MaxValidatorNumberUpdated`" - }, - "setMinEffectiveDaysOnwards(uint256)": { - "details": "Sets the minimum number of days to the effective date of commision rate change. Requirements: - The method caller is admin. Emits the `MinEffectiveDaysOnwardsUpdated` event." - }, - "setRoninTrustedOrganizationContract(address)": { - "details": "Sets the ronin trusted organization contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninTrustedOrganizationContractUpdated`." - }, - "setSlashIndicatorContract(address)": { - "details": "Sets the slash indicator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `SlashIndicatorContractUpdated`." - }, - "setStakingContract(address)": { - "details": "Sets the staking contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `StakingContractUpdated`." - }, - "setStakingVestingContract(address)": { - "details": "Sets the staking vesting contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `StakingVestingContractUpdated`." - }, - "slashIndicatorContract()": { - "details": "Returns the slash indicator contract." - }, - "stakingContract()": { - "details": "Returns the staking contract." - }, - "stakingVestingContract()": { - "details": "Returns the staking vesting contract." - }, - "submitBlockReward()": { - "details": "Submits reward of the current block. Requirements: - The method caller is coinbase. Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer. Emits the event `BlockRewardSubmitted` for the valid call." - }, - "totalBlockProducers()": { - "details": "Returns total numbers of the block producers." - }, - "totalBridgeOperators()": { - "details": "Returns total numbers of the bridge operators." - }, - "totalDeprecatedReward()": { - "details": "Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators" - }, - "tryGetPeriodOfEpoch(uint256)": { - "details": "Tries to get the period index from the epoch number." - }, - "wrapUpEpoch()": { - "details": "Wraps up the current epoch. Requirements: - The method must be called when the current epoch is ending. - The epoch is not wrapped yet. - The method caller is coinbase. Emits the event `MiningRewardDistributed` when some validator has reward distributed. Emits the event `StakingRewardDistributed` when some staking pool has reward distributed. Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up. Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending. Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated. Emits the event `WrappedUpEpoch`." - } - }, - "version": 1 - }, - "userdoc": { - "kind": "user", - "methods": {}, - "version": 1 - }, - "storageLayout": { - "storage": [ - { - "astId": 1373, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_initialized", - "offset": 0, - "slot": "0", - "type": "t_uint8" - }, - { - "astId": 1376, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_initializing", - "offset": 1, - "slot": "0", - "type": "t_bool" - }, - { - "astId": 33718, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_numberOfBlocksInEpoch", - "offset": 0, - "slot": "1", - "type": "t_uint256" - }, - { - "astId": 33721, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_lastUpdatedBlock", - "offset": 0, - "slot": "2", - "type": "t_uint256" - }, - { - "astId": 33724, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_lastUpdatedPeriod", - "offset": 0, - "slot": "3", - "type": "t_uint256" - }, - { - "astId": 33727, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_currentPeriodStartAtBlock", - "offset": 0, - "slot": "4", - "type": "t_uint256" - }, - { - "astId": 33732, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_periodOf", - "offset": 0, - "slot": "5", - "type": "t_mapping(t_uint256,t_uint256)" - }, - { - "astId": 33737, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "______gap", - "offset": 0, - "slot": "6", - "type": "t_array(t_uint256)49_storage" - }, - { - "astId": 33364, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_miningRewardDeprecatedAtPeriod", - "offset": 0, - "slot": "55", - "type": "t_mapping(t_address,t_mapping(t_uint256,t_bool))" - }, - { - "astId": 33371, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_miningRewardBailoutCutOffAtPeriod", - "offset": 0, - "slot": "56", - "type": "t_mapping(t_address,t_mapping(t_uint256,t_bool))" - }, - { - "astId": 33378, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_bridgeRewardDeprecatedAtPeriod", - "offset": 0, - "slot": "57", - "type": "t_mapping(t_address,t_mapping(t_uint256,t_bool))" - }, - { - "astId": 33383, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_blockProducerJailedBlock", - "offset": 0, - "slot": "58", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33388, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_emergencyExitJailedTimestamp", - "offset": 0, - "slot": "59", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33393, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_cannotBailoutUntilBlock", - "offset": 0, - "slot": "60", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33398, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "______gap", - "offset": 0, - "slot": "61", - "type": "t_array(t_uint256)48_storage" - }, - { - "astId": 6972, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_stakingVestingContract", - "offset": 0, - "slot": "109", - "type": "t_contract(IStakingVesting)10271" - }, - { - "astId": 6465, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_bridgeTrackingContract", - "offset": 0, - "slot": "110", - "type": "t_contract(IBridgeTracking)9283" - }, - { - "astId": 6544, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_maintenanceContract", - "offset": 0, - "slot": "111", - "type": "t_contract(IMaintenance)9657" - }, - { - "astId": 6814, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_slashIndicatorContract", - "offset": 0, - "slot": "112", - "type": "t_contract(ISlashIndicator)10849" - }, - { - "astId": 6893, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_stakingContract", - "offset": 0, - "slot": "113", - "type": "t_contract(IStaking)11489" - }, - { - "astId": 30114, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_maxValidatorCandidate", - "offset": 0, - "slot": "114", - "type": "t_uint256" - }, - { - "astId": 30118, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_candidates", - "offset": 0, - "slot": "115", - "type": "t_array(t_address)dyn_storage" - }, - { - "astId": 30123, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_candidateIndex", - "offset": 0, - "slot": "116", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 30129, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_candidateInfo", - "offset": 0, - "slot": "117", - "type": "t_mapping(t_address,t_struct(ValidatorCandidate)11506_storage)" - }, - { - "astId": 30132, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_minEffectiveDaysOnwards", - "offset": 0, - "slot": "118", - "type": "t_uint256" - }, - { - "astId": 30138, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_candidateCommissionChangeSchedule", - "offset": 0, - "slot": "119", - "type": "t_mapping(t_address,t_struct(CommissionSchedule)11511_storage)" - }, - { - "astId": 30143, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "______gap", - "offset": 0, - "slot": "120", - "type": "t_array(t_uint256)48_storage" - }, - { - "astId": 6735, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_roninTrustedOrganizationContract", - "offset": 0, - "slot": "168", - "type": "t_contract(IRoninTrustedOrganization)10182" - }, - { - "astId": 33897, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_maxValidatorNumber", - "offset": 0, - "slot": "169", - "type": "t_uint256" - }, - { - "astId": 33900, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "validatorCount", - "offset": 0, - "slot": "170", - "type": "t_uint256" - }, - { - "astId": 33905, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_validators", - "offset": 0, - "slot": "171", - "type": "t_mapping(t_uint256,t_address)" - }, - { - "astId": 33911, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_validatorMap", - "offset": 0, - "slot": "172", - "type": "t_mapping(t_address,t_enum(ValidatorFlag)12618)" - }, - { - "astId": 33914, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_maxPrioritizedValidatorNumber", - "offset": 0, - "slot": "173", - "type": "t_uint256" - }, - { - "astId": 33919, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "______gap", - "offset": 0, - "slot": "174", - "type": "t_array(t_uint256)50_storage" - }, - { - "astId": 33240, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_miningReward", - "offset": 0, - "slot": "224", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33245, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_delegatingReward", - "offset": 0, - "slot": "225", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33248, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_totalBridgeReward", - "offset": 0, - "slot": "226", - "type": "t_uint256" - }, - { - "astId": 33253, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_bridgeOperatingReward", - "offset": 0, - "slot": "227", - "type": "t_mapping(t_address,t_uint256)" - }, - { - "astId": 33256, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_totalDeprecatedReward", - "offset": 0, - "slot": "228", - "type": "t_uint256" - }, - { - "astId": 33259, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_emergencyExitLockedAmount", - "offset": 0, - "slot": "229", - "type": "t_uint256" - }, - { - "astId": 33262, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_emergencyExpiryDuration", - "offset": 0, - "slot": "230", - "type": "t_uint256" - }, - { - "astId": 33266, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_lockedConsensusList", - "offset": 0, - "slot": "231", - "type": "t_array(t_address)dyn_storage" - }, - { - "astId": 33272, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_exitInfo", - "offset": 0, - "slot": "232", - "type": "t_mapping(t_address,t_struct(EmergencyExitInfo)12039_storage)" - }, - { - "astId": 33277, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "_lockedFundReleased", - "offset": 0, - "slot": "233", - "type": "t_mapping(t_address,t_bool)" - }, - { - "astId": 33282, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "______gap", - "offset": 0, - "slot": "234", - "type": "t_array(t_uint256)44_storage" - } - ], - "types": { - "t_address": { - "encoding": "inplace", - "label": "address", - "numberOfBytes": "20" - }, - "t_address_payable": { - "encoding": "inplace", - "label": "address payable", - "numberOfBytes": "20" - }, - "t_array(t_address)dyn_storage": { - "base": "t_address", - "encoding": "dynamic_array", - "label": "address[]", - "numberOfBytes": "32" - }, - "t_array(t_uint256)44_storage": { - "base": "t_uint256", - "encoding": "inplace", - "label": "uint256[44]", - "numberOfBytes": "1408" - }, - "t_array(t_uint256)48_storage": { - "base": "t_uint256", - "encoding": "inplace", - "label": "uint256[48]", - "numberOfBytes": "1536" - }, - "t_array(t_uint256)49_storage": { - "base": "t_uint256", - "encoding": "inplace", - "label": "uint256[49]", - "numberOfBytes": "1568" - }, - "t_array(t_uint256)50_storage": { - "base": "t_uint256", - "encoding": "inplace", - "label": "uint256[50]", - "numberOfBytes": "1600" - }, - "t_bool": { - "encoding": "inplace", - "label": "bool", - "numberOfBytes": "1" - }, - "t_contract(IBridgeTracking)9283": { - "encoding": "inplace", - "label": "contract IBridgeTracking", - "numberOfBytes": "20" - }, - "t_contract(IMaintenance)9657": { - "encoding": "inplace", - "label": "contract IMaintenance", - "numberOfBytes": "20" - }, - "t_contract(IRoninTrustedOrganization)10182": { - "encoding": "inplace", - "label": "contract IRoninTrustedOrganization", - "numberOfBytes": "20" - }, - "t_contract(ISlashIndicator)10849": { - "encoding": "inplace", - "label": "contract ISlashIndicator", - "numberOfBytes": "20" - }, - "t_contract(IStaking)11489": { - "encoding": "inplace", - "label": "contract IStaking", - "numberOfBytes": "20" - }, - "t_contract(IStakingVesting)10271": { - "encoding": "inplace", - "label": "contract IStakingVesting", - "numberOfBytes": "20" - }, - "t_enum(ValidatorFlag)12618": { - "encoding": "inplace", - "label": "enum EnumFlags.ValidatorFlag", - "numberOfBytes": "1" - }, - "t_mapping(t_address,t_bool)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => bool)", - "numberOfBytes": "32", - "value": "t_bool" - }, - "t_mapping(t_address,t_enum(ValidatorFlag)12618)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => enum EnumFlags.ValidatorFlag)", - "numberOfBytes": "32", - "value": "t_enum(ValidatorFlag)12618" - }, - "t_mapping(t_address,t_mapping(t_uint256,t_bool))": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => mapping(uint256 => bool))", - "numberOfBytes": "32", - "value": "t_mapping(t_uint256,t_bool)" - }, - "t_mapping(t_address,t_struct(CommissionSchedule)11511_storage)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => struct ICandidateManager.CommissionSchedule)", - "numberOfBytes": "32", - "value": "t_struct(CommissionSchedule)11511_storage" - }, - "t_mapping(t_address,t_struct(EmergencyExitInfo)12039_storage)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => struct ICommonInfo.EmergencyExitInfo)", - "numberOfBytes": "32", - "value": "t_struct(EmergencyExitInfo)12039_storage" - }, - "t_mapping(t_address,t_struct(ValidatorCandidate)11506_storage)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => struct ICandidateManager.ValidatorCandidate)", - "numberOfBytes": "32", - "value": "t_struct(ValidatorCandidate)11506_storage" - }, - "t_mapping(t_address,t_uint256)": { - "encoding": "mapping", - "key": "t_address", - "label": "mapping(address => uint256)", - "numberOfBytes": "32", - "value": "t_uint256" - }, - "t_mapping(t_uint256,t_address)": { - "encoding": "mapping", - "key": "t_uint256", - "label": "mapping(uint256 => address)", - "numberOfBytes": "32", - "value": "t_address" - }, - "t_mapping(t_uint256,t_bool)": { - "encoding": "mapping", - "key": "t_uint256", - "label": "mapping(uint256 => bool)", - "numberOfBytes": "32", - "value": "t_bool" - }, - "t_mapping(t_uint256,t_uint256)": { - "encoding": "mapping", - "key": "t_uint256", - "label": "mapping(uint256 => uint256)", - "numberOfBytes": "32", - "value": "t_uint256" - }, - "t_struct(CommissionSchedule)11511_storage": { - "encoding": "inplace", - "label": "struct ICandidateManager.CommissionSchedule", - "members": [ - { - "astId": 11508, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "effectiveTimestamp", - "offset": 0, - "slot": "0", - "type": "t_uint256" - }, - { - "astId": 11510, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "commissionRate", - "offset": 0, - "slot": "1", - "type": "t_uint256" - } - ], - "numberOfBytes": "64" - }, - "t_struct(EmergencyExitInfo)12039_storage": { - "encoding": "inplace", - "label": "struct ICommonInfo.EmergencyExitInfo", - "members": [ - { - "astId": 12036, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "lockedAmount", - "offset": 0, - "slot": "0", - "type": "t_uint256" - }, - { - "astId": 12038, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "recyclingAt", - "offset": 0, - "slot": "1", - "type": "t_uint256" - } - ], - "numberOfBytes": "64" - }, - "t_struct(ValidatorCandidate)11506_storage": { - "encoding": "inplace", - "label": "struct ICandidateManager.ValidatorCandidate", - "members": [ - { - "astId": 11493, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "admin", - "offset": 0, - "slot": "0", - "type": "t_address" - }, - { - "astId": 11495, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "consensusAddr", - "offset": 0, - "slot": "1", - "type": "t_address" - }, - { - "astId": 11497, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "treasuryAddr", - "offset": 0, - "slot": "2", - "type": "t_address_payable" - }, - { - "astId": 11499, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "bridgeOperatorAddr", - "offset": 0, - "slot": "3", - "type": "t_address" - }, - { - "astId": 11501, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "commissionRate", - "offset": 0, - "slot": "4", - "type": "t_uint256" - }, - { - "astId": 11503, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "revokingTimestamp", - "offset": 0, - "slot": "5", - "type": "t_uint256" - }, - { - "astId": 11505, - "contract": "contracts/ronin/validator/RoninValidatorSet.sol:RoninValidatorSet", - "label": "topupDeadline", - "offset": 0, - "slot": "6", - "type": "t_uint256" - } - ], - "numberOfBytes": "224" - }, - "t_uint256": { - "encoding": "inplace", - "label": "uint256", - "numberOfBytes": "32" - }, - "t_uint8": { - "encoding": "inplace", - "label": "uint8", - "numberOfBytes": "1" - } - } - } + "numDeployments": 4, + "solcInputHash": "20f35804d80bd26382f04e7db0eee067", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedEmergencyExit\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedRevokingCandidate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyRequestedUpdatingCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAlreadyWrappedEpoch\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrAtEndOfEpochOnly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallPrecompiled\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeCoinbase\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"}],\"name\":\"ErrCannotBailout\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrExceedsMaxNumberOfCandidate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrExistentCandidate\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdminAddr\",\"type\":\"address\"}],\"name\":\"ErrExistentCandidateAdmin\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_treasuryAddr\",\"type\":\"address\"}],\"name\":\"ErrExistentTreasury\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"currentBalance\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"sendAmount\",\"type\":\"uint256\"}],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidEffectiveDaysOnwards\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMaxPrioritizedValidatorNumber\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidMinEffectiveDaysOnwards\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrNonExistentCandidate\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrTrustedOrgCannotRenounce\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnauthorizedReceiveRON\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"NonExistentRecyclingInfo\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epoch\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"BlockProducerSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"coinbaseAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rewardAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"enum ICoinbaseExecution.BlockRewardDeprecatedType\",\"name\":\"deprecatedType\",\"type\":\"uint8\"}],\"name\":\"BlockRewardDeprecated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"coinbaseAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"submittedAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bonusAmount\",\"type\":\"uint256\"}],\"name\":\"BlockRewardSubmitted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"bridgeOperator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epoch\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"bridgeOperators\",\"type\":\"address[]\"}],\"name\":\"BridgeOperatorSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"CandidateGranted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"}],\"name\":\"CandidateRevokingTimestampUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"name\":\"CandidateTopupDeadlineUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"CandidatesRevoked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"effectiveTimestamp\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateUpdateScheduled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"rate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"balance\",\"type\":\"uint256\"}],\"name\":\"DeprecatedRewardRecycleFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipientAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"DeprecatedRewardRecycled\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedAmountUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unlockedAmount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedFundReleased\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unlockedAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitLockedFundReleasingFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"lockedAmount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExitRequested\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"EmergencyExpiryDurationUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"FastFinalityRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"FastFinalityRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"MaxPrioritizedValidatorNumberUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"}],\"name\":\"MaxValidatorCandidateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"MaxValidatorNumberUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"numOfDays\",\"type\":\"uint256\"}],\"name\":\"MinEffectiveDaysOnwardsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"MiningRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"MiningRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"totalAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"amounts\",\"type\":\"uint256[]\"}],\"name\":\"StakingRewardDistributed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"totalAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"amounts\",\"type\":\"uint256[]\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingRewardDistributionFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailedUntil\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"deductedStakingAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"blockProducerRewardDeprecated\",\"type\":\"bool\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"bridgeOperatorRewardDeprecated\",\"type\":\"bool\"}],\"name\":\"ValidatorPunished\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"consensusAddrs\",\"type\":\"address[]\"}],\"name\":\"ValidatorSetUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"ValidatorUnjailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"periodNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"epochNumber\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"bool\",\"name\":\"periodEnding\",\"type\":\"bool\"}],\"name\":\"WrappedUpEpoch\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADDITION_GAS\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"PERIOD_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"checkJailed\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_blockNum\",\"type\":\"uint256\"}],\"name\":\"checkJailedAtBlock\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_addrList\",\"type\":\"address[]\"}],\"name\":\"checkManyJailed\",\"outputs\":[{\"internalType\":\"bool[]\",\"name\":\"_result\",\"type\":\"bool[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_blockProducer\",\"type\":\"address\"}],\"name\":\"checkMiningRewardDeprecated\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_blockProducer\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"checkMiningRewardDeprecatedAtPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_result\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"currentPeriod\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"currentPeriodStartAtBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyExitLockedAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"emergencyExpiryDuration\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"epochEndingAt\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_block\",\"type\":\"uint256\"}],\"name\":\"epochOf\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"execApplyValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"execBailOut\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_secLeftToRevoke\",\"type\":\"uint256\"}],\"name\":\"execEmergencyExit\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_recipient\",\"type\":\"address\"}],\"name\":\"execReleaseLockedFundForEmergencyExitRequest\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_secsLeft\",\"type\":\"uint256\"}],\"name\":\"execRequestRenounceCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_effectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"execRequestUpdateCommissionRate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"validatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"newJailedUntil\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"slashAmount\",\"type\":\"uint256\"},{\"internalType\":\"bool\",\"name\":\"cannotBailout\",\"type\":\"bool\"}],\"name\":\"execSlash\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBlockProducers\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_result\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateInfo\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"______deprecatedbridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.ValidatorCandidate\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCandidateInfos\",\"outputs\":[{\"components\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"______deprecatedbridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"revokingTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"topupDeadline\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.ValidatorCandidate[]\",\"name\":\"_list\",\"type\":\"tuple[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCommissionChangeSchedule\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"effectiveTimestamp\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"commissionRate\",\"type\":\"uint256\"}],\"internalType\":\"struct ICandidateManager.CommissionSchedule\",\"name\":\"\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"getEmergencyExitInfo\",\"outputs\":[{\"components\":[{\"internalType\":\"uint256\",\"name\":\"lockedAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"recyclingAt\",\"type\":\"uint256\"}],\"internalType\":\"struct ICommonInfo.EmergencyExitInfo\",\"name\":\"_info\",\"type\":\"tuple\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"getJailedTimeLeft\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"isJailed_\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"blockLeft_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"epochLeft_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_blockNum\",\"type\":\"uint256\"}],\"name\":\"getJailedTimeLeftAtBlock\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"isJailed_\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"blockLeft_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"epochLeft_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getLastUpdatedBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getValidatorCandidates\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getValidators\",\"outputs\":[{\"internalType\":\"address[]\",\"name\":\"_validatorList\",\"type\":\"address[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__slashIndicatorContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__stakingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__stakingVestingContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__maintenanceContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninTrustedOrganizationContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__maxValidatorNumber\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxValidatorCandidate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxPrioritizedValidatorNumber\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__minEffectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__numberOfBlocksInEpoch\",\"type\":\"uint256\"},{\"internalType\":\"uint256[2]\",\"name\":\"__emergencyExitConfigs\",\"type\":\"uint256[2]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"fastFinalityTrackingContract\",\"type\":\"address\"}],\"name\":\"initializeV3\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"isBlockProducer\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidate\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"}],\"name\":\"isCandidateAdmin\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"isPeriodEnding\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"isValidatorCandidate\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxPrioritizedValidatorNumber\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_maximumPrioritizedValidatorNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxValidatorCandidate\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maxValidatorNumber\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_maximumValidatorNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minEffectiveDaysOnward\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"numberOfBlocksInEpoch\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_numberOfBlocks\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompilePickValidatorSetAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompileSortValidatorsAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_emergencyExitLockedAmount\",\"type\":\"uint256\"}],\"name\":\"setEmergencyExitLockedAmount\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_emergencyExpiryDuration\",\"type\":\"uint256\"}],\"name\":\"setEmergencyExpiryDuration\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_number\",\"type\":\"uint256\"}],\"name\":\"setMaxPrioritizedValidatorNumber\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_number\",\"type\":\"uint256\"}],\"name\":\"setMaxValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_max\",\"type\":\"uint256\"}],\"name\":\"setMaxValidatorNumber\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_numOfDays\",\"type\":\"uint256\"}],\"name\":\"setMinEffectiveDaysOnwards\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"submitBlockReward\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalBlockProducer\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_total\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"totalDeprecatedReward\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_epoch\",\"type\":\"uint256\"}],\"name\":\"tryGetPeriodOfEpoch\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_filled\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"_periodNumber\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorCount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"wrapUpEpoch\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrAlreadyRequestedEmergencyExit()\":[{\"details\":\"Error of already requested emergency exit before.\"}],\"ErrAlreadyRequestedRevokingCandidate()\":[{\"details\":\"Error of already requested revoking candidate before.\"}],\"ErrAlreadyRequestedUpdatingCommissionRate()\":[{\"details\":\"Error of commission change schedule exists.\"}],\"ErrAlreadyWrappedEpoch()\":[{\"details\":\"Error of query for already wrapped up epoch\"}],\"ErrAtEndOfEpochOnly()\":[{\"details\":\"Error of only allowed at the end of epoch\"}],\"ErrCallPrecompiled()\":[{\"details\":\"Error of call to precompile fails.\"}],\"ErrCallerMustBeCoinbase()\":[{\"details\":\"Error of method caller must be coinbase\"}],\"ErrCannotBailout(address)\":[{\"details\":\"Error of cannot bailout due to high tier slash.\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrExceedsMaxNumberOfCandidate()\":[{\"details\":\"Error of exceeding maximum number of candidates.\"}],\"ErrExistentCandidate()\":[{\"details\":\"Error of querying for already existent candidate.\"}],\"ErrExistentCandidateAdmin(address)\":[{\"details\":\"Error of candidate admin already exists.\"}],\"ErrExistentTreasury(address)\":[{\"details\":\"Error of treasury already exists.\"}],\"ErrInsufficientBalance(bytes4,uint256,uint256)\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInvalidCommissionRate()\":[{\"details\":\"Error of invalid commission rate.\"}],\"ErrInvalidEffectiveDaysOnwards()\":[{\"details\":\"Error of invalid effective days onwards.\"}],\"ErrInvalidMaxPrioritizedValidatorNumber()\":[{\"details\":\"Error thrown when an invalid maximum prioritized validator number is provided.\"}],\"ErrInvalidMinEffectiveDaysOnwards()\":[{\"details\":\"Error of invalid min effective days onwards.\"}],\"ErrNonExistentCandidate()\":[{\"details\":\"Error of querying for non-existent candidate.\"}],\"ErrRecipientRevert(bytes4)\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrTrustedOrgCannotRenounce()\":[{\"details\":\"Error of trusted org cannot renounce.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnauthorizedReceiveRON()\":[{\"details\":\"Error thrown when receives RON from neither staking vesting contract nor staking contract\"}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}],\"NonExistentRecyclingInfo()\":[{\"details\":\"Error thrown when queries for a non existent info.\"}]},\"kind\":\"dev\",\"methods\":{\"checkJailed(address)\":{\"details\":\"Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\"},\"checkJailedAtBlock(address,uint256)\":{\"details\":\"Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\"},\"checkManyJailed(address[])\":{\"details\":\"Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\"},\"checkMiningRewardDeprecated(address)\":{\"details\":\"Returns whether the incoming reward of the block producer is deprecated during the current period.\"},\"checkMiningRewardDeprecatedAtPeriod(address,uint256)\":{\"details\":\"Returns whether the incoming reward of the block producer is deprecated during a specific period.\"},\"currentPeriod()\":{\"details\":\"Returns the period index from the current block.\"},\"currentPeriodStartAtBlock()\":{\"details\":\"Returns the block number that the current period starts at.\"},\"emergencyExitLockedAmount()\":{\"details\":\"Returns the amount of RON to lock from a consensus address.\"},\"emergencyExpiryDuration()\":{\"details\":\"Returns the duration that an emergency request is expired and the fund will be recycled.\"},\"epochEndingAt(uint256)\":{\"details\":\"Returns whether the epoch ending is at the block number `_block`.\"},\"epochOf(uint256)\":{\"details\":\"Returns the epoch index from the block number.\"},\"execApplyValidatorCandidate(address,address,address,uint256)\":{\"details\":\"Grants a validator candidate. Requirements: - The method caller is staking contract. Emits the event `CandidateGranted`.\"},\"execBailOut(address,uint256)\":{\"details\":\"Finalize the bailout request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorUnjailed`.\"},\"execEmergencyExit(address,uint256)\":{\"details\":\"Fallback function of `IStaking-requestEmergencyExit`. Requirements: - The method caller is staking contract.\"},\"execReleaseLockedFundForEmergencyExitRequest(address,address)\":{\"details\":\"Unlocks fund for emergency exit request. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked. Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\"},\"execRequestRenounceCandidate(address,uint256)\":{\"details\":\"Requests to revoke a validator candidate in next `_secsLeft` seconds. Requirements: - The method caller is staking contract. Emits the event `CandidateRevokingTimestampUpdated`.\"},\"execRequestUpdateCommissionRate(address,uint256,uint256)\":{\"details\":\"Fallback function of `CandidateStaking-requestUpdateCommissionRate`. Requirements: - The method caller is the staking contract. - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards - The `_rate` must be in range of [0_00; 100_00]. Emits the event `CommissionRateUpdateScheduled`.\"},\"execSlash(address,uint256,uint256,bool)\":{\"details\":\"Finalize the slash request from slash indicator contract. Requirements: - The method caller is slash indicator contract. Emits the event `ValidatorPunished`.\"},\"getBlockProducers()\":{\"details\":\"Returns the current block producer list.\"},\"getCandidateInfo(address)\":{\"details\":\"Returns the info of a candidate.\"},\"getCandidateInfos()\":{\"details\":\"Returns all candidate info.\"},\"getCommissionChangeSchedule(address)\":{\"details\":\"Returns the schedule of changing commission rate of a candidate address.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getEmergencyExitInfo(address)\":{\"details\":\"Returns the emergency exit request.\"},\"getJailedTimeLeft(address)\":{\"details\":\"Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\"},\"getJailedTimeLeftAtBlock(address,uint256)\":{\"details\":\"Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\"},\"getLastUpdatedBlock()\":{\"details\":\"Returns the block that validator set was updated.\"},\"getValidatorCandidates()\":{\"details\":\"Returns the validator candidate.\"},\"getValidators()\":{\"details\":\"Returns the current validator list.\"},\"initialize(address,address,address,address,address,address,uint256,uint256,uint256,uint256,uint256,uint256[2])\":{\"details\":\"Initializes the contract storage.\"},\"isBlockProducer(address)\":{\"details\":\"Returns whether the address is block producer or not.\"},\"isCandidateAdmin(address,address)\":{\"details\":\"Returns whether the address is the candidate admin.\"},\"isPeriodEnding()\":{\"details\":\"Returns whether the period ending at the current block number.\"},\"isValidatorCandidate(address)\":{\"details\":\"Returns whether the address is a validator (candidate).\"},\"maxPrioritizedValidatorNumber()\":{\"details\":\"Returns the number of reserved slots for prioritized validators.\"},\"maxValidatorCandidate()\":{\"details\":\"Returns the maximum number of validator candidate.\"},\"maxValidatorNumber()\":{\"details\":\"Returns the maximum number of validators in the epoch.\"},\"minEffectiveDaysOnward()\":{\"details\":\"Returns the minimum number of days to the effective date of commission rate change.\"},\"numberOfBlocksInEpoch()\":{\"details\":\"Returns the number of blocks in a epoch.\"},\"precompilePickValidatorSetAddress()\":{\"details\":\"Gets the address of the precompile of picking validator set\"},\"precompileSortValidatorsAddress()\":{\"details\":\"Gets the address of the precompile of sorting validators\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setEmergencyExitLockedAmount(uint256)\":{\"details\":\"Sets the amount of RON to lock from a consensus address. Requirements: - The method caller is admin. Emits the event `EmergencyExitLockedAmountUpdated`.\"},\"setEmergencyExpiryDuration(uint256)\":{\"details\":\"Sets the duration that an emergency request is expired and the fund will be recycled. Requirements: - The method caller is admin. Emits the event `EmergencyExpiryDurationUpdated`.\"},\"setMaxPrioritizedValidatorNumber(uint256)\":{\"details\":\"Updates the number of reserved slots for prioritized validators Requirements: - The method caller is admin Emits the event `MaxPrioritizedValidatorNumberUpdated`\"},\"setMaxValidatorCandidate(uint256)\":{\"details\":\"Sets the maximum number of validator candidate. Requirements: - The method caller is admin. Emits the `MaxValidatorCandidateUpdated` event.\"},\"setMaxValidatorNumber(uint256)\":{\"details\":\"Updates the max validator number Requirements: - The method caller is admin Emits the event `MaxValidatorNumberUpdated`\"},\"setMinEffectiveDaysOnwards(uint256)\":{\"details\":\"Sets the minimum number of days to the effective date of commision rate change. Requirements: - The method caller is admin. Emits the `MinEffectiveDaysOnwardsUpdated` event.\"},\"submitBlockReward()\":{\"details\":\"Submits reward of the current block. Requirements: - The method caller is coinbase. Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer. Emits the event `BlockRewardSubmitted` for the valid call.\"},\"totalBlockProducer()\":{\"details\":\"Returns total numbers of the block producers.\"},\"totalDeprecatedReward()\":{\"details\":\"Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\"},\"tryGetPeriodOfEpoch(uint256)\":{\"details\":\"Tries to get the period index from the epoch number.\"},\"wrapUpEpoch()\":{\"details\":\"Wraps up the current epoch. Requirements: - The method must be called when the current epoch is ending. - The epoch is not wrapped yet. - The method caller is coinbase. Emits the event `MiningRewardDistributed` when some validator has reward distributed. Emits the event `StakingRewardDistributed` when some staking pool has reward distributed. Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up. Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending. Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated. Emits the event `WrappedUpEpoch`.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/validator/RoninValidatorSet.sol\":\"RoninValidatorSet\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"none\"},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://383fb7b8181016ac5ccf07bc9cdb7c1b5045ea36e2cc4df52bcbf20396fc7688\",\"dweb:/ipfs/QmYJ7Cg4WmE3rR8KGQxjUCXFfTH6TcwZ2Z1f6tPrq7jHFr\"]},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://96b6d77a20bebd4eb06b801d3d020c7e82be13bd535cb0d0a6b7181c51dab5d5\",\"dweb:/ipfs/QmPUR9Cv9jNFdQX6PtBfaBW1ZCnKwiu65R2VD5kbdanDyn\"]},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://89c2a0f70157c13845be5cb49b078a6374fee3a78fa950052a3af26190255da8\",\"dweb:/ipfs/QmUcvMEQH1oMM2pUyMuDiBUKdvvnTz1NRB8bmPHrVq8725\"]},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://8831721b6f4cc26534d190f9f1631c3f59c9ff38efdd911f85e0882b8e360472\",\"dweb:/ipfs/QmQZnLErZNStirSQ13ZNWQgvEYUtGE5tXYwn4QUPaVUfPN\"]},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://ada1e030c0231db8d143b44ce92b4d1158eedb087880cad6d8cc7bd7ebe7b354\",\"dweb:/ipfs/QmWZ2NHZweRpz1U9GF6R1h65ri76dnX7fNxLBeM2t5N5Ce\"]},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://a6c4477d480bac20d681ade0e712b77ad828acf530a1d5c0abc5fb78068a05a1\",\"dweb:/ipfs/QmdBqsK8CcUceTeWzhHwFDEvKMoHimwtV96Lbim7ZBtCb8\"]},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://3313a8f9bb1f9476857c9050067b31982bf2140b83d84f3bc0cec1f62bbe947f\",\"dweb:/ipfs/Qma17Pk8NRe7aB4UD3jjVxk7nSFaov3eQyv86hcyqkwJRV\"]},\"@openzeppelin/contracts/utils/Address.sol\":{\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://35c47bece3c03caaa07fab37dd2bb3413bfbca20db7bd9895024390e0a469487\",\"dweb:/ipfs/QmPGWT2x3QHcKxqe6gRmAkdakhbaRgx3DLzcakHz5M4eXG\"]},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://39e096c60a6eb1c6a257122d515496bd92d0c6a693a8f07acb6aa4b1263e95d4\",\"dweb:/ipfs/QmPs5trJBacCiSkezP6tpevapuRYWNY6mqSFzsMCJj7e6B\"]},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://be161e54f24e5c6fae81a12db1a8ae87bc5ae1b0ddc805d82a1440a68455088f\",\"dweb:/ipfs/QmP7C3CHdY9urF4dEMb9wmsp1wMxHF6nhA2yQE5SKiPAdy\"]},\"contracts/extensions/RONTransferHelper.sol\":{\"keccak256\":\"0xdece837caa8da00fe031b8139ada009330b8bef149af12b535913c021ab94d0e\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://11af5018dd76ccfca6c4cfb886019987d88830c02efcec999c02d3e6d907475a\",\"dweb:/ipfs/QmNyEcRDvrCENivjdmw3TxMFDBcQNvEUzHorra7HkERLWf\"]},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://370c93bc1e962fcf8eab41d217d901716769f05c51a2cb25aae12abc84e871da\",\"dweb:/ipfs/QmQYL5QrJmXCdi5UN9K7imt1iPm9ydZQm6ifShpt451afd\"]},\"contracts/extensions/collections/HasContracts.sol\":{\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://b8903232a7a609b250a1ff2e9522a2366979652145af74637f9c0089916e3da3\",\"dweb:/ipfs/QmVoxZamJEhjYhr9RKVSAKGzakgqmFLfZXhZcDGor7DZe5\"]},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://2e220c59eb50b4e206d0a126f8cd2f7f2aa6865f56a0b4b091149e6928bf97b8\",\"dweb:/ipfs/QmRBk5hhn1w2MghZ8pRfaU1CvgRAZN7nZvxySSPDvkVuGp\"]},\"contracts/extensions/consumers/GlobalConfigConsumer.sol\":{\"keccak256\":\"0x96d6b1ea4c8e126a8c2468683e7513d195f8e05456d85dd8f259ab049347b527\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://23a7906515d4648b243fb01f8053b1595e8c1c62fa9745b56ed296372da6ebdf\",\"dweb:/ipfs/QmdUjefqn52Hu7bjAKYJMRanPy7fdKqJAtnqSB2793Zhfm\"]},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://e97f64c7f3522d605c5e8d6d96d568e0b8cb6b2f21cc288d508cbe43b831f5d9\",\"dweb:/ipfs/QmT9hBanREurnngznkfTAhHu4qDQu3F3hPXTzKgKjSWz7r\"]},\"contracts/interfaces/IFastFinalityTracking.sol\":{\"keccak256\":\"0xdc397642692af9710314e971f8de772d50d6bc304db9e5babd9ffcfb9d2f4434\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://9f43513532d979a1c4ff09c5b7b5b0b85ce19317e06d36a5b0215591f7d1f821\",\"dweb:/ipfs/QmQKKnarmdrYuoMAiA5aR1PJFCXnMrqgMm77oQU6mSVQVw\"]},\"contracts/interfaces/IMaintenance.sol\":{\"keccak256\":\"0xe30d31be54b9f9044c6a5d1393f04f9093d619a705d00276359853a086a91e8a\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://c2a0a4d97e3f10107822b10b758d85e1cbc311a940efcd7164c9c17e2e740cfc\",\"dweb:/ipfs/QmQdmGBJrt8ZmyivKGArrZmkaKPXg6HxWdxTiMpXGSpPev\"]},\"contracts/interfaces/IQuorum.sol\":{\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://a8c81134e4632e1240aead39fd5393b376a4be53668caf2a390f511f3c6d422d\",\"dweb:/ipfs/QmWPaQPP1WkpdPjLhK7wFXsih8HWs6kRQqjX5zGLu6McGH\"]},\"contracts/interfaces/IRoninGovernanceAdmin.sol\":{\"keccak256\":\"0x4ee85b5dc2b33068bc7cbe168ae26328a6459f98c558aba5d9e5a1d6aead0da8\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://2a3f3608d19c73d5b60a22317fa0594778aad515a6d9c5dc5b7bad8f5ac1f4f9\",\"dweb:/ipfs/QmYTPxJJGG9oycJDupSRv6YQaS8k3GuA46LmVZ3tStTpg2\"]},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"keccak256\":\"0x2eaef3332e209474b24574aeded61091e82a145fcbcf479577535c0cd210e1e5\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://5f65e26ad439a457865e4312e547bba57111b7b7b13ca6547b42647c7ae21e29\",\"dweb:/ipfs/Qme293o5nFv77wvHvgmRtxSkjFHhFWQhDDD3FQTqAtkgd3\"]},\"contracts/interfaces/IStakingVesting.sol\":{\"keccak256\":\"0xdf4e372179731e859e564988eba09fda97810aeda1fec2b84c8abdaa6e1a5912\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://469644e6ce6d573dadb2462235033be7b656a15363f3249fe03d4bd4dec75fe4\",\"dweb:/ipfs/Qmau5A3ALkEtcYQM8rT9uRHQgsAgmTGfcj8uq596zr7NmH\"]},\"contracts/interfaces/collections/IHasContracts.sol\":{\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://03390ff29b496e244faf4eab55565712f0aea5fecdcb915e3c5866ef29d5686d\",\"dweb:/ipfs/QmdGpXn3VSxfNvjFBxfho7rc41JTq5m6bonrfmpzShhRVs\"]},\"contracts/interfaces/consumers/PeriodWrapperConsumer.sol\":{\"keccak256\":\"0xb6777e3c364306eb8d5355583c1aca44de9d351cb40ddf1cea832206d4aad272\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://f158da03631d0e3c4558a18fc50e7f2416172983cfbb14a158dd4fc7c83c7053\",\"dweb:/ipfs/QmX8Vq2sKEAckrMEN5W5LaUzE7ppdaR7scv8amyV1YEXGG\"]},\"contracts/interfaces/slash-indicator/IBaseSlash.sol\":{\"keccak256\":\"0x2e09934977e0701a28b7f776f0bd4eefdfd8d6b68134822440b2c756b6b7d1e4\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://e6dad2674e816cc50055f86b36321aa00c786e0f729961a812486ad86990ca98\",\"dweb:/ipfs/QmTZLuEScB3rRjDN7VVpp3LUhRbQyKyfXwvMMwQehxjGcj\"]},\"contracts/interfaces/slash-indicator/ICreditScore.sol\":{\"keccak256\":\"0x26021ddf339495816692ea9f8545b4054d0ffb9c5ad11049cac4f3718a0bbc2d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://78be72af4c66b1156e34285cebbe996c9e12a1dddc7064ba19dc31c9ca29f04a\",\"dweb:/ipfs/QmQc6Qziq8FK22pHezjNK6anUpdRtLyTnUfbiYdo7KBFDT\"]},\"contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol\":{\"keccak256\":\"0x3ea38604baf3bc5a12dd1a243eec2052de9ee2cb171222a2e5b0e5202d301471\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://efe7768c54473cdd7ea25abf571302059266a7aeff5a29bada77ac1364b0af0c\",\"dweb:/ipfs/QmfXxeWbvybKEb13wBBJgmYT1N9p7txEGnZPPKNwP1AhHL\"]},\"contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol\":{\"keccak256\":\"0x89751cbf99adf7dbd165fbbba5d6b62b5c47f8486322a7abb27d6d6aef345fae\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://4d3d95b75ae204e2d7734590f9ae2adfec28e786c981a990157888ca9bc0a9b8\",\"dweb:/ipfs/QmSeRfhkrHiN1CNFQWZbVLvfPFw4jJQg8sm6uK1PLMcsvg\"]},\"contracts/interfaces/slash-indicator/ISlashDoubleSign.sol\":{\"keccak256\":\"0xb1adb41d0b1c8a362b7e669d9975754adbd4ed0f8de912e8455fa70eedd80d35\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://c08e156297b5a18128eac2dbbf47131d7122f8a67e733bdd5c1bd297a3e7ec37\",\"dweb:/ipfs/QmVh6cLdB1g1uRJb7C7SVfhWYarSFnWp6qG6maADYrpTaC\"]},\"contracts/interfaces/slash-indicator/ISlashIndicator.sol\":{\"keccak256\":\"0xe8b8fde3af614735cb304bc1eb82b05d65ede4df804b5d555787e5d5ecb95ec0\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://7c457aec7776026962e2a9e606f6b4bb76de6c4407ff5ca0197348c3a991612e\",\"dweb:/ipfs/QmPGBqNCqkUFvcktSryxS99Apzqq6MZF7S28hVrockzanS\"]},\"contracts/interfaces/slash-indicator/ISlashUnavailability.sol\":{\"keccak256\":\"0x458a7ae130a59b59b7f095fe3d4db8f779e0614041e5615f0afd36c543ac2046\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://947dcfcf74803babe38e80b37d234796cda3831a2f19936e98a0954c3936ee0e\",\"dweb:/ipfs/QmQW8ux3awTt8BNH6NnWtPNSBvWTA36wR35bTj1Eymx1D6\"]},\"contracts/interfaces/staking/IBaseStaking.sol\":{\"keccak256\":\"0x90517268a0e31147d97772c9ae518caa5eb8c03efe3b369e3c6d5166422f5962\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://cb491a0f017e3426a4c96344e65a1e3f26603759758159c8a75b731029a574d9\",\"dweb:/ipfs/QmTQ6jhx6pzzPdubogP5ktSyrhg5PspbCVaQaeHS4AJDg7\"]},\"contracts/interfaces/staking/ICandidateStaking.sol\":{\"keccak256\":\"0x9bc6ba6d13f00d9928c0add35ee6406906e16ed86207d373460930c0a75e5938\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://36091a688331967fbfff2890250653dc15906bf0f7bad1fe4019fb7db6c8a44f\",\"dweb:/ipfs/Qme2NLnJHrwa9pWA2aJevECkpgoN83EJFMofcJEhL24DN9\"]},\"contracts/interfaces/staking/IDelegatorStaking.sol\":{\"keccak256\":\"0x6dd71bf0c17a65da0dee49b98e4b038c1dd0e74f5473d03570421ceebd5b7084\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://c4b494d452bdfd70169edbc8fe348ccde87b626fa3eda23af15cf9b4c2287f51\",\"dweb:/ipfs/QmZ1EiHHUWE1ATTSoYs2iKQLw5YTV7zpQ9zBU6SNFUTAFP\"]},\"contracts/interfaces/staking/IRewardPool.sol\":{\"keccak256\":\"0x52349fecb897b3b8288d8732923551382822c0c5fb8db9c6b094d080a16a2129\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://67c0c9c2a736e1ba3bf329edef9d7d675dc86a5efe569fe49f9611896acd0667\",\"dweb:/ipfs/Qmc31DL6bovfqbdRb4a3Cqg1Gge8mC82Q43uh2HmS7YGvT\"]},\"contracts/interfaces/staking/IStaking.sol\":{\"keccak256\":\"0xd302d4a78203e277fb95a89de7ae32a3102129d3fbd64fc75f92d18be0443408\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://8ed162378c575055c0dff266b578780d3799613cf7912c0adb7428e35f70231f\",\"dweb:/ipfs/QmbnSRJwU3jee9zcvW12cYRuGpqThtx9zHzpGPQdsp6sNy\"]},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://1f26f12846961c93a302c912ef9534948e75d1712e9861361d6e4869067f74e3\",\"dweb:/ipfs/QmaQEiTdfFT9CbQEhMyvrEtPgiQUqdY2hZjAS3LUaVoGns\"]},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://e6c058176001fdf5c3568e3bef95dbd0616f29136f6488457bac313b49cf8307\",\"dweb:/ipfs/QmYCxycKBcX815zGkXPDBC3t2CgqJwZNHcvtKA9ssc4fMq\"]},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://06091b25304096f52e46fa2f5c693e5dcf30697cb4f25e6eac075a7daea2f2cd\",\"dweb:/ipfs/QmQxNvAdqydyWCjQt3gfXXB8a5dAiLZgCdiJQCtM7Ah19b\"]},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://e858204fc0e1f733b3b8482326a52fb150eb6c657881b7f2a7721d52826f7e4f\",\"dweb:/ipfs/QmboahnNNTeXjcELXsWZUq93wyvQQRMbimm27xDta85wEc\"]},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://eac6d51b093831c768d7ef2b17a01333f4aca4c419a593c8b2690db132a06f4a\",\"dweb:/ipfs/QmYZEfUKfmbREoTukK2sic686yABpFmcQTn3x75kjtVj58\"]},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://8c586009b6c57b4e0daf60123bf4b133a91a42a1d803c332ba0bdaecab871f18\",\"dweb:/ipfs/QmUT8bLX8MfVjLBs1pXEYXFob5YtAq9tEGBz3KV1WKac4B\"]},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://db41b9c12cde1d32f060db3b81eeee93a512cf0188aadfa9e262d9cc15714ef8\",\"dweb:/ipfs/QmfJkTv1kpfbHtz2hQiWhBZN1r725YAnZMHo71gmgQ4J43\"]},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://8a0c87e2e9c661730fdecd3cacc54a630ac2dfd35218dcbe41b70bb15d16aea2\",\"dweb:/ipfs/QmcLD62ZZ6YVSECvx7515PVXymbP8SRwayZsy6r4NAiPLJ\"]},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://a7ac5190b26cd4d6984da11578842b7b5c5230f5c7acd89ac6194df149f033ef\",\"dweb:/ipfs/QmURqWRZpt5QCJ9dj2EtJToY2Pz7KvTktdfWoTbWhNcGcP\"]},\"contracts/libraries/AddressArrayUtils.sol\":{\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\",\"urls\":[\"bzz-raw://3a413f290b8e81540bc6feb739bcfbacf56419b2e657bbce5be43826569b4406\",\"dweb:/ipfs/QmWRjGLBXs7WK92oPm51QpjxMYGuMTBx85Pv7QcGbUZE72\"]},\"contracts/libraries/EnumFlags.sol\":{\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\",\"urls\":[\"bzz-raw://1b05f2717fd40454d68d411ab7bbbf5e3bb8ea6d7f27d335b1338362305904a2\",\"dweb:/ipfs/QmaiGASjWNVyfFzguu5xoKFRcLqGg67DHSd5422b5k6rbb\"]},\"contracts/libraries/Math.sol\":{\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\",\"urls\":[\"bzz-raw://b4af5bb4d7c57d10844b31211dc52762f69c33f99fe90bf8bd4086b0f7ece4da\",\"dweb:/ipfs/Qma1Gtmp2Y5YMxAXS7XpUQHkc4auz95W6CevSLmD5CFrrB\"]},\"contracts/precompile-usages/PCUPickValidatorSet.sol\":{\"keccak256\":\"0xcb57a021897a773d11be9d98a195e0653f2124b7e95e84c4832b57d9d36d67e1\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://62cfabee3f0ad5ab8ba6b5f318ff33e68a3e532649a958b51fac6ae559ca95c0\",\"dweb:/ipfs/QmPJkxM87o2LGsqSRgTQnnaZJtZRXeRu7ZbGzwNXggMCsr\"]},\"contracts/precompile-usages/PCUSortValidators.sol\":{\"keccak256\":\"0xf2f21d25f9d1b77e591542440c839d98125ae3c41c73de7c42f8c46d95eac717\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://52b9340ff9f29ef0bcf0552142fe1df4036bdea579bf0d023bd3e65d0f706233\",\"dweb:/ipfs/Qmbv3QcysrYQiZiGC9A9Hj6EPRPu52fWFHDhmyX5nfUoqn\"]},\"contracts/precompile-usages/PrecompiledUsage.sol\":{\"keccak256\":\"0x76facc3f3a8dd573c826bbbfedaa5cd8ef30963fbabd8c163c0c72b6efea5551\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://6d7c9e940ba3e89d832b615239ba9e4af44471b3701bd1f480924a7e2c434f63\",\"dweb:/ipfs/QmPtxtdPgTzyw7WpzpLBCX7anYbq5q7zwarz1PzVAFX4zz\"]},\"contracts/ronin/validator/CandidateManager.sol\":{\"keccak256\":\"0x8cb589408125c80089fc496eb8531eedc20743417f528789629c6dacda6a43fc\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://b2d03cc377843c808989b4cab9e47374cdf00806f17b7f141c5c63797acc177f\",\"dweb:/ipfs/QmNy5GJRZ2AgQwRJGfEcVoFiakXGm2YPgbpVVyD8L2jC1M\"]},\"contracts/ronin/validator/CoinbaseExecution.sol\":{\"keccak256\":\"0xd4ab224eb249b8929505e0164020d58c9518668049b35102430d28dabc825042\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://bf59ea630694e5c0b48cd7a7bb628ae7ef3a51d77ad79f5b410fe27c8cd167f0\",\"dweb:/ipfs/QmWE2cmnT1UFro9mEJmoc4oPcatGCqb3xUo6XbTitLV1xq\"]},\"contracts/ronin/validator/EmergencyExit.sol\":{\"keccak256\":\"0x7b57a4e3afd9099caa0498ec60fc6cf660512784ca0f864ff44fa1aac6cd26c2\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://da721099dc33a82d6af75154c4f26ca8ca8e6786fe6321d8a58f02c12f0603b9\",\"dweb:/ipfs/QmbqcxVGHyBDkwLR8JjfrB4htcSgdV6FMw89E28QUwMEuA\"]},\"contracts/ronin/validator/RoninValidatorSet.sol\":{\"keccak256\":\"0xe58cf3b822cc47e0ae23e52c67e16659f86f0e95bf853730ccb57b95cceaa496\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://a228904556bf1f12502c12b046ec1b46b620bdbcb6df647a01c016ba4ee48553\",\"dweb:/ipfs/QmP8nUyZuL5qyBqbJ9JyFAw11Nh1X8UXwDMheMM8Epbqpa\"]},\"contracts/ronin/validator/SlashingExecution.sol\":{\"keccak256\":\"0x7be4b1597eeecd1acf643862289debadf5f84d68650ae39164d46bcaf9fa7c91\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://e449beda857caedc3dab011ff931be7b3a87096bc52fb59f903e8e915a1d4e2e\",\"dweb:/ipfs/QmPMAtdnY2iUPuRwNVeVUybqKY7NAor1PuFidvAa57hBZe\"]},\"contracts/ronin/validator/storage-fragments/CommonStorage.sol\":{\"keccak256\":\"0x917af4e54f9c93ec26ccdbfd28428f08450eec01e9af1b01e11536c12ba8fa8d\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://bae595f4b27ab2decefbe955ea9bd190b30043c2fdc23a658202e3502eeb71d5\",\"dweb:/ipfs/QmPT3nUHvyvDoGJKUbGkkUbieAPkkdAsUW1omEp6dcCur7\"]},\"contracts/ronin/validator/storage-fragments/JailingStorage.sol\":{\"keccak256\":\"0xdef0c07a95baaff5c23b5cacf7747f50a76a150875ae118f8553fe3ae0d15498\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://4c64a137711f1aa3504d9c9dac1cf0be859bad338a56fc581b164aee29adce69\",\"dweb:/ipfs/Qmd135rnBhmZjzEiNXym12zRnN6JGKkckgsucUWE7usF8d\"]},\"contracts/ronin/validator/storage-fragments/TimingStorage.sol\":{\"keccak256\":\"0xc545f119b8b8978d793b62f2495dc2d49c3f416791459b9833bdc65f4dae8e7f\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://dd26180c3dcd0765e292dd187e686c006ce2b41404898a24886b504d16f7234d\",\"dweb:/ipfs/QmV8dbzzqH7y7D8Hxshpanirb2GZaq9evLoWEurrvqQGrE\"]},\"contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol\":{\"keccak256\":\"0x502092b4bbe2b76543bcc576cb0fb815626dc06afbaaf26a59c6fc0cfbabeb4f\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://df9209f98da0e97e0a97133b6a5522a3cdf711104cffbb5c8865b0daa9ead482\",\"dweb:/ipfs/QmRf2fsvDEXAJ2iuzZjURv7KtsbVBy3S8nJZaayR6zQWdu\"]},\"contracts/utils/CommonErrors.sol\":{\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://d7e47ff198edb68a65d65938c67f860c041a4b7f64cff5b101a333869096044b\",\"dweb:/ipfs/QmTFwEY7jPiUSKc3GvYDY7qHqXJzUYCmSjoVrcgFhi8gZz\"]},\"contracts/utils/ContractType.sol\":{\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://130e3f8353d9f34098fbf2867c3bf812a5184904d0113d55c5c820eb64f2547b\",\"dweb:/ipfs/QmeFSUbPi8fyG1W7kKegFRtCqALjQBXQyVvQ4sjpi6SWH3\"]},\"contracts/utils/DeprecatedSlots.sol\":{\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://66205963116e22bb24d9f2e0c1a38a27c4c0c3cf50693bc5f3177068cba37612\",\"dweb:/ipfs/Qmb1hZg6Df4zLeDMPMH4WZVpyLFe7A4TTBEtR6HHddSohC\"]},\"contracts/utils/IdentityGuard.sol\":{\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://5e4cedc10e50bfaacdc732eab78768b5e0abbc8336eeaffa15de2a7be90de504\",\"dweb:/ipfs/QmR17AgM71NkH5ZeLpmaRMzPyXAKyhafoK2TZUnLw2z3Mv\"]},\"contracts/utils/RoleAccess.sol\":{\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\",\"urls\":[\"bzz-raw://070d8254ea4d6fde54ae02e121bb84bdb63a3c5a8513d2d364ad5038f6a95493\",\"dweb:/ipfs/QmfXpp3t8XcGFXewoVRmoQMKJb9vPo95Kj4vsGfNBf7gSH\"]}},\"version\":1}", + "bytecode": "0x60806040523480156200001157600080fd5b506200001c62000022565b620000e4565b600054610100900460ff16156200008f5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff9081161015620000e2576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b614cdc80620000f46000396000f3fe6080604052600436106102955760003560e01c806303827884146102ac57806304d971ab146102d557806306040618146103055780630f43a6771461031a57806311662dc2146103305780631196ab661461036d57806315b5ebde1461038d578063217f35c2146103ad57806323c65eb0146103c257806328bde1e1146103e25780632924de711461040f578063297a8fca1461042f5780632d784a98146104445780632f78204c146104715780633101cfcb1461049157806331a8aef5146104b1578063367ec12b146104d15780633b3159b6146104f1578063468c96ae1461050e57806349096d26146105455780634d8df063146105675780634de2b735146105875780634ee4d72b146105b45780634f2a693f146105c957806352091f17146105e95780635248184a146105f15780635cd8a76b14610613578063605239a114610628578063612c8d981461063d57806365244ece146106525780636558954f146106725780636611f84314610689578063690b7536146106a95780636aa1c2ef146106be57806372e46810146106d35780637593ff71146106db578063823a7b9c146106fb578063865e6fd31461071b578063873a5a701461073b57806387c891bd1461075b5780638d559c381461077057806396585fc214610784578063a0c3f2d2146107a4578063a3d545f5146107c4578063a66c0f77146107e4578063a7c2f119146107f9578063afc69d7314610819578063b7ab4db51461082e578063ba77b06c14610843578063c3c8b5d614610858578063c94aaa0214610878578063d09f1ab414610898578063dd716ad3146108ad578063de981f1b146108cd578063e5125a1d146108ed578063edb194bb1461090d578063eeb629a81461096f578063f883afaf14610984576102a4565b366102a4576102a26109a4565b005b6102a26109a4565b3480156102b857600080fd5b506102c26104b081565b6040519081526020015b60405180910390f35b3480156102e157600080fd5b506102f56102f03660046141c9565b610a0d565b60405190151581526020016102cc565b34801561031157600080fd5b506102c2610a34565b34801561032657600080fd5b506102c260aa5481565b34801561033c57600080fd5b5061035061034b366004614202565b610a44565b6040805193151584526020840192909252908201526060016102cc565b34801561037957600080fd5b506102a261038836600461422e565b610ac7565b34801561039957600080fd5b506102a26103a8366004614202565b610adb565b3480156103b957600080fd5b506102f5610bdc565b3480156103ce57600080fd5b506102f56103dd366004614202565b610bf1565b3480156103ee57600080fd5b506104026103fd366004614247565b610c04565b6040516102cc91906142b8565b34801561041b57600080fd5b506102f561042a366004614247565b610ca7565b34801561043b57600080fd5b506004546102c2565b34801561045057600080fd5b5061046461045f366004614247565b610cb3565b6040516102cc91906142c6565b34801561047d57600080fd5b506102a261048c3660046142eb565b610d15565b34801561049d57600080fd5b506102a26104ac366004614247565b610f30565b3480156104bd57600080fd5b506102f56104cc366004614202565b610fc0565b3480156104dd57600080fd5b506102a26104ec366004614346565b610fcc565b3480156104fd57600080fd5b5060685b6040516102cc919061440c565b34801561051a57600080fd5b5061052e61052936600461422e565b6110ff565b6040805192151583526020830191909152016102cc565b34801561055157600080fd5b5061055a61113d565b6040516102cc9190614464565b34801561057357600080fd5b506102a261058236600461422e565b61121c565b34801561059357600080fd5b506105a76105a2366004614477565b61122d565b6040516102cc91906144eb565b3480156105c057600080fd5b5060e4546102c2565b3480156105d557600080fd5b506102a26105e436600461422e565b6112de565b6102a26112ef565b3480156105fd57600080fd5b506106066116ba565b6040516102cc9190614531565b34801561061f57600080fd5b506102a26117df565b34801561063457600080fd5b506072546102c2565b34801561064957600080fd5b506076546102c2565b34801561065e57600080fd5b506102f561066d366004614247565b611918565b34801561067e57600080fd5b506102c26201518081565b34801561069557600080fd5b506102a26106a436600461422e565b611952565b3480156106b557600080fd5b5060e5546102c2565b3480156106ca57600080fd5b506001546102c2565b6102a2611963565b3480156106e757600080fd5b506102f56106f636600461422e565b611bb1565b34801561070757600080fd5b506102a261071636600461422e565b611bd5565b34801561072757600080fd5b506102a2610736366004614582565b611be6565b34801561074757600080fd5b506102f5610756366004614247565b611c05565b34801561076757600080fd5b506002546102c2565b34801561077c57600080fd5b506066610501565b34801561079057600080fd5b5061035061079f366004614247565b611c1c565b3480156107b057600080fd5b506102f56107bf366004614247565b611c38565b3480156107d057600080fd5b506102c26107df36600461422e565b611c55565b3480156107f057600080fd5b5060e6546102c2565b34801561080557600080fd5b506102a2610814366004614202565b611c60565b34801561082557600080fd5b506102c2611ea3565b34801561083a57600080fd5b5061055a611ee6565b34801561084f57600080fd5b5061055a611f8c565b34801561086457600080fd5b506102a26108733660046141c9565b611fee565b34801561088457600080fd5b506102a261089336600461422e565b612245565b3480156108a457600080fd5b5060a9546102c2565b3480156108b957600080fd5b506102a26108c8366004614202565b612256565b3480156108d957600080fd5b506105016108e836600461459e565b6122dc565b3480156108f957600080fd5b506102a26109083660046145b9565b612339565b34801561091957600080fd5b50610464610928366004614247565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b34801561097b57600080fd5b5060ad546102c2565b34801561099057600080fd5b506102a261099f3660046145ee565b612447565b6109ae60076122dc565b6001600160a01b0316336001600160a01b0316141580156109ea57506109d460096122dc565b6001600160a01b0316336001600160a01b031614155b15610a0b5760405160016234baed60e01b0319815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610a3f60035490565b905090565b6001600160a01b0382166000908152603a60205260408120548190819084811015610a7a57600080600093509350935050610ac0565b60019350610a888582614655565b610a93906001614668565b9250610a9e85611c55565b610aa782611c55565b610ab19190614655565b610abc906001614668565b9150505b9250925092565b610acf612647565b610ad881612690565b50565b6006610ae6816126e7565b6001600160a01b0383166000908152603c60205260409020544311610b2957826040516353e0424d60e01b8152600401610b20919061440c565b60405180910390fd5b6001600160a01b038316600081815260386020908152604080832086845282528083208054600160ff199182168117909255948452603783528184208785529092529091208054909216909155610b809043614655565b6001600160a01b0384166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e90610bcf9085815260200190565b60405180910390a2505050565b6000610a3f610bea42612733565b6003541090565b6000610bfd8383612742565b9392505050565b610c0c614178565b610c1582611c38565b610c325760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610a2e8243610bf1565b604080518082018252600080825260209182018190526001600160a01b038416815260e882528281208351808501909452805484526001015491830182905203610d10576040516370fdd4f160e11b815260040160405180910390fd5b919050565b6006610d20816126e7565b6000610d2a610a34565b6001600160a01b03871660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e090915291902054919250610d7891614668565b60e46000828254610d899190614668565b90915550506001600160a01b038616600090815260e06020908152604080832083905560e18252808320839055603a909152902054610dc9908690612762565b6001600160a01b0387166000908152603a60205260409020558315610e7f576000610df460096122dc565b6001600160a01b0316632715805e88876040518363ffffffff1660e01b8152600401610e2192919061467b565b6020604051808303816000875af1158015610e40573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e649190614694565b90508060e46000828254610e789190614668565b9091555050505b8215610ec3576001600160a01b0386166000908152603c6020526040902054610ea9908690612762565b6001600160a01b0387166000908152603c60205260409020555b6001600160a01b0386166000818152603a6020908152604080832054815190815291820188905260019082015260608101919091528291907f54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68a9060800160405180910390a3505050505050565b600054600390610100900460ff16158015610f52575060005460ff8083169116105b610f6e5760405162461bcd60e51b8152600401610b20906146ad565b6000805461ffff191660ff831617610100179055610f8d600e83612779565b6000805461ff001916905560405160ff82168152600080516020614cb08339815191529060200160405180910390a15050565b6000610bfd8383612804565b600054610100900460ff1615808015610fec5750600054600160ff909116105b806110065750303b158015611006575060005460ff166001145b6110225760405162461bcd60e51b8152600401610b20906146ad565b6000805460ff191660011790558015611045576000805461ff0019166101001790555b61105060068e612779565b61105b60098d612779565b61106660078c612779565b61107160058b612779565b61107c600a8a612779565b6110858761282f565b61108e86612864565b61109785612899565b6110a084612690565b6110aa82356128f1565b6110b76020830135612926565b600183905580156110f0576000805461ff001916905560405160018152600080516020614cb08339815191529060200160405180910390a15b50505050505050505050505050565b60008061110b43611c55565b83111580611126575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b606060aa546001600160401b0381111561115957611159614711565b604051908082528060200260200182016040528015611182578160200160208202803683370190505b5090506000805b825181101561121657600081815260ab60205260409020546111b3906001600160a01b0316611918565b1561120e57600081815260ab60205260409020546001600160a01b031683836111db81614727565b9450815181106111ed576111ed6146fb565b60200260200101906001600160a01b031690816001600160a01b0316815250505b600101611189565b50815290565b611224612647565b610ad881612926565b6060816001600160401b0381111561124757611247614711565b604051908082528060200260200182016040528015611270578160200160208202803683370190505b50905060005b828110156112d7576112ad848483818110611293576112936146fb565b90506020020160208101906112a89190614247565b61295b565b8282815181106112bf576112bf6146fb565b91151560209283029190910190910152600101611276565b5092915050565b6112e6612647565b610ad881612864565b6112f7612967565b600061130233611918565b801561131457506113123361295b565b155b801561132e575061132c33611327610a34565b612804565b155b905060008061133d60076122dc565b604051630634f5b960e01b81528415156004820152600060248201526001600160a01b039190911690630634f5b9906044016080604051808303816000875af115801561138e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113b29190614740565b935050925050826113f7573460e460008282546113cf9190614668565b90915550506040513390600080516020614c9083398151915290610bcf903490600190614795565b336001600160a01b03167f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b134846040516114329291906147b9565b60405180910390a26000611444610a34565b905060006114528434614668565b9050600061271061146385846147c7565b61146d91906147f4565b9050600061147b8284614655565b905060008260e260008282546114919190614668565b909155505033600090815260386020908152604080832088845290915290205460ff161561158a5760006114c560066122dc565b6001600160a01b031663c6391fa26040518163ffffffff1660e01b8152600401608060405180830381865afa158015611502573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115269190614808565b9350505050612710818461153a91906147c7565b61154491906147f4565b91508160e460008282546115589190614668565b90915550506040513390600080516020614c9083398151915290611580908590600290614795565b60405180910390a2505b6115948183614655565b91506000806115a360096122dc565b6001600160a01b0316634530d2026040518163ffffffff1660e01b81526004016040805180830381865afa1580156115df573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611603919061483e565b33600090815260756020526040812060040154929450909250906116319061162b9084612987565b84612762565b9050600061271061164287846147c7565b61164c91906147f4565b33600090815260e06020526040812080549293508392909190611670908490614668565b90915550600090506116828288614655565b33600090815260e160205260408120805492935083929091906116a6908490614668565b909155505050505050505050505050505050565b6073546060906001600160401b038111156116d7576116d7614711565b60405190808252806020026020018201604052801561171057816020015b6116fd614178565b8152602001906001900390816116f55790505b50905060005b81518110156117db576075600060738381548110611736576117366146fb565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015282518390839081106117c8576117c86146fb565b6020908102919091010152600101611716565b5090565b600054600290610100900460ff16158015611801575060005460ff8083169116105b61181d5760405162461bcd60e51b8152600401610b20906146ad565b6000805461ffff191660ff831617610100179055607154611849906009906001600160a01b0316612779565b606f54611861906005906001600160a01b0316612779565b607054611879906006906001600160a01b0316612779565b606d54611891906007906001600160a01b0316612779565b60a8546118a990600a906001600160a01b0316612779565b607180546001600160a01b0319908116909155606f8054821690556070805482169055606d805482169055606e80548216905560a8805490911690556000805461ff001916905560405160ff82168152600080516020614cb0833981519152906020015b60405180910390a150565b6001600160a01b038116600090815260ac6020526040812054610a2e9060019060ff16600381111561194c5761194c61477f565b90612996565b61195a612647565b610ad8816128f1565b61196b612967565b61197443611bb1565b61199157604051636c74eecf60e01b815260040160405180910390fd5b61199a43611c55565b6119a5600254611c55565b106119c357604051632458f64160e01b815260040160405180910390fd5b4360025560006119d242612733565b905060006119e1826003541090565b905060006119ed611ee6565b9050606060006119fc43611c55565b90506000611a0b826001614668565b90506000611a17610a34565b9050611a2383866129c9565b8515611b4b57600080611a368388612b38565b91509150611a4683888484612d06565b611a4e612e10565b611a56612f64565b6000611a6260066122dc565b604051631da0214360e21b81529091506001600160a01b03821690637680850c90611a93908b908890600401614862565b600060405180830381600087803b158015611aad57600080fd5b505af1158015611ac1573d6000803e3d6000fd5b50505050611ace8a61308d565b8051919950975015611b39576040516303e1697b60e11b81526001600160a01b038216906307c2d2f690611b06908a90600401614464565b600060405180830381600087803b158015611b2057600080fd5b505af1158015611b34573d6000803e3d6000fd5b505050505b611b44436001614668565b6004555050505b611b5687838761321e565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce788604051611b8b911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b600060018054611bc19190614655565b600154611bce9084614884565b1492915050565b611bdd612647565b610ad88161282f565b611bee612647565b611bf78161349f565b611c018282612779565b5050565b600080611c10610a34565b9050610bfd8382612804565b6000806000611c2b8443610a44565b9250925092509193909250565b6001600160a01b0316600090815260746020526040902054151590565b6000610a2e826134cc565b6009611c6b816126e7565b6001600160a01b038316600090815260e860205260409020600181015415611ca65760405163057aab3160e31b815260040160405180910390fd5b6000611cb28442614668565b6001600160a01b0386166000908152607560205260409020909150611cd790826134e7565b6001600160a01b0385166000908152603b602052604080822083905560e554905163138ac02f60e11b81523391632715805e91611d18918a9160040161467b565b6020604051808303816000875af1158015611d37573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d5b9190614694565b90508015611e5857600060e65442611d739190614668565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038b1617905583865585018190559050611dd161356a565b6001600160a01b0388811660008181526075602052604090819020600201549051630a2fae5760e41b81526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b158015611e3e57600080fd5b505af1158015611e52573d6000803e3d6000fd5b50505050505b856001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c482604051611e9391815260200190565b60405180910390a2505050505050565b6000805b60aa548110156117db57600081815260ab6020526040902054611ed2906001600160a01b0316611918565b15611ede576001909101905b600101611ea7565b606060aa546001600160401b03811115611f0257611f02614711565b604051908082528060200260200182016040528015611f2b578160200160208202803683370190505b50905060005b81518110156117db57600081815260ab602052604090205482516001600160a01b03909116908190849084908110611f6b57611f6b6146fb565b6001600160a01b039092166020928302919091019091015250600101611f31565b60606073805480602002602001604051908101604052809291908181526020018280548015611fe457602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311611fc6575b5050505050905090565b611ff6612647565b6001600160a01b038216600090815260e8602052604090206001015415611c015760e7548060005b8281101561206d57846001600160a01b031660e78281548110612043576120436146fb565b6000918252602090912001546001600160a01b0316036120655780915061206d565b60010161201e565b5081810361207b5750505050565b6001600160a01b038416600090815260e86020526040902054801561223e576001600160a01b038516600090815260e86020526040812081815560019081019190915583111561213d5760e76120d2600185614655565b815481106120e2576120e26146fb565b60009182526020909120015460e780546001600160a01b03909216918490811061210e5761210e6146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061214e5761214e614898565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff191660011790556121a084826104b0613598565b156121f957836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e4836040516121ea91815260200190565b60405180910390a35050505050565b836001600160a01b0316856001600160a01b03167f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a183476040516121ea9291906147b9565b5050505050565b61224d612647565b610ad881612899565b6009612261816126e7565b61226a836135f8565b156122885760405163030081e760e01b815260040160405180910390fd5b6001600160a01b03831660009081526075602052604090206005810154156122c35760405163fab9167360e01b815260040160405180910390fd5b6122d6816122d18542614668565b6134e7565b50505050565b60006122e6613678565b600083600f8111156122fa576122fa61477f565b60ff1681526020810191909152604001600020546001600160a01b0316905080610d10578160405163409140df60e11b8152600401610b2091906148c2565b6009612344816126e7565b6001600160a01b0384166000908152607760205260409020541561237b57604051632f32dcdd60e11b815260040160405180910390fd5b61271082111561239e57604051631b8454a360e21b815260040160405180910390fd5b6076548310156123c15760405163fa0ae69360e01b815260040160405180910390fd5b6001600160a01b03841660009081526077602052604081209062015180856123e982426147f4565b6123f39190614668565b6123fd91906147c7565b808355600183018590556040519091506001600160a01b038716907f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f2190611e9390849088906147b9565b6009612452816126e7565b607354607254811061247757604051638616841b60e01b815260040160405180910390fd5b61248085611c38565b1561249e57604051638ad9cdf960e01b815260040160405180910390fd5b6127108311156124c157604051631b8454a360e21b815260040160405180910390fd5b60005b60735481101561257657600060756000607384815481106124e7576124e76146fb565b60009182526020808320909101546001600160a01b0390811684529083019390935260409091019020805490925081169089160361253a578760405163fc3d8c7560e01b8152600401610b20919061440c565b60028101546001600160a01b039081169087160361256d5785604051632d33a7e760e11b8152600401610b20919061440c565b506001016124c4565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b031990811687179091556075909352818420805484168d881690811782559181018054851687179055600281018054909416968b1696871790935560048301899055905191949093909290917f1ca451a9920472b99355a9cf74185bf017604a7849c113f020888ecec9db93669190a450505050505050565b61264f61356a565b6001600160a01b0316336001600160a01b031614610a0b576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b209291906148d0565b60018110156126b2576040516317b8970f60e01b815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a252679060200161190d565b6126f0816122dc565b6001600160a01b0316336001600160a01b031614610ad8576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610b20939291906148f1565b6000610a2e62015180836147f4565b6001600160a01b03919091166000908152603a6020526040902054101590565b6000818310156127725781610bfd565b5090919050565b80612782613678565b600084600f8111156127965761279661477f565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156127d7576127d761477f565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b59060200161190d565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab49060200161190d565b60a9548111156128bc576040516355408ce960e11b815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e9060200161190d565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a9060200161190d565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b9060200161190d565b6000610a2e8243612742565b334114610a0b576040516309f358fd60e01b815260040160405180910390fd5b60008183106127725781610bfd565b60008160038111156129aa576129aa61477f565b8360038111156129bc576129bc61477f565b1660ff1615159392505050565b60006129d5600e6122dc565b6001600160a01b031663468d24be84846040518363ffffffff1660e01b8152600401612a02929190614928565b600060405180830381865afa158015612a1f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052612a47919081019061499c565b905060008251600154612a5a91906147c7565b60e25490915060009081805b8651811015612b095784868281518110612a8257612a826146fb565b602002602001015184612a9591906147c7565b612a9f91906147f4565b93508360e36000898481518110612ab857612ab86146fb565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020016000206000828254612aef9190614668565b90915550612aff90508483614668565b9150600101612a66565b50612b148183614655565b60e46000828254612b259190614668565b9091555050600060e25550505050505050565b6000606060008084516001600160401b03811115612b5857612b58614711565b604051908082528060200260200182016040528015612b81578160200160208202803683370190505b50925060005b8551811015612cfc57858181518110612ba257612ba26146fb565b6020908102919091018101516001600160a01b0380821660009081526075909352604090922060020154909450169150612bdb8361295b565b158015612bef5750612bed8388612804565b155b15612c6d576001600160a01b038316600090815260e16020526040902054612c179086614668565b6001600160a01b038416600090815260e16020526040902054855191965090859083908110612c4857612c486146fb565b602002602001018181525050612c5e838361369c565b612c688383613764565b612cc4565b6001600160a01b038316600090815260e3602090815260408083205460e183528184205460e0909352922054612ca39190614668565b612cad9190614668565b60e46000828254612cbe9190614668565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e3909152812055600101612b87565b5050509250929050565b6000612d1260096122dc565b9050821561223e57612d24818461381f565b15612dcc5760405163566bce2360e11b81526001600160a01b0382169063acd79c4690612d5990879086908a90600401614a61565b600060405180830381600087803b158015612d7357600080fd5b505af1158015612d87573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d087838584604051612dbe93929190614a97565b60405180910390a1506122d6565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f8983858447604051612e019493929190614acc565b60405180910390a15050505050565b60e754600080805b838310156122d65760e78381548110612e3357612e336146fb565b60009182526020808320909101546001600160a01b031680835260e89091526040909120600181015491935091504210612f5957805460e48054600090612e7b908490614668565b90915550506001600160a01b038216600090815260e860205260408120818155600101819055612eaa85614b09565b9450841115612f215760e78481548110612ec657612ec66146fb565b60009182526020909120015460e780546001600160a01b039092169185908110612ef257612ef26146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480612f3257612f32614898565b600082815260209020810160001990810180546001600160a01b0319169055019055612e18565b600190920191612e18565b60e4548015610ad8576000612f7960076122dc565b600060e481905560408051600481526024810182526020810180516001600160e01b03166359f778df60e01b179052905192935090916001600160a01b038416918591612fc69190614b20565b60006040518083038185875af1925050503d8060008114613003576040519150601f19603f3d011682016040523d82523d6000602084013e613008565b606091505b50509050801561304d57816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051610bcf91815260200190565b816001600160a01b03167fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b738447604051610bcf9291906147b9565b505050565b6060806130998361387b565b905060006130a760096122dc565b6001600160a01b03166391f8723f60736040518263ffffffff1660e01b81526004016130d39190614b4f565b600060405180830381865afa1580156130f0573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613118919081019061499c565b90506000613126600a6122dc565b6001600160a01b031663520fce6260736040518263ffffffff1660e01b81526004016131529190614b4f565b600060405180830381865afa15801561316f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613197919081019061499c565b9050600061320660738054806020026020016040519081016040528092919081815260200182805480156131f457602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116131d6575b5050505050848460a95460ad54613d65565b9095509050613216858288613e2f565b505050915091565b600061322a60056122dc565b6001600160a01b031663fdadda8183613244436001614668565b6040518363ffffffff1660e01b8152600401613261929190614862565b600060405180830381865afa15801561327e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526132a69190810190614b93565b905060005b82518110156134585760008382815181106132c8576132c86146fb565b6020908102919091018101516001600160a01b0381166000908152603b9092526040822054909250421115906132fd83611918565b9050600061331584613310436001614668565b612742565b80613336575085858151811061332d5761332d6146fb565b60200260200101515b8061333e5750825b1590508115801561334c5750805b156133c7576001600160a01b038416600090815260ac602052604090205461338b9060019060ff1660038111156133855761338561477f565b90613f6f565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156133bd576133bd61477f565b0217905550613449565b8180156133d2575080155b15613449576001600160a01b038416600090815260ac60205260409020546134119060019060ff16600381111561340b5761340b61477f565b90613faa565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156134435761344361477f565b02179055505b846001019450505050506132ab565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b8261348461113d565b6040516134919190614464565b60405180910390a350505050565b806001600160a01b03163b600003610ad85780604051630bfc64a360e21b8152600401610b20919061440c565b6000600154826134dc91906147f4565b610a2e906001614668565b60018201546134fe906001600160a01b0316611c38565b61351b5760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e79060200160405180910390a25050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146135e8576040519150601f19603f3d011682016040523d82523d6000602084013e6135ed565b606091505b509095945050505050565b600080613605600a6122dc565b6001600160a01b03166341feed1c846040518263ffffffff1660e01b8152600401613630919061440c565b602060405180830381865afa15801561364d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906136719190614694565b1192915050565b7fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb90565b6001600160a01b038216600090815260e060205260409020548015613088576136c882826104b0613598565b1561371f57816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec8360405161371291815260200190565b60405180910390a3505050565b816001600160a01b0316836001600160a01b03167f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e83476040516137129291906147b9565b6001600160a01b038216600090815260e3602052604090205480156130885761379082826104b0613598565b156137da57816001600160a01b0316836001600160a01b03167f0c4d6a43fc8470dee97db74874b5685e412cc517d9bdecfde1623c5e835b18e48360405161371291815260200190565b816001600160a01b0316836001600160a01b03167f98697ee35f04a599a814432016fff3968c483d2d88dacb484926b9358f8e7cf983476040516137129291906147b9565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461386c576040519150601f19603f3d011682016040523d82523d6000602084013e613871565b606091505b5090949350505050565b6060600061388960096122dc565b90506000816001600160a01b031663af2454296040518163ffffffff1660e01b8152600401602060405180830381865afa1580156138cb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906138ef9190614694565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015613931573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906139559190614694565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b81526004016139869190614b4f565b600060405180830381865afa1580156139a3573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526139cb919081019061499c565b6073549091506000816001600160401b038111156139eb576139eb614711565b604051908082528060200260200182016040528015613a14578160200160208202803683370190505b50965060008060005b84831015613cb65760738381548110613a3857613a386146fb565b60009182526020808320909101546001600160a01b031680835260759091526040909120600681015488519294509092501515908890889086908110613a8057613a806146fb565b60200260200101511015613adc5780613ad7576000613a9f8a42614668565b600684018190556040518181529091506001600160a01b03851690600080516020614c708339815191529060200160405180910390a2505b613b1d565b8015613b1d578160060160009055826001600160a01b0316600080516020614c708339815191526000604051613b1491815260200190565b60405180910390a25b60008260050154600014158015613b38575042836005015411155b80613b5b57506001600160a01b038416600090815260e9602052604090205460ff165b905060008360060154600014158015613b78575042846006015411155b90508180613b835750805b15613c155788613b9289614b09565b98508881518110613ba557613ba56146fb565b6020026020010151898781518110613bbf57613bbf6146fb565b602002602001018181525050848d8880600101995081518110613be457613be46146fb565b60200260200101906001600160a01b031690816001600160a01b031681525050613c0d85613fe6565b505050613a1d565b6001600160a01b0385166000908152607760205260409020548015801590613c3d5750428111155b15613ca6576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b505060019094019350613a1d9050565b5050508087528015613d5a577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c9187604051613cf19190614464565b60405180910390a160405163e22d1c9d60e01b81526001600160a01b0387169063e22d1c9d90613d27908a908c90600401614862565b600060405180830381600087803b158015613d4157600080fd5b505af1158015613d55573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401613d89959493929190614c21565b60408051601f19818403018152919052602080820180516001600160e01b0316633bca0a8960e11b17905281518b519293506001929091600091613dcc916147c7565b613dd7906040614668565b90506020840181888483895afa613ded57600093505b503d613df857600092505b60208701965082613e1c57604051630fc2632160e01b815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa54811015613e8357600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b0319169055600101613e31565b5060005b82811015613ec357600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff19169055600101613e87565b5060005b82811015613f37576000848281518110613ee357613ee36146fb565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b031916909117905550600101613ec7565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051610bcf9190614464565b6000816003811115613f8357613f8361477f565b836003811115613f9557613f9561477f565b1760ff166003811115610bfd57610bfd61477f565b6000816003811115613fbe57613fbe61477f565b19836003811115613fd157613fd161477f565b1660ff166003811115610bfd57610bfd61477f565b6001600160a01b038116600090815260e960209081526040808320805460ff191690556074909152812054610ad891839190819003614023575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b0319908116825560018083018054831690556002830180548316905560038301805490921690915560048201859055600582018590556006909101849055607483528184208490556077909252822082815581018290556073805490916140ad91614655565b815481106140bd576140bd6146fb565b6000918252602090912001546001600160a01b03908116915083168114614140576001600160a01b0381166000908152607460205260409020829055607380548291908419908110614111576141116146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b607380548061415157614151614898565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6040805160e081018252600080825260208201819052918101829052606081018290526080810182905260a0810182905260c081019190915290565b6001600160a01b0381168114610ad857600080fd5b600080604083850312156141dc57600080fd5b82356141e7816141b4565b915060208301356141f7816141b4565b809150509250929050565b6000806040838503121561421557600080fd5b8235614220816141b4565b946020939093013593505050565b60006020828403121561424057600080fd5b5035919050565b60006020828403121561425957600080fd5b8135610bfd816141b4565b60018060a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b60e08101610a2e8284614264565b815181526020808301519082015260408101610a2e565b8015158114610ad857600080fd5b6000806000806080858703121561430157600080fd5b843561430c816141b4565b93506020850135925060408501359150606085013561432a816142dd565b939692955090935050565b8060408101831015610a2e57600080fd5b6000806000806000806000806000806000806101a08d8f03121561436957600080fd5b8c35614374816141b4565b9b5060208d0135614384816141b4565b9a5060408d0135614394816141b4565b995060608d01356143a4816141b4565b985060808d01356143b4816141b4565b975060a08d01356143c4816141b4565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d013591506143fa8e6101608f01614335565b90509295989b509295989b509295989b565b6001600160a01b0391909116815260200190565b600081518084526020808501945080840160005b838110156144595781516001600160a01b031687529582019590820190600101614434565b509495945050505050565b602081526000610bfd6020830184614420565b6000806020838503121561448a57600080fd5b82356001600160401b03808211156144a157600080fd5b818501915085601f8301126144b557600080fd5b8135818111156144c457600080fd5b8660208260051b85010111156144d957600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015614525578351151583529284019291840191600101614507565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b8181101561452557614560838551614264565b9284019260e0929092019160010161454d565b803560108110610d1057600080fd5b6000806040838503121561459557600080fd5b6141e783614573565b6000602082840312156145b057600080fd5b610bfd82614573565b6000806000606084860312156145ce57600080fd5b83356145d9816141b4565b95602085013595506040909401359392505050565b6000806000806080858703121561460457600080fd5b843561460f816141b4565b9350602085013561461f816141b4565b9250604085013561462f816141b4565b9396929550929360600135925050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610a2e57610a2e61463f565b80820180821115610a2e57610a2e61463f565b6001600160a01b03929092168252602082015260400190565b6000602082840312156146a657600080fd5b5051919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6000600182016147395761473961463f565b5060010190565b6000806000806080858703121561475657600080fd5b8451614761816142dd565b60208601516040870151606090970151919890975090945092505050565b634e487b7160e01b600052602160045260246000fd5b82815260408101600383106147ac576147ac61477f565b8260208301529392505050565b918252602082015260400190565b8082028115828204841417610a2e57610a2e61463f565b634e487b7160e01b600052601260045260246000fd5b600082614803576148036147de565b500490565b6000806000806080858703121561481e57600080fd5b505082516020840151604085015160609095015191969095509092509050565b6000806040838503121561485157600080fd5b505080516020909101519092909150565b6040815260006148756040830185614420565b90508260208301529392505050565b600082614893576148936147de565b500690565b634e487b7160e01b600052603160045260246000fd5b601081106148be576148be61477f565b9052565b60208101610a2e82846148ae565b6001600160e01b03198316815260408101600b83106147ac576147ac61477f565b6001600160e01b0319841681526060810161490f60208301856148ae565b6001600160a01b03929092166040919091015292915050565b8281526040602082015260006149416040830184614420565b949350505050565b604051601f8201601f191681016001600160401b038111828210171561497157614971614711565b604052919050565b60006001600160401b0382111561499257614992614711565b5060051b60200190565b600060208083850312156149af57600080fd5b82516001600160401b038111156149c557600080fd5b8301601f810185136149d657600080fd5b80516149e96149e482614979565b614949565b81815260059190911b82018301908381019087831115614a0857600080fd5b928401925b82841015614a2657835182529284019290840190614a0d565b979650505050505050565b600081518084526020808501945080840160005b8381101561445957815187529582019590820190600101614a45565b606081526000614a746060830186614420565b8281036020840152614a868186614a31565b915050826040830152949350505050565b838152606060208201526000614ab06060830185614420565b8281036040840152614ac28185614a31565b9695505050505050565b848152608060208201526000614ae56080830186614420565b8281036040840152614af78186614a31565b91505082606083015295945050505050565b600081614b1857614b1861463f565b506000190190565b6000825160005b81811015614b415760208186018101518583015201614b27565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b818110156145255783546001600160a01b031683526001938401939285019201614b6e565b60006020808385031215614ba657600080fd5b82516001600160401b03811115614bbc57600080fd5b8301601f81018513614bcd57600080fd5b8051614bdb6149e482614979565b81815260059190911b82018301908381019087831115614bfa57600080fd5b928401925b82841015614a26578351614c12816142dd565b82529284019290840190614bff565b60a081526000614c3460a0830188614420565b8281036020840152614c468188614a31565b90508281036040840152614c5a8187614a31565b6060840195909552505060800152939250505056fe88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342754042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498a164736f6c6343000811000a", + "deployedBytecode": "0x6080604052600436106102955760003560e01c806303827884146102ac57806304d971ab146102d557806306040618146103055780630f43a6771461031a57806311662dc2146103305780631196ab661461036d57806315b5ebde1461038d578063217f35c2146103ad57806323c65eb0146103c257806328bde1e1146103e25780632924de711461040f578063297a8fca1461042f5780632d784a98146104445780632f78204c146104715780633101cfcb1461049157806331a8aef5146104b1578063367ec12b146104d15780633b3159b6146104f1578063468c96ae1461050e57806349096d26146105455780634d8df063146105675780634de2b735146105875780634ee4d72b146105b45780634f2a693f146105c957806352091f17146105e95780635248184a146105f15780635cd8a76b14610613578063605239a114610628578063612c8d981461063d57806365244ece146106525780636558954f146106725780636611f84314610689578063690b7536146106a95780636aa1c2ef146106be57806372e46810146106d35780637593ff71146106db578063823a7b9c146106fb578063865e6fd31461071b578063873a5a701461073b57806387c891bd1461075b5780638d559c381461077057806396585fc214610784578063a0c3f2d2146107a4578063a3d545f5146107c4578063a66c0f77146107e4578063a7c2f119146107f9578063afc69d7314610819578063b7ab4db51461082e578063ba77b06c14610843578063c3c8b5d614610858578063c94aaa0214610878578063d09f1ab414610898578063dd716ad3146108ad578063de981f1b146108cd578063e5125a1d146108ed578063edb194bb1461090d578063eeb629a81461096f578063f883afaf14610984576102a4565b366102a4576102a26109a4565b005b6102a26109a4565b3480156102b857600080fd5b506102c26104b081565b6040519081526020015b60405180910390f35b3480156102e157600080fd5b506102f56102f03660046141c9565b610a0d565b60405190151581526020016102cc565b34801561031157600080fd5b506102c2610a34565b34801561032657600080fd5b506102c260aa5481565b34801561033c57600080fd5b5061035061034b366004614202565b610a44565b6040805193151584526020840192909252908201526060016102cc565b34801561037957600080fd5b506102a261038836600461422e565b610ac7565b34801561039957600080fd5b506102a26103a8366004614202565b610adb565b3480156103b957600080fd5b506102f5610bdc565b3480156103ce57600080fd5b506102f56103dd366004614202565b610bf1565b3480156103ee57600080fd5b506104026103fd366004614247565b610c04565b6040516102cc91906142b8565b34801561041b57600080fd5b506102f561042a366004614247565b610ca7565b34801561043b57600080fd5b506004546102c2565b34801561045057600080fd5b5061046461045f366004614247565b610cb3565b6040516102cc91906142c6565b34801561047d57600080fd5b506102a261048c3660046142eb565b610d15565b34801561049d57600080fd5b506102a26104ac366004614247565b610f30565b3480156104bd57600080fd5b506102f56104cc366004614202565b610fc0565b3480156104dd57600080fd5b506102a26104ec366004614346565b610fcc565b3480156104fd57600080fd5b5060685b6040516102cc919061440c565b34801561051a57600080fd5b5061052e61052936600461422e565b6110ff565b6040805192151583526020830191909152016102cc565b34801561055157600080fd5b5061055a61113d565b6040516102cc9190614464565b34801561057357600080fd5b506102a261058236600461422e565b61121c565b34801561059357600080fd5b506105a76105a2366004614477565b61122d565b6040516102cc91906144eb565b3480156105c057600080fd5b5060e4546102c2565b3480156105d557600080fd5b506102a26105e436600461422e565b6112de565b6102a26112ef565b3480156105fd57600080fd5b506106066116ba565b6040516102cc9190614531565b34801561061f57600080fd5b506102a26117df565b34801561063457600080fd5b506072546102c2565b34801561064957600080fd5b506076546102c2565b34801561065e57600080fd5b506102f561066d366004614247565b611918565b34801561067e57600080fd5b506102c26201518081565b34801561069557600080fd5b506102a26106a436600461422e565b611952565b3480156106b557600080fd5b5060e5546102c2565b3480156106ca57600080fd5b506001546102c2565b6102a2611963565b3480156106e757600080fd5b506102f56106f636600461422e565b611bb1565b34801561070757600080fd5b506102a261071636600461422e565b611bd5565b34801561072757600080fd5b506102a2610736366004614582565b611be6565b34801561074757600080fd5b506102f5610756366004614247565b611c05565b34801561076757600080fd5b506002546102c2565b34801561077c57600080fd5b506066610501565b34801561079057600080fd5b5061035061079f366004614247565b611c1c565b3480156107b057600080fd5b506102f56107bf366004614247565b611c38565b3480156107d057600080fd5b506102c26107df36600461422e565b611c55565b3480156107f057600080fd5b5060e6546102c2565b34801561080557600080fd5b506102a2610814366004614202565b611c60565b34801561082557600080fd5b506102c2611ea3565b34801561083a57600080fd5b5061055a611ee6565b34801561084f57600080fd5b5061055a611f8c565b34801561086457600080fd5b506102a26108733660046141c9565b611fee565b34801561088457600080fd5b506102a261089336600461422e565b612245565b3480156108a457600080fd5b5060a9546102c2565b3480156108b957600080fd5b506102a26108c8366004614202565b612256565b3480156108d957600080fd5b506105016108e836600461459e565b6122dc565b3480156108f957600080fd5b506102a26109083660046145b9565b612339565b34801561091957600080fd5b50610464610928366004614247565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b34801561097b57600080fd5b5060ad546102c2565b34801561099057600080fd5b506102a261099f3660046145ee565b612447565b6109ae60076122dc565b6001600160a01b0316336001600160a01b0316141580156109ea57506109d460096122dc565b6001600160a01b0316336001600160a01b031614155b15610a0b5760405160016234baed60e01b0319815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610a3f60035490565b905090565b6001600160a01b0382166000908152603a60205260408120548190819084811015610a7a57600080600093509350935050610ac0565b60019350610a888582614655565b610a93906001614668565b9250610a9e85611c55565b610aa782611c55565b610ab19190614655565b610abc906001614668565b9150505b9250925092565b610acf612647565b610ad881612690565b50565b6006610ae6816126e7565b6001600160a01b0383166000908152603c60205260409020544311610b2957826040516353e0424d60e01b8152600401610b20919061440c565b60405180910390fd5b6001600160a01b038316600081815260386020908152604080832086845282528083208054600160ff199182168117909255948452603783528184208785529092529091208054909216909155610b809043614655565b6001600160a01b0384166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e90610bcf9085815260200190565b60405180910390a2505050565b6000610a3f610bea42612733565b6003541090565b6000610bfd8383612742565b9392505050565b610c0c614178565b610c1582611c38565b610c325760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610a2e8243610bf1565b604080518082018252600080825260209182018190526001600160a01b038416815260e882528281208351808501909452805484526001015491830182905203610d10576040516370fdd4f160e11b815260040160405180910390fd5b919050565b6006610d20816126e7565b6000610d2a610a34565b6001600160a01b03871660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e090915291902054919250610d7891614668565b60e46000828254610d899190614668565b90915550506001600160a01b038616600090815260e06020908152604080832083905560e18252808320839055603a909152902054610dc9908690612762565b6001600160a01b0387166000908152603a60205260409020558315610e7f576000610df460096122dc565b6001600160a01b0316632715805e88876040518363ffffffff1660e01b8152600401610e2192919061467b565b6020604051808303816000875af1158015610e40573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610e649190614694565b90508060e46000828254610e789190614668565b9091555050505b8215610ec3576001600160a01b0386166000908152603c6020526040902054610ea9908690612762565b6001600160a01b0387166000908152603c60205260409020555b6001600160a01b0386166000818152603a6020908152604080832054815190815291820188905260019082015260608101919091528291907f54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68a9060800160405180910390a3505050505050565b600054600390610100900460ff16158015610f52575060005460ff8083169116105b610f6e5760405162461bcd60e51b8152600401610b20906146ad565b6000805461ffff191660ff831617610100179055610f8d600e83612779565b6000805461ff001916905560405160ff82168152600080516020614cb08339815191529060200160405180910390a15050565b6000610bfd8383612804565b600054610100900460ff1615808015610fec5750600054600160ff909116105b806110065750303b158015611006575060005460ff166001145b6110225760405162461bcd60e51b8152600401610b20906146ad565b6000805460ff191660011790558015611045576000805461ff0019166101001790555b61105060068e612779565b61105b60098d612779565b61106660078c612779565b61107160058b612779565b61107c600a8a612779565b6110858761282f565b61108e86612864565b61109785612899565b6110a084612690565b6110aa82356128f1565b6110b76020830135612926565b600183905580156110f0576000805461ff001916905560405160018152600080516020614cb08339815191529060200160405180910390a15b50505050505050505050505050565b60008061110b43611c55565b83111580611126575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b606060aa546001600160401b0381111561115957611159614711565b604051908082528060200260200182016040528015611182578160200160208202803683370190505b5090506000805b825181101561121657600081815260ab60205260409020546111b3906001600160a01b0316611918565b1561120e57600081815260ab60205260409020546001600160a01b031683836111db81614727565b9450815181106111ed576111ed6146fb565b60200260200101906001600160a01b031690816001600160a01b0316815250505b600101611189565b50815290565b611224612647565b610ad881612926565b6060816001600160401b0381111561124757611247614711565b604051908082528060200260200182016040528015611270578160200160208202803683370190505b50905060005b828110156112d7576112ad848483818110611293576112936146fb565b90506020020160208101906112a89190614247565b61295b565b8282815181106112bf576112bf6146fb565b91151560209283029190910190910152600101611276565b5092915050565b6112e6612647565b610ad881612864565b6112f7612967565b600061130233611918565b801561131457506113123361295b565b155b801561132e575061132c33611327610a34565b612804565b155b905060008061133d60076122dc565b604051630634f5b960e01b81528415156004820152600060248201526001600160a01b039190911690630634f5b9906044016080604051808303816000875af115801561138e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113b29190614740565b935050925050826113f7573460e460008282546113cf9190614668565b90915550506040513390600080516020614c9083398151915290610bcf903490600190614795565b336001600160a01b03167f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b134846040516114329291906147b9565b60405180910390a26000611444610a34565b905060006114528434614668565b9050600061271061146385846147c7565b61146d91906147f4565b9050600061147b8284614655565b905060008260e260008282546114919190614668565b909155505033600090815260386020908152604080832088845290915290205460ff161561158a5760006114c560066122dc565b6001600160a01b031663c6391fa26040518163ffffffff1660e01b8152600401608060405180830381865afa158015611502573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115269190614808565b9350505050612710818461153a91906147c7565b61154491906147f4565b91508160e460008282546115589190614668565b90915550506040513390600080516020614c9083398151915290611580908590600290614795565b60405180910390a2505b6115948183614655565b91506000806115a360096122dc565b6001600160a01b0316634530d2026040518163ffffffff1660e01b81526004016040805180830381865afa1580156115df573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611603919061483e565b33600090815260756020526040812060040154929450909250906116319061162b9084612987565b84612762565b9050600061271061164287846147c7565b61164c91906147f4565b33600090815260e06020526040812080549293508392909190611670908490614668565b90915550600090506116828288614655565b33600090815260e160205260408120805492935083929091906116a6908490614668565b909155505050505050505050505050505050565b6073546060906001600160401b038111156116d7576116d7614711565b60405190808252806020026020018201604052801561171057816020015b6116fd614178565b8152602001906001900390816116f55790505b50905060005b81518110156117db576075600060738381548110611736576117366146fb565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015282518390839081106117c8576117c86146fb565b6020908102919091010152600101611716565b5090565b600054600290610100900460ff16158015611801575060005460ff8083169116105b61181d5760405162461bcd60e51b8152600401610b20906146ad565b6000805461ffff191660ff831617610100179055607154611849906009906001600160a01b0316612779565b606f54611861906005906001600160a01b0316612779565b607054611879906006906001600160a01b0316612779565b606d54611891906007906001600160a01b0316612779565b60a8546118a990600a906001600160a01b0316612779565b607180546001600160a01b0319908116909155606f8054821690556070805482169055606d805482169055606e80548216905560a8805490911690556000805461ff001916905560405160ff82168152600080516020614cb0833981519152906020015b60405180910390a150565b6001600160a01b038116600090815260ac6020526040812054610a2e9060019060ff16600381111561194c5761194c61477f565b90612996565b61195a612647565b610ad8816128f1565b61196b612967565b61197443611bb1565b61199157604051636c74eecf60e01b815260040160405180910390fd5b61199a43611c55565b6119a5600254611c55565b106119c357604051632458f64160e01b815260040160405180910390fd5b4360025560006119d242612733565b905060006119e1826003541090565b905060006119ed611ee6565b9050606060006119fc43611c55565b90506000611a0b826001614668565b90506000611a17610a34565b9050611a2383866129c9565b8515611b4b57600080611a368388612b38565b91509150611a4683888484612d06565b611a4e612e10565b611a56612f64565b6000611a6260066122dc565b604051631da0214360e21b81529091506001600160a01b03821690637680850c90611a93908b908890600401614862565b600060405180830381600087803b158015611aad57600080fd5b505af1158015611ac1573d6000803e3d6000fd5b50505050611ace8a61308d565b8051919950975015611b39576040516303e1697b60e11b81526001600160a01b038216906307c2d2f690611b06908a90600401614464565b600060405180830381600087803b158015611b2057600080fd5b505af1158015611b34573d6000803e3d6000fd5b505050505b611b44436001614668565b6004555050505b611b5687838761321e565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce788604051611b8b911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b600060018054611bc19190614655565b600154611bce9084614884565b1492915050565b611bdd612647565b610ad88161282f565b611bee612647565b611bf78161349f565b611c018282612779565b5050565b600080611c10610a34565b9050610bfd8382612804565b6000806000611c2b8443610a44565b9250925092509193909250565b6001600160a01b0316600090815260746020526040902054151590565b6000610a2e826134cc565b6009611c6b816126e7565b6001600160a01b038316600090815260e860205260409020600181015415611ca65760405163057aab3160e31b815260040160405180910390fd5b6000611cb28442614668565b6001600160a01b0386166000908152607560205260409020909150611cd790826134e7565b6001600160a01b0385166000908152603b602052604080822083905560e554905163138ac02f60e11b81523391632715805e91611d18918a9160040161467b565b6020604051808303816000875af1158015611d37573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611d5b9190614694565b90508015611e5857600060e65442611d739190614668565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038b1617905583865585018190559050611dd161356a565b6001600160a01b0388811660008181526075602052604090819020600201549051630a2fae5760e41b81526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b158015611e3e57600080fd5b505af1158015611e52573d6000803e3d6000fd5b50505050505b856001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c482604051611e9391815260200190565b60405180910390a2505050505050565b6000805b60aa548110156117db57600081815260ab6020526040902054611ed2906001600160a01b0316611918565b15611ede576001909101905b600101611ea7565b606060aa546001600160401b03811115611f0257611f02614711565b604051908082528060200260200182016040528015611f2b578160200160208202803683370190505b50905060005b81518110156117db57600081815260ab602052604090205482516001600160a01b03909116908190849084908110611f6b57611f6b6146fb565b6001600160a01b039092166020928302919091019091015250600101611f31565b60606073805480602002602001604051908101604052809291908181526020018280548015611fe457602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311611fc6575b5050505050905090565b611ff6612647565b6001600160a01b038216600090815260e8602052604090206001015415611c015760e7548060005b8281101561206d57846001600160a01b031660e78281548110612043576120436146fb565b6000918252602090912001546001600160a01b0316036120655780915061206d565b60010161201e565b5081810361207b5750505050565b6001600160a01b038416600090815260e86020526040902054801561223e576001600160a01b038516600090815260e86020526040812081815560019081019190915583111561213d5760e76120d2600185614655565b815481106120e2576120e26146fb565b60009182526020909120015460e780546001600160a01b03909216918490811061210e5761210e6146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061214e5761214e614898565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff191660011790556121a084826104b0613598565b156121f957836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e4836040516121ea91815260200190565b60405180910390a35050505050565b836001600160a01b0316856001600160a01b03167f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a183476040516121ea9291906147b9565b5050505050565b61224d612647565b610ad881612899565b6009612261816126e7565b61226a836135f8565b156122885760405163030081e760e01b815260040160405180910390fd5b6001600160a01b03831660009081526075602052604090206005810154156122c35760405163fab9167360e01b815260040160405180910390fd5b6122d6816122d18542614668565b6134e7565b50505050565b60006122e6613678565b600083600f8111156122fa576122fa61477f565b60ff1681526020810191909152604001600020546001600160a01b0316905080610d10578160405163409140df60e11b8152600401610b2091906148c2565b6009612344816126e7565b6001600160a01b0384166000908152607760205260409020541561237b57604051632f32dcdd60e11b815260040160405180910390fd5b61271082111561239e57604051631b8454a360e21b815260040160405180910390fd5b6076548310156123c15760405163fa0ae69360e01b815260040160405180910390fd5b6001600160a01b03841660009081526077602052604081209062015180856123e982426147f4565b6123f39190614668565b6123fd91906147c7565b808355600183018590556040519091506001600160a01b038716907f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f2190611e9390849088906147b9565b6009612452816126e7565b607354607254811061247757604051638616841b60e01b815260040160405180910390fd5b61248085611c38565b1561249e57604051638ad9cdf960e01b815260040160405180910390fd5b6127108311156124c157604051631b8454a360e21b815260040160405180910390fd5b60005b60735481101561257657600060756000607384815481106124e7576124e76146fb565b60009182526020808320909101546001600160a01b0390811684529083019390935260409091019020805490925081169089160361253a578760405163fc3d8c7560e01b8152600401610b20919061440c565b60028101546001600160a01b039081169087160361256d5785604051632d33a7e760e11b8152600401610b20919061440c565b506001016124c4565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b031990811687179091556075909352818420805484168d881690811782559181018054851687179055600281018054909416968b1696871790935560048301899055905191949093909290917f1ca451a9920472b99355a9cf74185bf017604a7849c113f020888ecec9db93669190a450505050505050565b61264f61356a565b6001600160a01b0316336001600160a01b031614610a0b576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b209291906148d0565b60018110156126b2576040516317b8970f60e01b815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a252679060200161190d565b6126f0816122dc565b6001600160a01b0316336001600160a01b031614610ad8576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610b20939291906148f1565b6000610a2e62015180836147f4565b6001600160a01b03919091166000908152603a6020526040902054101590565b6000818310156127725781610bfd565b5090919050565b80612782613678565b600084600f8111156127965761279661477f565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156127d7576127d761477f565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b59060200161190d565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab49060200161190d565b60a9548111156128bc576040516355408ce960e11b815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e9060200161190d565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a9060200161190d565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b9060200161190d565b6000610a2e8243612742565b334114610a0b576040516309f358fd60e01b815260040160405180910390fd5b60008183106127725781610bfd565b60008160038111156129aa576129aa61477f565b8360038111156129bc576129bc61477f565b1660ff1615159392505050565b60006129d5600e6122dc565b6001600160a01b031663468d24be84846040518363ffffffff1660e01b8152600401612a02929190614928565b600060405180830381865afa158015612a1f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052612a47919081019061499c565b905060008251600154612a5a91906147c7565b60e25490915060009081805b8651811015612b095784868281518110612a8257612a826146fb565b602002602001015184612a9591906147c7565b612a9f91906147f4565b93508360e36000898481518110612ab857612ab86146fb565b60200260200101516001600160a01b03166001600160a01b031681526020019081526020016000206000828254612aef9190614668565b90915550612aff90508483614668565b9150600101612a66565b50612b148183614655565b60e46000828254612b259190614668565b9091555050600060e25550505050505050565b6000606060008084516001600160401b03811115612b5857612b58614711565b604051908082528060200260200182016040528015612b81578160200160208202803683370190505b50925060005b8551811015612cfc57858181518110612ba257612ba26146fb565b6020908102919091018101516001600160a01b0380821660009081526075909352604090922060020154909450169150612bdb8361295b565b158015612bef5750612bed8388612804565b155b15612c6d576001600160a01b038316600090815260e16020526040902054612c179086614668565b6001600160a01b038416600090815260e16020526040902054855191965090859083908110612c4857612c486146fb565b602002602001018181525050612c5e838361369c565b612c688383613764565b612cc4565b6001600160a01b038316600090815260e3602090815260408083205460e183528184205460e0909352922054612ca39190614668565b612cad9190614668565b60e46000828254612cbe9190614668565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e3909152812055600101612b87565b5050509250929050565b6000612d1260096122dc565b9050821561223e57612d24818461381f565b15612dcc5760405163566bce2360e11b81526001600160a01b0382169063acd79c4690612d5990879086908a90600401614a61565b600060405180830381600087803b158015612d7357600080fd5b505af1158015612d87573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d087838584604051612dbe93929190614a97565b60405180910390a1506122d6565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f8983858447604051612e019493929190614acc565b60405180910390a15050505050565b60e754600080805b838310156122d65760e78381548110612e3357612e336146fb565b60009182526020808320909101546001600160a01b031680835260e89091526040909120600181015491935091504210612f5957805460e48054600090612e7b908490614668565b90915550506001600160a01b038216600090815260e860205260408120818155600101819055612eaa85614b09565b9450841115612f215760e78481548110612ec657612ec66146fb565b60009182526020909120015460e780546001600160a01b039092169185908110612ef257612ef26146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e7805480612f3257612f32614898565b600082815260209020810160001990810180546001600160a01b0319169055019055612e18565b600190920191612e18565b60e4548015610ad8576000612f7960076122dc565b600060e481905560408051600481526024810182526020810180516001600160e01b03166359f778df60e01b179052905192935090916001600160a01b038416918591612fc69190614b20565b60006040518083038185875af1925050503d8060008114613003576040519150601f19603f3d011682016040523d82523d6000602084013e613008565b606091505b50509050801561304d57816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051610bcf91815260200190565b816001600160a01b03167fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b738447604051610bcf9291906147b9565b505050565b6060806130998361387b565b905060006130a760096122dc565b6001600160a01b03166391f8723f60736040518263ffffffff1660e01b81526004016130d39190614b4f565b600060405180830381865afa1580156130f0573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613118919081019061499c565b90506000613126600a6122dc565b6001600160a01b031663520fce6260736040518263ffffffff1660e01b81526004016131529190614b4f565b600060405180830381865afa15801561316f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052613197919081019061499c565b9050600061320660738054806020026020016040519081016040528092919081815260200182805480156131f457602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116131d6575b5050505050848460a95460ad54613d65565b9095509050613216858288613e2f565b505050915091565b600061322a60056122dc565b6001600160a01b031663fdadda8183613244436001614668565b6040518363ffffffff1660e01b8152600401613261929190614862565b600060405180830381865afa15801561327e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526132a69190810190614b93565b905060005b82518110156134585760008382815181106132c8576132c86146fb565b6020908102919091018101516001600160a01b0381166000908152603b9092526040822054909250421115906132fd83611918565b9050600061331584613310436001614668565b612742565b80613336575085858151811061332d5761332d6146fb565b60200260200101515b8061333e5750825b1590508115801561334c5750805b156133c7576001600160a01b038416600090815260ac602052604090205461338b9060019060ff1660038111156133855761338561477f565b90613f6f565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156133bd576133bd61477f565b0217905550613449565b8180156133d2575080155b15613449576001600160a01b038416600090815260ac60205260409020546134119060019060ff16600381111561340b5761340b61477f565b90613faa565b6001600160a01b038516600090815260ac60205260409020805460ff191660018360038111156134435761344361477f565b02179055505b846001019450505050506132ab565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b8261348461113d565b6040516134919190614464565b60405180910390a350505050565b806001600160a01b03163b600003610ad85780604051630bfc64a360e21b8152600401610b20919061440c565b6000600154826134dc91906147f4565b610a2e906001614668565b60018201546134fe906001600160a01b0316611c38565b61351b5760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e79060200160405180910390a25050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d80600081146135e8576040519150601f19603f3d011682016040523d82523d6000602084013e6135ed565b606091505b509095945050505050565b600080613605600a6122dc565b6001600160a01b03166341feed1c846040518263ffffffff1660e01b8152600401613630919061440c565b602060405180830381865afa15801561364d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906136719190614694565b1192915050565b7fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb90565b6001600160a01b038216600090815260e060205260409020548015613088576136c882826104b0613598565b1561371f57816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec8360405161371291815260200190565b60405180910390a3505050565b816001600160a01b0316836001600160a01b03167f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e83476040516137129291906147b9565b6001600160a01b038216600090815260e3602052604090205480156130885761379082826104b0613598565b156137da57816001600160a01b0316836001600160a01b03167f0c4d6a43fc8470dee97db74874b5685e412cc517d9bdecfde1623c5e835b18e48360405161371291815260200190565b816001600160a01b0316836001600160a01b03167f98697ee35f04a599a814432016fff3968c483d2d88dacb484926b9358f8e7cf983476040516137129291906147b9565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461386c576040519150601f19603f3d011682016040523d82523d6000602084013e613871565b606091505b5090949350505050565b6060600061388960096122dc565b90506000816001600160a01b031663af2454296040518163ffffffff1660e01b8152600401602060405180830381865afa1580156138cb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906138ef9190614694565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015613931573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906139559190614694565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b81526004016139869190614b4f565b600060405180830381865afa1580156139a3573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526139cb919081019061499c565b6073549091506000816001600160401b038111156139eb576139eb614711565b604051908082528060200260200182016040528015613a14578160200160208202803683370190505b50965060008060005b84831015613cb65760738381548110613a3857613a386146fb565b60009182526020808320909101546001600160a01b031680835260759091526040909120600681015488519294509092501515908890889086908110613a8057613a806146fb565b60200260200101511015613adc5780613ad7576000613a9f8a42614668565b600684018190556040518181529091506001600160a01b03851690600080516020614c708339815191529060200160405180910390a2505b613b1d565b8015613b1d578160060160009055826001600160a01b0316600080516020614c708339815191526000604051613b1491815260200190565b60405180910390a25b60008260050154600014158015613b38575042836005015411155b80613b5b57506001600160a01b038416600090815260e9602052604090205460ff165b905060008360060154600014158015613b78575042846006015411155b90508180613b835750805b15613c155788613b9289614b09565b98508881518110613ba557613ba56146fb565b6020026020010151898781518110613bbf57613bbf6146fb565b602002602001018181525050848d8880600101995081518110613be457613be46146fb565b60200260200101906001600160a01b031690816001600160a01b031681525050613c0d85613fe6565b505050613a1d565b6001600160a01b0385166000908152607760205260409020548015801590613c3d5750428111155b15613ca6576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b505060019094019350613a1d9050565b5050508087528015613d5a577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c9187604051613cf19190614464565b60405180910390a160405163e22d1c9d60e01b81526001600160a01b0387169063e22d1c9d90613d27908a908c90600401614862565b600060405180830381600087803b158015613d4157600080fd5b505af1158015613d55573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401613d89959493929190614c21565b60408051601f19818403018152919052602080820180516001600160e01b0316633bca0a8960e11b17905281518b519293506001929091600091613dcc916147c7565b613dd7906040614668565b90506020840181888483895afa613ded57600093505b503d613df857600092505b60208701965082613e1c57604051630fc2632160e01b815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa54811015613e8357600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b0319169055600101613e31565b5060005b82811015613ec357600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff19169055600101613e87565b5060005b82811015613f37576000848281518110613ee357613ee36146fb565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b031916909117905550600101613ec7565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051610bcf9190614464565b6000816003811115613f8357613f8361477f565b836003811115613f9557613f9561477f565b1760ff166003811115610bfd57610bfd61477f565b6000816003811115613fbe57613fbe61477f565b19836003811115613fd157613fd161477f565b1660ff166003811115610bfd57610bfd61477f565b6001600160a01b038116600090815260e960209081526040808320805460ff191690556074909152812054610ad891839190819003614023575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b0319908116825560018083018054831690556002830180548316905560038301805490921690915560048201859055600582018590556006909101849055607483528184208490556077909252822082815581018290556073805490916140ad91614655565b815481106140bd576140bd6146fb565b6000918252602090912001546001600160a01b03908116915083168114614140576001600160a01b0381166000908152607460205260409020829055607380548291908419908110614111576141116146fb565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b607380548061415157614151614898565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6040805160e081018252600080825260208201819052918101829052606081018290526080810182905260a0810182905260c081019190915290565b6001600160a01b0381168114610ad857600080fd5b600080604083850312156141dc57600080fd5b82356141e7816141b4565b915060208301356141f7816141b4565b809150509250929050565b6000806040838503121561421557600080fd5b8235614220816141b4565b946020939093013593505050565b60006020828403121561424057600080fd5b5035919050565b60006020828403121561425957600080fd5b8135610bfd816141b4565b60018060a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b60e08101610a2e8284614264565b815181526020808301519082015260408101610a2e565b8015158114610ad857600080fd5b6000806000806080858703121561430157600080fd5b843561430c816141b4565b93506020850135925060408501359150606085013561432a816142dd565b939692955090935050565b8060408101831015610a2e57600080fd5b6000806000806000806000806000806000806101a08d8f03121561436957600080fd5b8c35614374816141b4565b9b5060208d0135614384816141b4565b9a5060408d0135614394816141b4565b995060608d01356143a4816141b4565b985060808d01356143b4816141b4565b975060a08d01356143c4816141b4565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d013591506143fa8e6101608f01614335565b90509295989b509295989b509295989b565b6001600160a01b0391909116815260200190565b600081518084526020808501945080840160005b838110156144595781516001600160a01b031687529582019590820190600101614434565b509495945050505050565b602081526000610bfd6020830184614420565b6000806020838503121561448a57600080fd5b82356001600160401b03808211156144a157600080fd5b818501915085601f8301126144b557600080fd5b8135818111156144c457600080fd5b8660208260051b85010111156144d957600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015614525578351151583529284019291840191600101614507565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b8181101561452557614560838551614264565b9284019260e0929092019160010161454d565b803560108110610d1057600080fd5b6000806040838503121561459557600080fd5b6141e783614573565b6000602082840312156145b057600080fd5b610bfd82614573565b6000806000606084860312156145ce57600080fd5b83356145d9816141b4565b95602085013595506040909401359392505050565b6000806000806080858703121561460457600080fd5b843561460f816141b4565b9350602085013561461f816141b4565b9250604085013561462f816141b4565b9396929550929360600135925050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610a2e57610a2e61463f565b80820180821115610a2e57610a2e61463f565b6001600160a01b03929092168252602082015260400190565b6000602082840312156146a657600080fd5b5051919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6000600182016147395761473961463f565b5060010190565b6000806000806080858703121561475657600080fd5b8451614761816142dd565b60208601516040870151606090970151919890975090945092505050565b634e487b7160e01b600052602160045260246000fd5b82815260408101600383106147ac576147ac61477f565b8260208301529392505050565b918252602082015260400190565b8082028115828204841417610a2e57610a2e61463f565b634e487b7160e01b600052601260045260246000fd5b600082614803576148036147de565b500490565b6000806000806080858703121561481e57600080fd5b505082516020840151604085015160609095015191969095509092509050565b6000806040838503121561485157600080fd5b505080516020909101519092909150565b6040815260006148756040830185614420565b90508260208301529392505050565b600082614893576148936147de565b500690565b634e487b7160e01b600052603160045260246000fd5b601081106148be576148be61477f565b9052565b60208101610a2e82846148ae565b6001600160e01b03198316815260408101600b83106147ac576147ac61477f565b6001600160e01b0319841681526060810161490f60208301856148ae565b6001600160a01b03929092166040919091015292915050565b8281526040602082015260006149416040830184614420565b949350505050565b604051601f8201601f191681016001600160401b038111828210171561497157614971614711565b604052919050565b60006001600160401b0382111561499257614992614711565b5060051b60200190565b600060208083850312156149af57600080fd5b82516001600160401b038111156149c557600080fd5b8301601f810185136149d657600080fd5b80516149e96149e482614979565b614949565b81815260059190911b82018301908381019087831115614a0857600080fd5b928401925b82841015614a2657835182529284019290840190614a0d565b979650505050505050565b600081518084526020808501945080840160005b8381101561445957815187529582019590820190600101614a45565b606081526000614a746060830186614420565b8281036020840152614a868186614a31565b915050826040830152949350505050565b838152606060208201526000614ab06060830185614420565b8281036040840152614ac28185614a31565b9695505050505050565b848152608060208201526000614ae56080830186614420565b8281036040840152614af78186614a31565b91505082606083015295945050505050565b600081614b1857614b1861463f565b506000190190565b6000825160005b81811015614b415760208186018101518583015201614b27565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b818110156145255783546001600160a01b031683526001938401939285019201614b6e565b60006020808385031215614ba657600080fd5b82516001600160401b03811115614bbc57600080fd5b8301601f81018513614bcd57600080fd5b8051614bdb6149e482614979565b81815260059190911b82018301908381019087831115614bfa57600080fd5b928401925b82841015614a26578351614c12816142dd565b82529284019290840190614bff565b60a081526000614c3460a0830188614420565b8281036020840152614c468188614a31565b90508281036040840152614c5a8187614a31565b6060840195909552505060800152939250505056fe88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342754042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498a164736f6c6343000811000a" } \ No newline at end of file diff --git a/deployments/ronin-mainnet/SlashIndicatorLogic.json b/deployments/ronin-mainnet/SlashIndicatorLogic.json index 39df4c136..3c91cfc43 100644 --- a/deployments/ronin-mainnet/SlashIndicatorLogic.json +++ b/deployments/ronin-mainnet/SlashIndicatorLogic.json @@ -1,5 +1,5 @@ { - "address": "0x056500E6028048dB7FCA81Ac307008A9042605f3", + "address": "0x440BAF1c4B008EE4D617A83401f06AA80f5163E9", "abi": [ { "inputs": [], @@ -13,26 +13,127 @@ }, { "inputs": [], - "name": "ErrCallerMustBeGovernanceAdminContract", + "name": "ErrCallerMustBeJailedInTheCurrentPeriod", "type": "error" }, { "inputs": [], - "name": "ErrCallerMustBeMaintenanceContract", + "name": "ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [], + "name": "ErrEvidenceAlreadySubmitted", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInsufficientCreditScoreToBailOut", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidArguments", "type": "error" }, { "inputs": [], - "name": "ErrCallerMustBeRoninTrustedOrgContract", + "name": "ErrInvalidCreditScoreConfig", "type": "error" }, { "inputs": [], - "name": "ErrCallerMustBeValidatorContract", + "name": "ErrInvalidCutOffPercentageConfig", "type": "error" }, { "inputs": [], + "name": "ErrInvalidRatios", + "type": "error" + }, + { + "inputs": [], + "name": "ErrInvalidSlash", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidThreshold", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [], + "name": "ErrValidatorHasBailedOutPreviously", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, @@ -111,6 +212,25 @@ "name": "BridgeVotingSlashingConfigsUpdated", "type": "event" }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, { "anonymous": false, "inputs": [ @@ -191,38 +311,18 @@ "inputs": [ { "indexed": false, - "internalType": "uint8", - "name": "version", - "type": "uint8" - } - ], - "name": "Initialized", - "type": "event" - }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "MaintenanceContractUpdated", - "type": "event" - }, - { - "anonymous": false, - "inputs": [ + "internalType": "uint256", + "name": "slashFastFinalityAmount", + "type": "uint256" + }, { "indexed": false, - "internalType": "address", - "name": "", - "type": "address" + "internalType": "uint256", + "name": "fastFinalityJailUntilBlock", + "type": "uint256" } ], - "name": "RoninGovernanceAdminContractUpdated", + "name": "FastFinalitySlashingConfigsUpdated", "type": "event" }, { @@ -230,12 +330,12 @@ "inputs": [ { "indexed": false, - "internalType": "address", - "name": "", - "type": "address" + "internalType": "uint8", + "name": "version", + "type": "uint8" } ], - "name": "RoninTrustedOrganizationContractUpdated", + "name": "Initialized", "type": "event" }, { @@ -294,19 +394,6 @@ "name": "UnavailabilitySlashingConfigsUpdated", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "ValidatorContractUpdated", - "type": "event" - }, { "inputs": [ { @@ -445,6 +532,25 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -515,6 +621,24 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [], + "name": "getFastFinalitySlashingConfigs", + "outputs": [ + { + "internalType": "uint256", + "name": "slashFastFinalityAmount_", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "fastFinalityJailUntilBlock_", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -640,39 +764,39 @@ "type": "function" }, { - "inputs": [], - "name": "lastUnavailabilitySlashedBlock", - "outputs": [ + "inputs": [ { - "internalType": "uint256", - "name": "", - "type": "uint256" + "internalType": "address", + "name": "roninGovernanceAdminContract", + "type": "address" } ], - "stateMutability": "view", + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", "type": "function" }, { - "inputs": [], - "name": "maintenanceContract", - "outputs": [ + "inputs": [ { "internalType": "address", - "name": "", + "name": "profileContract", "type": "address" } ], - "stateMutability": "view", + "name": "initializeV3", + "outputs": [], + "stateMutability": "nonpayable", "type": "function" }, { "inputs": [], - "name": "precompileValidateDoubleSignAddress", + "name": "lastUnavailabilitySlashedBlock", "outputs": [ { - "internalType": "address", + "internalType": "uint256", "name": "", - "type": "address" + "type": "uint256" } ], "stateMutability": "view", @@ -680,7 +804,7 @@ }, { "inputs": [], - "name": "roninGovernanceAdminContract", + "name": "precompileValidateDoubleSignAddress", "outputs": [ { "internalType": "address", @@ -693,7 +817,7 @@ }, { "inputs": [], - "name": "roninTrustedOrganizationContract", + "name": "precompileValidateFastFinalityAddress", "outputs": [ { "internalType": "address", @@ -750,6 +874,24 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "setContract", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [ { @@ -804,38 +946,17 @@ { "inputs": [ { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setMaintenanceContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [ - { - "internalType": "address", - "name": "_addr", - "type": "address" - } - ], - "name": "setRoninGovernanceAdminContract", - "outputs": [], - "stateMutability": "nonpayable", - "type": "function" - }, - { - "inputs": [ + "internalType": "uint256", + "name": "slashAmount", + "type": "uint256" + }, { - "internalType": "address", - "name": "_addr", - "type": "address" + "internalType": "uint256", + "name": "jailUntilBlock", + "type": "uint256" } ], - "name": "setRoninTrustedOrganizationContract", + "name": "setFastFinalitySlashingConfigs", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -872,11 +993,11 @@ "inputs": [ { "internalType": "address", - "name": "_addr", + "name": "_consensusAddr", "type": "address" } ], - "name": "setValidatorContract", + "name": "slashBridgeVoting", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -887,9 +1008,19 @@ "internalType": "address", "name": "_consensusAddr", "type": "address" + }, + { + "internalType": "bytes", + "name": "_header1", + "type": "bytes" + }, + { + "internalType": "bytes", + "name": "_header2", + "type": "bytes" } ], - "name": "slashBridgeVoting", + "name": "slashDoubleSign", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -898,21 +1029,36 @@ "inputs": [ { "internalType": "address", - "name": "_consensusAddr", + "name": "consensusAddr", "type": "address" }, { "internalType": "bytes", - "name": "_header1", + "name": "voterPublicKey", "type": "bytes" }, { - "internalType": "bytes", - "name": "_header2", - "type": "bytes" + "internalType": "uint256", + "name": "targetBlockNumber", + "type": "uint256" + }, + { + "internalType": "bytes32[2]", + "name": "targetBlockHash", + "type": "bytes32[2]" + }, + { + "internalType": "bytes[][2]", + "name": "listOfPublicKey", + "type": "bytes[][2]" + }, + { + "internalType": "bytes[2]", + "name": "aggregatedSignature", + "type": "bytes[2]" } ], - "name": "slashDoubleSign", + "name": "slashFastFinality", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -947,56 +1093,43 @@ "outputs": [], "stateMutability": "nonpayable", "type": "function" - }, - { - "inputs": [], - "name": "validatorContract", - "outputs": [ - { - "internalType": "address", - "name": "", - "type": "address" - } - ], - "stateMutability": "view", - "type": "function" } ], - "transactionHash": "0x6ee00398d0a4bc945a69ac24f8d1b9564f3d268392dfa229794499d23cee5b5a", + "transactionHash": "0x18af3b627db40f02a1334376ed0cc8f588ae408e51b74a4b3f2d610db51e166e", "receipt": { "to": null, - "from": "0x0F68eDBE14C8f68481771016d7E2871d6a35DE11", - "contractAddress": "0x056500E6028048dB7FCA81Ac307008A9042605f3", - "transactionIndex": 3, - "gasUsed": "2626414", - "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000000000800000008000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0xccca0b80024cd79c72c8415efb705dab390b56820311eec112cf3fddecefb3a6", - "transactionHash": "0x6ee00398d0a4bc945a69ac24f8d1b9564f3d268392dfa229794499d23cee5b5a", + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x440BAF1c4B008EE4D617A83401f06AA80f5163E9", + "transactionIndex": 1, + "gasUsed": "2952593", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000001000000000000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x984e859f411836f06f8723b7dd6346cb2aa810162a6e3c2f45614f6f16e42605", + "transactionHash": "0x18af3b627db40f02a1334376ed0cc8f588ae408e51b74a4b3f2d610db51e166e", "logs": [ { - "transactionIndex": 3, - "blockNumber": 22984609, - "transactionHash": "0x6ee00398d0a4bc945a69ac24f8d1b9564f3d268392dfa229794499d23cee5b5a", - "address": "0x056500E6028048dB7FCA81Ac307008A9042605f3", + "transactionIndex": 1, + "blockNumber": 28538527, + "transactionHash": "0x18af3b627db40f02a1334376ed0cc8f588ae408e51b74a4b3f2d610db51e166e", + "address": "0x440BAF1c4B008EE4D617A83401f06AA80f5163E9", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 3, - "blockHash": "0xccca0b80024cd79c72c8415efb705dab390b56820311eec112cf3fddecefb3a6" + "logIndex": 1, + "blockHash": "0x984e859f411836f06f8723b7dd6346cb2aa810162a6e3c2f45614f6f16e42605" } ], - "blockNumber": 22984609, - "cumulativeGasUsed": "2912055", + "blockNumber": 28538527, + "cumulativeGasUsed": "3001469", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 3, - "solcInputHash": "cee8587b26e080f856978a2f78dd6e87", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallPrecompiled\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeGovernanceAdminContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeMaintenanceContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeRoninTrustedOrgContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeValidatorContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"usedCreditScore\",\"type\":\"uint256\"}],\"name\":\"BailedOut\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier1\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier2\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailDurationForMissingVotesRatioTier2\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"skipBridgeOperatorSlashingThreshold\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeVotingThreshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeVotingSlashAmount\",\"type\":\"uint256\"}],\"name\":\"BridgeVotingSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"gainCreditScore\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxCreditScore\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bailOutCostMultiplier\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"cutOffPercentageAfterBailout\",\"type\":\"uint256\"}],\"name\":\"CreditScoreConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"validators\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"creditScores\",\"type\":\"uint256[]\"}],\"name\":\"CreditScoresUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashDoubleSignAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"doubleSigningJailUntilBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"doubleSigningOffsetLimitBlock\",\"type\":\"uint256\"}],\"name\":\"DoubleSignSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"MaintenanceContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"RoninGovernanceAdminContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"RoninTrustedOrganizationContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"enum IBaseSlash.SlashType\",\"name\":\"slashType\",\"type\":\"uint8\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"Slashed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unavailabilityTier1Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unavailabilityTier2Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashAmountForUnavailabilityTier2Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailDurationForUnavailabilityTier2Threshold\",\"type\":\"uint256\"}],\"name\":\"UnavailabilitySlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"ValidatorContractUpdated\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"bailOut\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"checkBailedOutAtPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"}],\"name\":\"currentUnavailabilityIndicator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"}],\"name\":\"execResetCreditScores\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_tier\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"execSlashBridgeOperator\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeOperatorSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier1_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier2_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"jailDurationForMissingVotesRatioTier2_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"skipBridgeOperatorSlashingThreshold_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeVotingSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"bridgeVotingThreshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"bridgeVotingSlashAmount_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"}],\"name\":\"getCreditScore\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCreditScoreConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"gainCreditScore_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"maxCreditScore_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"bailOutCostMultiplier_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"cutOffPercentageAfterBailout_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getDoubleSignSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"slashDoubleSignAmount_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"doubleSigningJailUntilBlock_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"doubleSigningOffsetLimitBlock_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"}],\"name\":\"getManyCreditScores\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_resultList\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"getUnavailabilityIndicator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getUnavailabilitySlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"unavailabilityTier1Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"unavailabilityTier2Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"slashAmountForUnavailabilityTier2Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"jailDurationForUnavailabilityTier2Threshold_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__maintenanceContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninTrustedOrganizationContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninGovernanceAdminContract\",\"type\":\"address\"},{\"internalType\":\"uint256[4]\",\"name\":\"_bridgeOperatorSlashingConfigs\",\"type\":\"uint256[4]\"},{\"internalType\":\"uint256[2]\",\"name\":\"_bridgeVotingSlashingConfigs\",\"type\":\"uint256[2]\"},{\"internalType\":\"uint256[3]\",\"name\":\"_doubleSignSlashingConfigs\",\"type\":\"uint256[3]\"},{\"internalType\":\"uint256[4]\",\"name\":\"_unavailabilitySlashingConfigs\",\"type\":\"uint256[4]\"},{\"internalType\":\"uint256[4]\",\"name\":\"_creditScoreConfigs\",\"type\":\"uint256[4]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"lastUnavailabilitySlashedBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"maintenanceContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompileValidateDoubleSignAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"roninGovernanceAdminContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"roninTrustedOrganizationContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_ratioTier1\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_ratioTier2\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailDurationTier2\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_skipSlashingThreshold\",\"type\":\"uint256\"}],\"name\":\"setBridgeOperatorSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_slashAmount\",\"type\":\"uint256\"}],\"name\":\"setBridgeVotingSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_gainScore\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxScore\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_bailOutMultiplier\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cutOffPercentage\",\"type\":\"uint256\"}],\"name\":\"setCreditScoreConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_slashAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailUntilBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_offsetLimitBlock\",\"type\":\"uint256\"}],\"name\":\"setDoubleSignSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setMaintenanceContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setRoninGovernanceAdminContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setRoninTrustedOrganizationContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_tier1Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_tier2Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_slashAmountForTier2Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailDurationForTier2Threshold\",\"type\":\"uint256\"}],\"name\":\"setUnavailabilitySlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setValidatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"slashBridgeVoting\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_header1\",\"type\":\"bytes\"},{\"internalType\":\"bytes\",\"name\":\"_header2\",\"type\":\"bytes\"}],\"name\":\"slashDoubleSign\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validatorAddr\",\"type\":\"address\"}],\"name\":\"slashUnavailability\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"updateCreditScores\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallPrecompiled()\":[{\"details\":\"Error of call to precompile fails.\"}],\"ErrCallerMustBeGovernanceAdminContract()\":[{\"details\":\"Error of method caller must be goverance admin contract.\"}],\"ErrCallerMustBeMaintenanceContract()\":[{\"details\":\"Error of method caller must be maintenance contract.\"}],\"ErrCallerMustBeRoninTrustedOrgContract()\":[{\"details\":\"Error of method caller must be Ronin trusted org contract.\"}],\"ErrCallerMustBeValidatorContract()\":[{\"details\":\"Error of method caller must be validator contract.\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"bailOut(address)\":{\"details\":\"A slashed validator use this method to get out of jail. Requirements: - The `_consensusAddr` must be a validator. - Only validator's admin can call this method. Emits the event `BailedOut`.\"},\"checkBailedOutAtPeriod(address,uint256)\":{\"details\":\"Returns the whether the `_validator` has been bailed out at the `_period`.\"},\"currentUnavailabilityIndicator(address)\":{\"details\":\"Returns the current unavailability indicator of a block producer.\"},\"execResetCreditScores(address[])\":{\"details\":\"Resets the credit score for the revoked validators. Requirements: - Only validator contract can call this method. - This method is only called at the end of each period. Emits the event `CreditScoresUpdated`.\"},\"execSlashBridgeOperator(address,uint256,uint256)\":{\"details\":\"Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\",\"params\":{\"_tier\":\"The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1` and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2` Requirements: - Only validator contract can invoke this method. - Should be called only at the end of period. - Should be called only when there is slash of bridge operator. Emits the event `Slashed`.\"}},\"getBridgeOperatorSlashingConfigs()\":{\"details\":\"Returns the configs related to bridge operator slashing.\",\"returns\":{\"jailDurationForMissingVotesRatioTier2_\":\"The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\",\"missingVotesRatioTier1_\":\"The bridge reward will be deprecated if (s)he missed more than this ratio.\",\"missingVotesRatioTier2_\":\"The bridge reward and mining reward will be deprecated and the corresponding block producer will be put in jail if (s)he misses more than this ratio.\",\"skipBridgeOperatorSlashingThreshold_\":\"The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\"}},\"getBridgeVotingSlashingConfigs()\":{\"details\":\"Returns the configs related to bridge voting slashing.\",\"returns\":{\"bridgeVotingSlashAmount_\":\"The amount of RON to slash bridge voting.\",\"bridgeVotingThreshold_\":\"The threshold to slash when a trusted organization does not vote for bridge operators.\"}},\"getCreditScore(address)\":{\"details\":\"Returns the current credit score of the validator.\"},\"getCreditScoreConfigs()\":{\"details\":\"Returns the configs related to credit score.\",\"returns\":{\"bailOutCostMultiplier_\":\"The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\",\"cutOffPercentageAfterBailout_\":\"The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\",\"gainCreditScore_\":\"The score to gain per period.\",\"maxCreditScore_\":\"The max number of credit score that a validator can hold.\"}},\"getDoubleSignSlashingConfigs()\":{\"details\":\"Returns the configs related to block producer slashing.\",\"params\":{\"_doubleSigningOffsetLimitBlock\":\"The number of block that the current block is at most far from the double signing block.\"},\"returns\":{\"doubleSigningJailUntilBlock_\":\"The block number that the punished validator will be jailed until, due to double signing.\",\"slashDoubleSignAmount_\":\"The amount of RON to slash double sign.\"}},\"getManyCreditScores(address[])\":{\"details\":\"Returns the current credit score of a list of validators.\"},\"getUnavailabilityIndicator(address,uint256)\":{\"details\":\"Helper for CreditScore contract to query indicator of the validator.\"},\"getUnavailabilitySlashingConfigs()\":{\"details\":\"Returns the configs related to block producer slashing.\",\"returns\":{\"jailDurationForUnavailabilityTier2Threshold_\":\"The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\",\"slashAmountForUnavailabilityTier2Threshold_\":\"The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with tier-2 or tier-3.\",\"unavailabilityTier1Threshold_\":\"The mining reward will be deprecated, if (s)he missed more than this threshold. This threshold is applied for tier-1 and tier-3 slash.\",\"unavailabilityTier2Threshold_\":\" The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\"}},\"initialize(address,address,address,address,uint256[4],uint256[2],uint256[3],uint256[4],uint256[4])\":{\"details\":\"Initializes the contract storage.\"},\"maintenanceContract()\":{\"details\":\"Returns the maintenance contract.\"},\"precompileValidateDoubleSignAddress()\":{\"details\":\"Gets the address of the precompile of validating double sign evidence\"},\"roninGovernanceAdminContract()\":{\"details\":\"Returns the ronin governance admin contract.\"},\"roninTrustedOrganizationContract()\":{\"details\":\"Returns the ronin trusted organization contract.\"},\"setBridgeOperatorSlashingConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash bridge operators. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.\",\"params\":{\"_jailDurationTier2\":\"The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\",\"_ratioTier1\":\"The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map to 0%-100%.\",\"_ratioTier2\":\"The bridge reward and mining reward will be deprecated and the corresponding block producer will be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\",\"_skipSlashingThreshold\":\"The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\"}},\"setBridgeVotingSlashingConfigs(uint256,uint256)\":{\"details\":\"Sets the configs to slash bridge voting. Requirements: - The method caller is admin. Emits the event `BridgeVotingSlashingConfigsUpdated`.\",\"params\":{\"_slashAmount\":\"The amount of RON to slash bridge voting.\",\"_threshold\":\"The threshold to slash when a trusted organization does not vote for bridge operators.\"}},\"setCreditScoreConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to credit score. Requirements: - The method caller is admin. Emits the event `CreditScoreConfigsUpdated`.\",\"params\":{\"_bailOutMultiplier\":\"The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\",\"_cutOffPercentage\":\"The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\",\"_gainScore\":\"The score to gain per period.\",\"_maxScore\":\"The max number of credit score that a validator can hold.\"}},\"setDoubleSignSlashingConfigs(uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `DoubleSignSlashingConfigsUpdated`.\",\"params\":{\"_doubleSigningOffsetLimitBlock\":\"The number of block that the current block is at most far from the double signing block.\",\"_jailUntilBlock\":\"The block number that the punished validator will be jailed until, due to double signing.\",\"_slashAmount\":\"The amount of RON to slash double sign.\"}},\"setMaintenanceContract(address)\":{\"details\":\"Sets the maintenance contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `MaintenanceContractUpdated`.\"},\"setRoninGovernanceAdminContract(address)\":{\"details\":\"Sets the ronin governance admin contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninGovernanceAdminContractUpdated`.\"},\"setRoninTrustedOrganizationContract(address)\":{\"details\":\"Sets the ronin trusted organization contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninTrustedOrganizationContractUpdated`.\"},\"setUnavailabilitySlashingConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.\",\"params\":{\"_jailDurationForTier2Threshold\":\"The number of blocks to jail a block producer when (s)he is slashed tier-2.\",\"_slashAmountForTier2Threshold\":\"The amount of RON to deduct from self-staking of a block producer when (s)he is slashed tier-2.\",\"_tier1Threshold\":\"The mining reward will be deprecated, if (s)he missed more than this threshold.\",\"_tier2Threshold\":\"The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted self-staking if (s)he misses more than this threshold.\"}},\"setValidatorContract(address)\":{\"details\":\"Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`.\"},\"slashBridgeVoting(address)\":{\"details\":\"Slashes for bridge voter governance. Emits the event `Slashed`.\"},\"slashDoubleSign(address,bytes,bytes)\":{\"details\":\"Slashes for double signing. Requirements: - The method caller is coinbase. Emits the event `Slashed` if the double signing evidence of the two headers valid.\"},\"slashUnavailability(address)\":{\"details\":\"Slashes for unavailability by increasing the counter of block producer `_consensusAddr`. Requirements: - The method caller is coinbase. Emits the event `Slashed` when the threshold is reached.\"},\"updateCreditScores(address[],uint256)\":{\"details\":\"Updates the credit score for the validators. Requirements: - Only validator contract can call this method. - This method is only called at the end of each period. Emits the event `CreditScoresUpdated`.\"},\"validatorContract()\":{\"details\":\"Returns the validator contract.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/slash-indicator/SlashIndicator.sol\":\"SlashIndicator\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasMaintenanceContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasMaintenanceContract.sol\\\";\\nimport \\\"../../interfaces/IMaintenance.sol\\\";\\n\\ncontract HasMaintenanceContract is IHasMaintenanceContract, HasProxyAdmin {\\n IMaintenance internal _maintenanceContract;\\n\\n modifier onlyMaintenanceContract() {\\n if (maintenanceContract() != msg.sender) revert ErrCallerMustBeMaintenanceContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasMaintenanceContract\\n */\\n function maintenanceContract() public view override returns (address) {\\n return address(_maintenanceContract);\\n }\\n\\n /**\\n * @inheritdoc IHasMaintenanceContract\\n */\\n function setMaintenanceContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setMaintenanceContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the scheduled maintenance contract.\\n *\\n * Emits the event `MaintenanceContractUpdated`.\\n *\\n */\\n function _setMaintenanceContract(address _addr) internal {\\n _maintenanceContract = IMaintenance(_addr);\\n emit MaintenanceContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x117a29d878d44a20350df8ab539d34335713ba0f3b2c768a58124f61efb74357\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasRoninGovernanceAdminContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasRoninGovernanceAdminContract.sol\\\";\\nimport \\\"../../interfaces/IRoninGovernanceAdmin.sol\\\";\\n\\ncontract HasRoninGovernanceAdminContract is IHasRoninGovernanceAdminContract, HasProxyAdmin {\\n IRoninGovernanceAdmin internal _roninGovernanceAdminContract;\\n\\n modifier onlyRoninGovernanceAdminContract() {\\n if (roninGovernanceAdminContract() != msg.sender) revert ErrCallerMustBeGovernanceAdminContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasRoninGovernanceAdminContract\\n */\\n function roninGovernanceAdminContract() public view override returns (address) {\\n return address(_roninGovernanceAdminContract);\\n }\\n\\n /**\\n * @inheritdoc IHasRoninGovernanceAdminContract\\n */\\n function setRoninGovernanceAdminContract(address _addr) external override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setRoninGovernanceAdminContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the ronin governance admin contract.\\n *\\n * Emits the event `RoninGovernanceAdminContractUpdated`.\\n *\\n */\\n function _setRoninGovernanceAdminContract(address _addr) internal {\\n _roninGovernanceAdminContract = IRoninGovernanceAdmin(_addr);\\n emit RoninGovernanceAdminContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xbbb077c4c406c6b13d8602dd1bcac1031cd144e9c1965ec59311ded2b9fe8e3c\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasRoninTrustedOrganizationContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasRoninTrustedOrganizationContract.sol\\\";\\nimport \\\"../../interfaces/IRoninTrustedOrganization.sol\\\";\\n\\ncontract HasRoninTrustedOrganizationContract is IHasRoninTrustedOrganizationContract, HasProxyAdmin {\\n IRoninTrustedOrganization internal _roninTrustedOrganizationContract;\\n\\n modifier onlyRoninTrustedOrganizationContract() {\\n if (roninTrustedOrganizationContract() != msg.sender) revert ErrCallerMustBeRoninTrustedOrgContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasRoninTrustedOrganizationContract\\n */\\n function roninTrustedOrganizationContract() public view override returns (address) {\\n return address(_roninTrustedOrganizationContract);\\n }\\n\\n /**\\n * @inheritdoc IHasRoninTrustedOrganizationContract\\n */\\n function setRoninTrustedOrganizationContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setRoninTrustedOrganizationContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the ronin trusted organization contract.\\n *\\n * Emits the event `RoninTrustedOrganizationContractUpdated`.\\n *\\n */\\n function _setRoninTrustedOrganizationContract(address _addr) internal {\\n _roninTrustedOrganizationContract = IRoninTrustedOrganization(_addr);\\n emit RoninTrustedOrganizationContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0x951fd730f4853d8c932da5484ea093f3094c8186735b603d31fb53035c395751\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\n\\ncontract HasValidatorContract is IHasValidatorContract, HasProxyAdmin {\\n IRoninValidatorSet internal _validatorContract;\\n\\n modifier onlyValidatorContract() {\\n if (validatorContract() != msg.sender) revert ErrCallerMustBeValidatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function validatorContract() public view override returns (address) {\\n return address(_validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function setValidatorContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setValidatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function _setValidatorContract(address _addr) internal {\\n _validatorContract = IRoninValidatorSet(_addr);\\n emit ValidatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xf0a7c4c2165ede118c6ba219ee1a20d293d94049b18aa6fc86a2c48661eb654d\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/IMaintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IMaintenance {\\n struct Schedule {\\n uint256 from;\\n uint256 to;\\n uint256 lastUpdatedBlock;\\n uint256 requestTimestamp;\\n }\\n\\n /// @dev Emitted when a maintenance is scheduled.\\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\\n /// @dev Emitted when a schedule of maintenance is cancelled.\\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\\n /// @dev Emitted when the maintenance config is updated.\\n event MaintenanceConfigUpdated(\\n uint256 minMaintenanceDurationInBlock,\\n uint256 maxMaintenanceDurationInBlock,\\n uint256 minOffsetToStartSchedule,\\n uint256 maxOffsetToStartSchedule,\\n uint256 maxSchedules,\\n uint256 cooldownSecsToMaintain\\n );\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool);\\n\\n /**\\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\\n */\\n function checkScheduled(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr`\\n */\\n function checkCooldownEnds(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\\n */\\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\\n\\n /**\\n * @dev Returns the total of current schedules.\\n */\\n function totalSchedules() external view returns (uint256 _count);\\n\\n /**\\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The max duration is larger than the min duration.\\n * - The max offset is larger than the min offset.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external;\\n\\n /**\\n * @dev Returns the min duration for maintenance in block.\\n */\\n function minMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max duration for maintenance in block.\\n */\\n function maxMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the min block number that the schedule can start\\n */\\n function minOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the max block number that the schedule can start\\n */\\n function maxOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max number of scheduled maintenances.\\n */\\n function maxSchedules() external view returns (uint256);\\n\\n /**\\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\\n * - The total number of schedules is not larger than `maxSchedules()`.\\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\\n * - The end block is larger than the start block.\\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\\n * - The start block is at the start of an epoch.\\n * - The end block is at the end of an epoch.\\n *\\n * Emits the event `MaintenanceScheduled`.\\n *\\n */\\n function schedule(\\n address _consensusAddr,\\n uint256 _startedAtBlock,\\n uint256 _endedAtBlock\\n ) external;\\n\\n /**\\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\\n *\\n * Emits the event `MaintenanceScheduleCancelled`.\\n */\\n function cancelSchedule(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x4f06c8f3ad7ec8b863882c655ddf443675d557272445e51d8a1e1f3454089d09\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(uint256 _numerator, uint256 _denominator)\\n external\\n returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x10f3b360430e6d03773c9959f54cbed6fb0346069645c05b05ef50cfb19f3753\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninGovernanceAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"../libraries/BridgeOperatorsBallot.sol\\\";\\n\\ninterface IRoninGovernanceAdmin {\\n /// @dev Emitted when the bridge operators are approved.\\n event BridgeOperatorsApproved(uint256 _period, uint256 _epoch, address[] _operators);\\n /// @dev Emitted when an emergency exit poll is created.\\n event EmergencyExitPollCreated(\\n bytes32 _voteHash,\\n address _consensusAddr,\\n address _recipientAfterUnlockedFund,\\n uint256 _requestedAt,\\n uint256 _expiredAt\\n );\\n /// @dev Emitted when an emergency exit poll is approved.\\n event EmergencyExitPollApproved(bytes32 _voteHash);\\n /// @dev Emitted when an emergency exit poll is expired.\\n event EmergencyExitPollExpired(bytes32 _voteHash);\\n\\n /**\\n * @dev Returns the last voted block of the bridge voter.\\n */\\n function lastVotedBlock(address _bridgeVoter) external view returns (uint256);\\n\\n /**\\n * @dev Returns the synced bridge operator set info.\\n */\\n function lastSyncedBridgeOperatorSetInfo()\\n external\\n view\\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory _bridgeOperatorSetInfo);\\n\\n /**\\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\\n *\\n * Requirements:\\n * - The method caller is validator contract.\\n *\\n */\\n function createEmergencyExitPoll(\\n address _consensusAddr,\\n address _recipientAfterUnlockedFund,\\n uint256 _requestedAt,\\n uint256 _expiredAt\\n ) external;\\n}\\n\",\"keccak256\":\"0x1aa218f9a8cad8fa9f865c179b257aa8f2614e034100dedebdd352da9a7d96d9\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeights() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeights(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganizations() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x1edb7a3f5d340e7efc141cb8d94c5499954dec869f026d3998ad92cbc714d604\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasMaintenanceContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasMaintenanceContract is IHasContract {\\n /// @dev Emitted when the maintenance contract is updated.\\n event MaintenanceContractUpdated(address);\\n\\n /// @dev Error of method caller must be maintenance contract.\\n error ErrCallerMustBeMaintenanceContract();\\n\\n /**\\n * @dev Returns the maintenance contract.\\n */\\n function maintenanceContract() external view returns (address);\\n\\n /**\\n * @dev Sets the maintenance contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `MaintenanceContractUpdated`.\\n *\\n */\\n function setMaintenanceContract(address) external;\\n}\\n\",\"keccak256\":\"0x0a0ef6ba14e2929c7c8dda0642a7a831c9997d1b0d049eb83f64dfc21ff0e72e\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasRoninGovernanceAdminContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasRoninGovernanceAdminContract is IHasContract {\\n /// @dev Emitted when the ronin governance admin contract is updated.\\n event RoninGovernanceAdminContractUpdated(address);\\n\\n /// @dev Error of method caller must be goverance admin contract.\\n error ErrCallerMustBeGovernanceAdminContract();\\n\\n /**\\n * @dev Returns the ronin governance admin contract.\\n */\\n function roninGovernanceAdminContract() external view returns (address);\\n\\n /**\\n * @dev Sets the ronin governance admin contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `RoninGovernanceAdminContractUpdated`.\\n *\\n */\\n function setRoninGovernanceAdminContract(address) external;\\n}\\n\",\"keccak256\":\"0x7143a90b75a403f79f017c5350f816375d1ad5858ddbfa896c964ab9c8d4225a\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasRoninTrustedOrganizationContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasRoninTrustedOrganizationContract is IHasContract {\\n /// @dev Emitted when the ronin trusted organization contract is updated.\\n event RoninTrustedOrganizationContractUpdated(address);\\n\\n /// @dev Error of method caller must be Ronin trusted org contract.\\n error ErrCallerMustBeRoninTrustedOrgContract();\\n\\n /**\\n * @dev Returns the ronin trusted organization contract.\\n */\\n function roninTrustedOrganizationContract() external view returns (address);\\n\\n /**\\n * @dev Sets the ronin trusted organization contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `RoninTrustedOrganizationContractUpdated`.\\n *\\n */\\n function setRoninTrustedOrganizationContract(address) external;\\n}\\n\",\"keccak256\":\"0x7d0a0b1d658e9cf4d69f4934748e0a5c1d22183024d26927f5d621fc61aff0b2\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasValidatorContract is IHasContract {\\n /// @dev Emitted when the validator contract is updated.\\n event ValidatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be validator contract.\\n error ErrCallerMustBeValidatorContract();\\n\\n /**\\n * @dev Returns the validator contract.\\n */\\n function validatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function setValidatorContract(address) external;\\n}\\n\",\"keccak256\":\"0x35a715f123b0c5dc296d13583f946bef4e485201e122b5170988a7535f114559\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/IBaseSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseSlash {\\n enum SlashType {\\n UNKNOWN,\\n UNAVAILABILITY_TIER_1,\\n UNAVAILABILITY_TIER_2,\\n DOUBLE_SIGNING,\\n BRIDGE_VOTING,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\\n UNAVAILABILITY_TIER_3\\n }\\n\\n /// @dev Emitted when the validator is slashed.\\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\\n}\\n\",\"keccak256\":\"0x04d449f2852840566dfff4e3673929f6e9b8d9b5fc5b29744bf4f344dc7f9bc0\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ICreditScore.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICreditScore {\\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\\n event CreditScoreConfigsUpdated(\\n uint256 gainCreditScore,\\n uint256 maxCreditScore,\\n uint256 bailOutCostMultiplier,\\n uint256 cutOffPercentageAfterBailout\\n );\\n /// @dev Emitted the credit score of validators is updated.\\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\\n /// @dev Emitted when a validator bailed out of jail.\\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\\n\\n /**\\n * @dev Updates the credit score for the validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\\n\\n /**\\n * @dev Resets the credit score for the revoked validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function execResetCreditScores(address[] calldata _validators) external;\\n\\n /**\\n * @dev A slashed validator use this method to get out of jail.\\n *\\n * Requirements:\\n * - The `_consensusAddr` must be a validator.\\n * - Only validator's admin can call this method.\\n *\\n * Emits the event `BailedOut`.\\n *\\n */\\n function bailOut(address _consensusAddr) external;\\n\\n /**\\n * @dev Sets the configs to credit score.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CreditScoreConfigsUpdated`.\\n *\\n * @param _gainScore The score to gain per period.\\n * @param _maxScore The max number of credit score that a validator can hold.\\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to credit score.\\n *\\n * @return _gainCreditScore The score to gain per period.\\n * @return _maxCreditScore The max number of credit score that a validator can hold.\\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function getCreditScoreConfigs()\\n external\\n view\\n returns (\\n uint256 _gainCreditScore,\\n uint256 _maxCreditScore,\\n uint256 _bailOutCostMultiplier,\\n uint256 _cutOffPercentageAfterBailout\\n );\\n\\n /**\\n * @dev Returns the current credit score of the validator.\\n */\\n function getCreditScore(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the current credit score of a list of validators.\\n */\\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\\n\\n /**\\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0xd5364db88efb971f73aac569e27e5604758a123f28567af757b9933fdddd14f8\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeOperator is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\\n * `getBridgeOperatorSlashingConfigs` for param details.\\n */\\n event BridgeOperatorSlashingConfigsUpdated(\\n uint256 missingVotesRatioTier1,\\n uint256 missingVotesRatioTier2,\\n uint256 jailDurationForMissingVotesRatioTier2,\\n uint256 skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\\n *\\n * Requirements:\\n * - Only validator contract can invoke this method.\\n * - Should be called only at the end of period.\\n * - Should be called only when there is slash of bridge operator.\\n *\\n * Emits the event `Slashed`.\\n */\\n function execSlashBridgeOperator(\\n address _consensusAddr,\\n uint256 _tier,\\n uint256 _period\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to bridge operator slashing.\\n *\\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\\n * block producer will be put in jail if (s)he misses more than this ratio.\\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\\n * its bridge operator is slashed tier-2.\\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\\n * number of votes in the bridge is too small.\\n *\\n */\\n function getBridgeOperatorSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _missingVotesRatioTier1,\\n uint256 _missingVotesRatioTier2,\\n uint256 _jailDurationForMissingVotesRatioTier2,\\n uint256 _skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash bridge operators.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\\n * to 0%-100%.\\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\\n * slashed tier-2.\\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\\n * in the bridge is too small.\\n *\\n */\\n function setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x5c09ac11ead005bfa25ae58e970c441144849b14d58fd5f53fadc3b9be16e5d6\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeVoting is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\\n * details.\\n */\\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Slashes for bridge voter governance.\\n *\\n * Emits the event `Slashed`.\\n */\\n function slashBridgeVoting(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the configs related to bridge voting slashing.\\n *\\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\\n * operators.\\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function getBridgeVotingSlashingConfigs()\\n external\\n view\\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Sets the configs to slash bridge voting.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\\n *\\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\\n * @param _slashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\\n}\\n\",\"keccak256\":\"0x72c3bcfe3c49f946651caa3066bd5296d007871c9a56fa113e2d3c0f3db7eb99\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashDoubleSign is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\\n * for param details.\\n */\\n event DoubleSignSlashingConfigsUpdated(\\n uint256 slashDoubleSignAmount,\\n uint256 doubleSigningJailUntilBlock,\\n uint256 doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Slashes for double signing.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\\n */\\n function slashDoubleSign(\\n address _validatorAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\\n * double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function getDoubleSignSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _slashDoubleSignAmount,\\n uint256 _doubleSigningJailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\\n *\\n * @param _slashAmount The amount of RON to slash double sign.\\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n ) external;\\n}\\n\",\"keccak256\":\"0xe72708c42d468b0c40ffa0c72b3386899f11273e4149425aab490a78d5312222\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashIndicator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashDoubleSign.sol\\\";\\nimport \\\"./ISlashBridgeVoting.sol\\\";\\nimport \\\"./ISlashBridgeOperator.sol\\\";\\nimport \\\"./ISlashUnavailability.sol\\\";\\nimport \\\"./ICreditScore.sol\\\";\\n\\ninterface ISlashIndicator is\\n ISlashDoubleSign,\\n ISlashBridgeVoting,\\n ISlashBridgeOperator,\\n ISlashUnavailability,\\n ICreditScore\\n{}\\n\",\"keccak256\":\"0xe8b8fde3af614735cb304bc1eb82b05d65ede4df804b5d555787e5d5ecb95ec0\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashUnavailability.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashUnavailability is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\\n * for param details.\\n */\\n event UnavailabilitySlashingConfigsUpdated(\\n uint256 unavailabilityTier1Threshold,\\n uint256 unavailabilityTier2Threshold,\\n uint256 slashAmountForUnavailabilityTier2Threshold,\\n uint256 jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Returns the last block that a block producer is slashed for unavailability.\\n */\\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` when the threshold is reached.\\n *\\n */\\n function slashUnavailability(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the current unavailability indicator of a block producer.\\n */\\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\\n * producer when (s)he is slashed with tier-2 or tier-3.\\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\\n * slashed with tier-2 or tier-3.\\n *\\n */\\n function getUnavailabilitySlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _unavailabilityTier1Threshold,\\n uint256 _unavailabilityTier2Threshold,\\n uint256 _slashAmountForUnavailabilityTier2Threshold,\\n uint256 _jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\\n * self-staking if (s)he misses more than this threshold.\\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\\n * is slashed tier-2.\\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\\n *\\n */\\n function setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x92f7d8e9c6f80d4fedab80515c68db0a46cf4f8da143f8d766bf5f7582aa0a21\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/BridgeOperatorsBallot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\n\\nlibrary BridgeOperatorsBallot {\\n struct BridgeOperatorSet {\\n uint256 period;\\n uint256 epoch;\\n address[] operators;\\n }\\n\\n // keccak256(\\\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\\\");\\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\\n\\n /**\\n * @dev Verifies whether the ballot is valid or not.\\n *\\n * Requirements:\\n * - The ballot is not for an empty operator set.\\n * - The operator address list is in order.\\n *\\n */\\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\\n require(_ballot.operators.length > 0, \\\"BridgeOperatorsBallot: invalid array length\\\");\\n address _addr = _ballot.operators[0];\\n for (uint _i = 1; _i < _ballot.operators.length; _i++) {\\n require(_addr < _ballot.operators[_i], \\\"BridgeOperatorsBallot: invalid order of bridge operators\\\");\\n _addr = _ballot.operators[_i];\\n }\\n }\\n\\n /**\\n * @dev Returns hash of the ballot.\\n */\\n function hash(BridgeOperatorSet calldata _ballot) internal pure returns (bytes32) {\\n bytes32 _operatorsHash;\\n address[] memory _operators = _ballot.operators;\\n\\n assembly {\\n _operatorsHash := keccak256(add(_operators, 32), mul(mload(_operators), 32))\\n }\\n\\n return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\\n }\\n}\\n\",\"keccak256\":\"0x986425ebae2dcfcfa266c9ca825232ff300ec8ce796e8975da6714d87e921793\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(\\n uint256 c,\\n uint256 a,\\n uint256 b\\n ) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(\\n uint256 x1,\\n uint256 x2,\\n uint256 y1,\\n uint256 y2\\n ) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(\\n uint256 a,\\n uint256 b,\\n uint256 upperbound\\n ) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xf719e74bc39be7aceb4e5cc455260f81b2b21e83aa693e0b50c390c9909e08c4\",\"license\":\"UNLICENSED\"},\"contracts/precompile-usages/PCUValidateDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\\n /// @dev Gets the address of the precompile of validating double sign evidence\\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\\n return address(0x67);\\n }\\n\\n /**\\n * @dev Validates the two submitted block header if they are produced by the same address\\n *\\n * Note: The recover process is done by pre-compiled contract. This function is marked as\\n * virtual for implementing mocking contract for testing purpose.\\n */\\n function _pcValidateEvidence(\\n address _consensusAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) internal view virtual returns (bool _validEvidence) {\\n address _smc = precompileValidateDoubleSignAddress();\\n bool _success = true;\\n\\n bytes memory _payload = abi.encodeWithSignature(\\n \\\"validatingDoubleSignProof(address,bytes,bytes)\\\",\\n _consensusAddr,\\n _header1,\\n _header2\\n );\\n uint _payloadLength = _payload.length;\\n uint[1] memory _output;\\n\\n assembly {\\n let _payloadStart := add(_payload, 0x20)\\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\\n _success := 0\\n }\\n\\n if iszero(returndatasize()) {\\n _success := 0\\n }\\n }\\n\\n if (!_success) revert ErrCallPrecompiled();\\n return (_output[0] != 0);\\n }\\n}\\n\",\"keccak256\":\"0x9df5b8272e1cd963d776b94e29a69ba1139f0df7404b67c213b3c5ebe19e527b\",\"license\":\"MIT\"},\"contracts/precompile-usages/PrecompiledUsage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PrecompiledUsage {\\n /// @dev Error of call to precompile fails.\\n error ErrCallPrecompiled();\\n}\\n\",\"keccak256\":\"0x76facc3f3a8dd573c826bbbfedaa5cd8ef30963fbabd8c163c0c72b6efea5551\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/CreditScore.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/slash-indicator/ICreditScore.sol\\\";\\nimport \\\"../../extensions/collections/HasMaintenanceContract.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\n\\nabstract contract CreditScore is ICreditScore, HasValidatorContract, HasMaintenanceContract, PercentageConsumer {\\n /// @dev Mapping from validator address => period index => whether bailed out before\\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\\n /// @dev Mapping from validator address => credit score\\n mapping(address => uint256) internal _creditScore;\\n\\n /// @dev The max gained number of credit score per period.\\n uint256 internal _gainCreditScore;\\n /// @dev The max number of credit score that a validator can hold.\\n uint256 internal _maxCreditScore;\\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n uint256 internal _bailOutCostMultiplier;\\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\\n uint256 internal _cutOffPercentageAfterBailout;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function updateCreditScores(address[] calldata _validators, uint256 _period) external override onlyValidatorContract {\\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\\n\\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\\n bool[] memory _maintaineds = _maintenanceContract.checkManyMaintainedInBlockRange(\\n _validators,\\n _periodStartAtBlock,\\n block.number\\n );\\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\\n\\n for (uint _i = 0; _i < _validators.length; _i++) {\\n address _validator = _validators[_i];\\n\\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\\n bool _isJailedInPeriod = _jaileds[_i];\\n bool _isMaintainingInPeriod = _maintaineds[_i];\\n\\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\\n ? 0\\n : Math.subNonNegative(_gainCreditScore, _indicator);\\n\\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\\n _updatedCreditScores[_i] = _creditScore[_validator];\\n }\\n\\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\\n }\\n\\n function execResetCreditScores(address[] calldata _validators) external override onlyValidatorContract {\\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\\n for (uint _i = 0; _i < _validators.length; _i++) {\\n address _validator = _validators[_i];\\n delete _creditScore[_validator];\\n delete _updatedCreditScores[_i];\\n }\\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function bailOut(address _consensusAddr) external override {\\n require(\\n _validatorContract.isValidatorCandidate(_consensusAddr),\\n \\\"SlashIndicator: consensus address must be a validator candidate\\\"\\n );\\n require(\\n _validatorContract.isCandidateAdmin(_consensusAddr, msg.sender),\\n \\\"SlashIndicator: method caller must be a candidate admin\\\"\\n );\\n\\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\\n require(_isJailed, \\\"SlashIndicator: caller must be jailed in the current period\\\");\\n\\n uint256 _period = _validatorContract.currentPeriod();\\n require(!_checkBailedOutAtPeriod[_consensusAddr][_period], \\\"SlashIndicator: validator has bailed out previously\\\");\\n\\n uint256 _score = _creditScore[_consensusAddr];\\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\\n require(_score >= _cost, \\\"SlashIndicator: insufficient credit score to bail out\\\");\\n\\n _validatorContract.execBailOut(_consensusAddr, _period);\\n\\n _creditScore[_consensusAddr] -= _cost;\\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\\n emit BailedOut(_consensusAddr, _period, _cost);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) external override onlyAdmin {\\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\\n }\\n\\n /**\\n * @dev See `ISlashUnavailability`\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getCreditScoreConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 gainCreditScore_,\\n uint256 maxCreditScore_,\\n uint256 bailOutCostMultiplier_,\\n uint256 cutOffPercentageAfterBailout_\\n )\\n {\\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getCreditScore(address _validator) external view override returns (uint256) {\\n return _creditScore[_validator];\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getManyCreditScores(address[] calldata _validators)\\n public\\n view\\n override\\n returns (uint256[] memory _resultList)\\n {\\n _resultList = new uint256[](_validators.length);\\n\\n for (uint _i = 0; _i < _resultList.length; _i++) {\\n _resultList[_i] = _creditScore[_validators[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\\n return _checkBailedOutAtPeriod[_validator][_period];\\n }\\n\\n /**\\n * @dev See `SlashUnavailability`.\\n */\\n function _setUnavailabilityIndicator(\\n address _validator,\\n uint256 _period,\\n uint256 _indicator\\n ) internal virtual;\\n\\n /**\\n * @dev See `ICreditScore-setCreditScoreConfigs`.\\n */\\n function _setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) internal {\\n require(_gainScore <= _maxScore, \\\"CreditScore: invalid credit score config\\\");\\n require(_cutOffPercentage <= _MAX_PERCENTAGE, \\\"CreditScore: invalid cut off percentage config\\\");\\n\\n _gainCreditScore = _gainScore;\\n _maxCreditScore = _maxScore;\\n _bailOutCostMultiplier = _bailOutMultiplier;\\n _cutOffPercentageAfterBailout = _cutOffPercentage;\\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\\n }\\n}\\n\",\"keccak256\":\"0xe2a4b46731a462e0f71eda5a47b7b56bb1a77ca7e618e02f56acccc7bc759bab\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashBridgeOperator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../extensions/collections/HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\n\\nabstract contract SlashBridgeOperator is ISlashBridgeOperator, HasProxyAdmin, HasValidatorContract, PercentageConsumer {\\n /**\\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\\n * Values 0-10,000 map to 0%-100%.\\n */\\n uint256 internal _missingVotesRatioTier1;\\n /**\\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\\n * more than the ratio. Values 0-10,000 map to 0%-100%.\\n */\\n uint256 internal _missingVotesRatioTier2;\\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\\n uint256 internal _jailDurationForMissingVotesRatioTier2;\\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\\n uint256 internal _skipBridgeOperatorSlashingThreshold;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function getBridgeOperatorSlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 missingVotesRatioTier1_,\\n uint256 missingVotesRatioTier2_,\\n uint256 jailDurationForMissingVotesRatioTier2_,\\n uint256 skipBridgeOperatorSlashingThreshold_\\n )\\n {\\n return (\\n _missingVotesRatioTier1,\\n _missingVotesRatioTier2,\\n _jailDurationForMissingVotesRatioTier2,\\n _skipBridgeOperatorSlashingThreshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) external override onlyAdmin {\\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function execSlashBridgeOperator(\\n address _consensusAddr,\\n uint256 _tier,\\n uint256 _period\\n ) external onlyValidatorContract {\\n if (_tier == 1) {\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\\n } else if (_tier == 2) {\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\\n }\\n }\\n\\n /**\\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\\n */\\n function _setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) internal {\\n require(\\n _ratioTier1 <= _ratioTier2 && _ratioTier1 <= _MAX_PERCENTAGE && _ratioTier2 <= _MAX_PERCENTAGE,\\n \\\"SlashIndicator: invalid ratios\\\"\\n );\\n _missingVotesRatioTier1 = _ratioTier1;\\n _missingVotesRatioTier2 = _ratioTier2;\\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\\n }\\n}\\n\",\"keccak256\":\"0x80fc557349f05e584737a6ba80f87dff5940bcae770db6215d62fb435342957a\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashBridgeVoting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\\\";\\nimport \\\"../../extensions/collections/HasRoninTrustedOrganizationContract.sol\\\";\\nimport \\\"../../extensions/collections/HasRoninGovernanceAdminContract.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\n\\nabstract contract SlashBridgeVoting is\\n ISlashBridgeVoting,\\n HasValidatorContract,\\n HasRoninTrustedOrganizationContract,\\n HasRoninGovernanceAdminContract\\n{\\n /// @dev Mapping from validator address => period index => bridge voting slashed\\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\\n uint256 internal _bridgeVotingThreshold;\\n /// @dev The amount of RON to slash bridge voting.\\n uint256 internal _bridgeVotingSlashAmount;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\\n IRoninTrustedOrganization.TrustedOrganization memory _org = _roninTrustedOrganizationContract\\n .getTrustedOrganization(_consensusAddr);\\n uint256 _lastVotedBlock = Math.max(_roninGovernanceAdminContract.lastVotedBlock(_org.bridgeVoter), _org.addedBlock);\\n uint256 _period = _validatorContract.currentPeriod();\\n\\n require(\\n block.number - _lastVotedBlock > _bridgeVotingThreshold && !_bridgeVotingSlashed[_consensusAddr][_period],\\n \\\"SlashBridgeVoting: invalid slash\\\"\\n );\\n\\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function getBridgeVotingSlashingConfigs()\\n external\\n view\\n override\\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\\n {\\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\\n }\\n\\n /**\\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\\n */\\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\\n _bridgeVotingThreshold = _threshold;\\n _bridgeVotingSlashAmount = _slashAmount;\\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\\n }\\n}\\n\",\"keccak256\":\"0x63eaf9d93feda26b62b814d45926569c0657b0f0bf7d7a8244c6688e9850502c\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/slash-indicator/ISlashDoubleSign.sol\\\";\\nimport \\\"../../precompile-usages/PCUValidateDoubleSign.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\n\\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasValidatorContract, PCUValidateDoubleSign {\\n /// @dev The amount of RON to slash double sign.\\n uint256 internal _slashDoubleSignAmount;\\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\\n uint256 internal _doubleSigningJailUntilBlock;\\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\\n * This parameter is exposed for system transaction.\\n **/\\n uint256 internal _doubleSigningOffsetLimitBlock;\\n /// @dev Recording of submitted proof to prevent relay attack.\\n mapping(bytes32 => bool) _submittedEvidence;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[48] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function slashDoubleSign(\\n address _consensusAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) external override onlyAdmin {\\n bytes32 _header1Checksum = keccak256(_header1);\\n bytes32 _header2Checksum = keccak256(_header2);\\n\\n require(\\n !_submittedEvidence[_header1Checksum] && !_submittedEvidence[_header2Checksum],\\n \\\"SlashDoubleSign: evidence already submitted\\\"\\n );\\n\\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\\n uint256 _period = _validatorContract.currentPeriod();\\n _submittedEvidence[_header1Checksum] = true;\\n _submittedEvidence[_header2Checksum] = true;\\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\\n }\\n }\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function getDoubleSignSlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 slashDoubleSignAmount_,\\n uint256 doubleSigningJailUntilBlock_,\\n uint256 doubleSigningOffsetLimitBlock_\\n )\\n {\\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\\n }\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _offsetLimitBlock\\n ) external override onlyAdmin {\\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\\n }\\n\\n /**\\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\\n */\\n function _setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _offsetLimitBlock\\n ) internal {\\n _slashDoubleSignAmount = _slashAmount;\\n _doubleSigningJailUntilBlock = _jailUntilBlock;\\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\\n }\\n\\n /**\\n * @dev Returns whether the account `_addr` should be slashed or not.\\n */\\n function _shouldSlash(address _addr) internal view virtual returns (bool);\\n}\\n\",\"keccak256\":\"0xc0a3f6c59aa50b857e81fbb1ea1cb52ea631ddd1a0efb34b3619b1f4fd3a567a\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashIndicator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashIndicator.sol\\\";\\nimport \\\"./SlashDoubleSign.sol\\\";\\nimport \\\"./SlashBridgeVoting.sol\\\";\\nimport \\\"./SlashBridgeOperator.sol\\\";\\nimport \\\"./SlashUnavailability.sol\\\";\\nimport \\\"./CreditScore.sol\\\";\\n\\ncontract SlashIndicator is\\n ISlashIndicator,\\n SlashDoubleSign,\\n SlashBridgeVoting,\\n SlashBridgeOperator,\\n SlashUnavailability,\\n CreditScore,\\n Initializable\\n{\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n address __maintenanceContract,\\n address __roninTrustedOrganizationContract,\\n address __roninGovernanceAdminContract,\\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\\n uint256[2] calldata _bridgeVotingSlashingConfigs,\\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\\n uint256[3] calldata _doubleSignSlashingConfigs,\\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\\n uint256[4] calldata _unavailabilitySlashingConfigs,\\n // _creditScoreConfigs[0]: _gainCreditScore\\n // _creditScoreConfigs[1]: _maxCreditScore\\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\\n uint256[4] calldata _creditScoreConfigs\\n ) external initializer {\\n _setValidatorContract(__validatorContract);\\n _setMaintenanceContract(__maintenanceContract);\\n _setRoninTrustedOrganizationContract(__roninTrustedOrganizationContract);\\n _setRoninGovernanceAdminContract(__roninGovernanceAdminContract);\\n _setBridgeOperatorSlashingConfigs(\\n _bridgeOperatorSlashingConfigs[0],\\n _bridgeOperatorSlashingConfigs[1],\\n _bridgeOperatorSlashingConfigs[2],\\n _bridgeOperatorSlashingConfigs[3]\\n );\\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\\n _setDoubleSignSlashingConfigs(\\n _doubleSignSlashingConfigs[0],\\n _doubleSignSlashingConfigs[1],\\n _doubleSignSlashingConfigs[2]\\n );\\n _setUnavailabilitySlashingConfigs(\\n _unavailabilitySlashingConfigs[0],\\n _unavailabilitySlashingConfigs[1],\\n _unavailabilitySlashingConfigs[2],\\n _unavailabilitySlashingConfigs[3]\\n );\\n _setCreditScoreConfigs(\\n _creditScoreConfigs[0],\\n _creditScoreConfigs[1],\\n _creditScoreConfigs[2],\\n _creditScoreConfigs[3]\\n );\\n }\\n\\n /**\\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\\n */\\n function _setUnavailabilityIndicator(\\n address _validator,\\n uint256 _period,\\n uint256 _indicator\\n ) internal override(CreditScore, SlashUnavailability) {\\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\\n }\\n\\n /**\\n * @dev Helper for CreditScore contract to query indicator of the validator.\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period)\\n public\\n view\\n override(CreditScore, ISlashUnavailability, SlashUnavailability)\\n returns (uint256)\\n {\\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period)\\n public\\n view\\n override(CreditScore, ICreditScore, SlashUnavailability)\\n returns (bool)\\n {\\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\\n }\\n\\n /**\\n * @dev Sanity check the address to be slashed\\n */\\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\\n return\\n (msg.sender != _addr) &&\\n _validatorContract.isBlockProducer(_addr) &&\\n !_maintenanceContract.checkMaintained(_addr, block.number);\\n }\\n}\\n\",\"keccak256\":\"0x4e8ed6197fb42f52420fae0ebe09f46d891c5e6c56f4ee0fb8b3c2ffc879b648\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashUnavailability.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./CreditScore.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashUnavailability.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\n\\nabstract contract SlashUnavailability is ISlashUnavailability, HasValidatorContract {\\n /// @dev The last block that a validator is slashed for unavailability.\\n uint256 public lastUnavailabilitySlashedBlock;\\n /// @dev Mapping from validator address => period index => unavailability indicator.\\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\\n\\n /**\\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\\n */\\n uint256 internal _unavailabilityTier1Threshold;\\n /**\\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\\n */\\n uint256 internal _unavailabilityTier2Threshold;\\n /**\\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\\n * tier-2 or tier-3.\\n **/\\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n modifier oncePerBlock() {\\n require(\\n block.number > lastUnavailabilitySlashedBlock,\\n \\\"SlashIndicator: cannot slash a validator twice or slash more than one validator in one block\\\"\\n );\\n lastUnavailabilitySlashedBlock = block.number;\\n _;\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\\n require(msg.sender == block.coinbase, \\\"SlashUnavailability: method caller must be coinbase\\\");\\n if (!_shouldSlash(_validatorAddr)) {\\n // Should return instead of throwing error since this is a part of system transaction.\\n return;\\n }\\n\\n uint256 _period = _validatorContract.currentPeriod();\\n uint256 _count = ++_unavailabilityIndicator[_validatorAddr][_period];\\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\\n\\n if (_count == _unavailabilityTier2Threshold) {\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\\n _validatorContract.execSlash(\\n _validatorAddr,\\n _newJailedUntilBlock,\\n _slashAmountForUnavailabilityTier2Threshold,\\n false\\n );\\n } else if (_count == _unavailabilityTier1Threshold) {\\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\\n if (!_tier1SecondTime) {\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\\n } else {\\n /// Handles tier-3\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\\n _validatorContract.execSlash(\\n _validatorAddr,\\n _newJailedUntilBlock,\\n _slashAmountForUnavailabilityTier2Threshold,\\n true\\n );\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) external override onlyAdmin {\\n _setUnavailabilitySlashingConfigs(\\n _tier1Threshold,\\n _tier2Threshold,\\n _slashAmountForTier2Threshold,\\n _jailDurationForTier2Threshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function getUnavailabilitySlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 unavailabilityTier1Threshold_,\\n uint256 unavailabilityTier2Threshold_,\\n uint256 slashAmountForUnavailabilityTier2Threshold_,\\n uint256 jailDurationForUnavailabilityTier2Threshold_\\n )\\n {\\n return (\\n _unavailabilityTier1Threshold,\\n _unavailabilityTier2Threshold,\\n _slashAmountForUnavailabilityTier2Threshold,\\n _jailDurationForUnavailabilityTier2Threshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\\n return getUnavailabilityIndicator(_validator, _validatorContract.currentPeriod());\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period)\\n public\\n view\\n virtual\\n override\\n returns (uint256)\\n {\\n return _unavailabilityIndicator[_validator][_period];\\n }\\n\\n /**\\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\\n */\\n function _setUnavailabilityIndicator(\\n address _validator,\\n uint256 _period,\\n uint256 _indicator\\n ) internal virtual {\\n _unavailabilityIndicator[_validator][_period] = _indicator;\\n }\\n\\n /**\\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\\n */\\n function _setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) internal {\\n require(_unavailabilityTier1Threshold <= _unavailabilityTier2Threshold, \\\"SlashUnavailability: invalid threshold\\\");\\n _unavailabilityTier1Threshold = _tier1Threshold;\\n _unavailabilityTier2Threshold = _tier2Threshold;\\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\\n emit UnavailabilitySlashingConfigsUpdated(\\n _tier1Threshold,\\n _tier2Threshold,\\n _slashAmountForTier2Threshold,\\n _jailDurationForTier2Threshold\\n );\\n }\\n\\n /**\\n * @dev Returns whether the account `_addr` should be slashed or not.\\n */\\n function _shouldSlash(address _addr) internal view virtual returns (bool);\\n\\n /**\\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\\n}\\n\",\"keccak256\":\"0xf725c5d1992bad9a7e952bf1b2e0b0fec11858be35cf8d91ffc001fcf64b0e02\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x60806040523480156200001157600080fd5b506200001c62000022565b620000e7565b61011354610100900460ff1615620000905760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b6101135460ff9081161015620000e557610113805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b612e0e80620000f76000396000f3fe608060405234801561001057600080fd5b506004361061018b5760003560e01c806307c2d2f614610190578063082e7420146101a55780630e1512ac146101cb5780631079402a146101de5780631a697341146101fb5780631e90b2a01461020e57806323368e471461022157806329ddc3c01461023b5780633d48fd7d1461025e57806346fe93111461026f5780635511cde11461028257806362ffe6cb146102935780637680850c146102a65780637c2b55a0146102b9578063853af1b7146102c057806399103f7b146102d357806399439089146102e6578063b5e337de146102ee578063c008ce3914610301578063c2e524dc14610314578063c6391fa21461032f578063ccbb72ed14610340578063cdf64a7614610353578063cf39d13c14610366578063d1737e2714610379578063d1f992f71461038c578063d2cb215e1461039f578063d3dd2bdf146103b0578063d73e81b8146103d9578063df4b6ee0146103ec578063f1001e7814610410578063f562b3c414610430578063fd422cd014610439575b600080fd5b6101a361019e3660046125a2565b61044c565b005b6101b86101b33660046125f8565b610575565b6040519081526020015b60405180910390f35b6101a36101d9366004612615565b6105f6565b606d54606e54606f546070545b6040516101c29493929190612647565b6101a36102093660046125f8565b610649565b6101a361021c3660046126a3565b610947565b6036546001600160a01b03165b6040516101c29190612725565b61024e610249366004612739565b610bac565b60405190151581526020016101c2565b60a55460a65460a75460a8546101eb565b6101a361027d3660046125f8565b610bdb565b6035546001600160a01b031661022e565b6101b86102a1366004612739565b610c4a565b6101a36102b4366004612765565b610c73565b606761022e565b6101a36102ce3660046127b0565b610fb4565b6101a36102e13660046127e3565b610ffa565b61022e6111a4565b6101a36102fc3660046125f8565b6111b3565b6101a361030f3660046128a7565b61121f565b603854603954604080519283526020830191909152016101c2565b60dd5460de5460df5460e0546101eb565b6101a361034e366004612615565b6112c5565b6101a36103613660046125f8565b611309565b6101a36103743660046128dc565b611375565b6101a3610387366004612615565b6113b8565b6101a361039a3660046125f8565b6113fc565b606c546001600160a01b031661022e565b6101b86103be3660046125f8565b6001600160a01b0316600090815260dc602052604090205490565b6101a36103e73660046125f8565b61196d565b600154600254600354604080519384526020840192909252908201526060016101c2565b61042361041e3660046125a2565b6119d9565b6040516101c29190612943565b6101b860a35481565b6101a36104473660046125f8565b611aad565b336104556111a4565b6001600160a01b03161461047c57604051630e6444a160e31b815260040160405180910390fd5b6000816001600160401b0381111561049657610496612956565b6040519080825280602002602001820160405280156104bf578160200160208202803683370190505b50905060005b828110156105465760008484838181106104e1576104e161296c565b90506020020160208101906104f691906125f8565b6001600160a01b038116600090815260dc602052604081205583519091508390839081106105265761052661296c565b60200260200101600081525050808061053e90612998565b9150506104c5565b50600080516020612db9833981519152838383604051610568939291906129ef565b60405180910390a1505050565b60006105f08260008054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105cc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102a19190612a1f565b92915050565b6105fe611e91565b6001600160a01b0316336001600160a01b0316146106375760405162461bcd60e51b815260040161062e90612a38565b60405180910390fd5b61064384848484611ebf565b50505050565b610651611e91565b6001600160a01b0316336001600160a01b0316146106815760405162461bcd60e51b815260040161062e90612a38565b603554604051636db349d160e11b81526000916001600160a01b03169063db6693a2906106b2908590600401612725565b60a060405180830381865afa1580156106cf573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106f39190612aaa565b6036546040808301519051632623bd4f60e21b815292935060009261077a926001600160a01b03169163988ef53c9161072f9190600401612725565b602060405180830381865afa15801561074c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107709190612a1f565b8360800151611f83565b905060008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107d0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f49190612a1f565b6038549091506108048343612b31565b11801561083557506001600160a01b038416600090815260376020908152604080832084845290915290205460ff16155b6108815760405162461bcd60e51b815260206004820181905260248201527f536c617368427269646765566f74696e673a20696e76616c696420736c617368604482015260640161062e565b6001600160a01b038416600081815260376020908152604080832085845290915290819020805460ff1916600117905551600080516020612d99833981519152906108d0906004908590612b44565b60405180910390a260008054603954604051630bde081360e21b81526001600160a01b0390921692632f78204c9261090f928992918290600401612b70565b600060405180830381600087803b15801561092957600080fd5b505af115801561093d573d6000803e3d6000fd5b5050505050505050565b61094f611e91565b6001600160a01b0316336001600160a01b03161461097f5760405162461bcd60e51b815260040161062e90612a38565b60008484604051610991929190612b98565b60405180910390209050600083836040516109ad929190612b98565b604080519182900390912060008481526004602052919091205490915060ff161580156109e9575060008181526004602052604090205460ff16155b610a495760405162461bcd60e51b815260206004820152602b60248201527f536c617368446f75626c655369676e3a2065766964656e636520616c7265616460448201526a1e481cdd589b5a5d1d195960aa1b606482015260840161062e565b610a568787878787611f9a565b15610ba35760008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610aaf573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ad39190612a1f565b6000848152600460205260408082208054600160ff19918216811790925586845292829020805490931617909155519091506001600160a01b03891690600080516020612d9983398151915290610b2e906003908590612b44565b60405180910390a260005460025460018054604051630bde081360e21b81526001600160a01b0390941693632f78204c93610b6f938e939192600401612b70565b600060405180830381600087803b158015610b8957600080fd5b505af1158015610b9d573d6000803e3d6000fd5b50505050505b50505050505050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b610be3611e91565b6001600160a01b0316336001600160a01b031614610c135760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b600003610c3e57604051637bcd509160e01b815260040160405180910390fd5b610c4781612044565b50565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610bd4565b33610c7c6111a4565b6001600160a01b031614610ca357604051630e6444a160e31b815260040160405180910390fd5b60008060009054906101000a90046001600160a01b03166001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cf7573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d1b9190612a1f565b60008054604051634de2b73560e01b815292935090916001600160a01b0390911690634de2b73590610d539088908890600401612ba8565b600060405180830381865afa158015610d70573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610d989190810190612bd1565b606c5460405163ba30375560e01b81529192506000916001600160a01b039091169063ba30375590610dd4908990899088904390600401612c7d565b600060405180830381865afa158015610df1573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e199190810190612bd1565b90506000856001600160401b03811115610e3557610e35612956565b604051908082528060200260200182016040528015610e5e578160200160208202803683370190505b50905060005b86811015610f81576000888883818110610e8057610e8061296c565b9050602002016020810190610e9591906125f8565b90506000610ea38289610c4a565b90506000868481518110610eb957610eb961296c565b602002602001015190506000868581518110610ed757610ed761296c565b6020026020010151905060008280610eec5750815b610f0157610efc60dd548561209a565b610f04565b60005b6001600160a01b038616600090815260dc602052604090205460de54919250610f2e9183906120b4565b6001600160a01b038616600090815260dc602052604090208190558751889088908110610f5d57610f5d61296c565b60200260200101818152505050505050508080610f7990612998565b915050610e64565b50600080516020612db9833981519152878783604051610fa3939291906129ef565b60405180910390a150505050505050565b610fbc611e91565b6001600160a01b0316336001600160a01b031614610fec5760405162461bcd60e51b815260040161062e90612a38565b610ff682826120d1565b5050565b61011354610100900460ff161580801561101c575061011354600160ff909116105b806110375750303b15801561103757506101135460ff166001145b61109a5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b606482015260840161062e565b610113805460ff1916600117905580156110bf57610113805461ff0019166101001790555b6110c88a612118565b6110d189612044565b6110da88612163565b6110e3876121ae565b6110fc86356020880135604089013560608a0135611ebf565b61110b853560208701356120d1565b61111f8435602086013560408701356121f9565b6111388335602085013560408601356060870135612246565b61115182356020840135604085013560608601356122f3565b801561119857610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6000546001600160a01b031690565b6111bb611e91565b6001600160a01b0316336001600160a01b0316146111eb5760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b60000361121657604051637bcd509160e01b815260040160405180910390fd5b610c4781612163565b336112286111a4565b6001600160a01b03161461124f57604051630e6444a160e31b815260040160405180910390fd5b8160010361128e57826001600160a01b0316600080516020612d99833981519152600583604051611281929190612b44565b60405180910390a2505050565b816002036112c057826001600160a01b0316600080516020612d99833981519152600683604051611281929190612b44565b505050565b6112cd611e91565b6001600160a01b0316336001600160a01b0316146112fd5760405162461bcd60e51b815260040161062e90612a38565b610643848484846122f3565b611311611e91565b6001600160a01b0316336001600160a01b0316146113415760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b60000361136c57604051637bcd509160e01b815260040160405180910390fd5b610c4781612118565b61137d611e91565b6001600160a01b0316336001600160a01b0316146113ad5760405162461bcd60e51b815260040161062e90612a38565b6112c08383836121f9565b6113c0611e91565b6001600160a01b0316336001600160a01b0316146113f05760405162461bcd60e51b815260040161062e90612a38565b61064384848484612246565b600054604051635061f96960e11b81526001600160a01b039091169063a0c3f2d29061142c908490600401612725565b602060405180830381865afa158015611449573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061146d9190612ca4565b6114df5760405162461bcd60e51b815260206004820152603f60248201527f536c617368496e64696361746f723a20636f6e73656e7375732061646472657360448201527f73206d75737420626520612076616c696461746f722063616e64696461746500606482015260840161062e565b6000546040516304d971ab60e01b81526001600160a01b038381166004830152336024830152909116906304d971ab90604401602060405180830381865afa15801561152f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115539190612ca4565b6115bf5760405162461bcd60e51b815260206004820152603760248201527f536c617368496e64696361746f723a206d6574686f642063616c6c6572206d7560448201527639ba10313290309031b0b73234b230ba329030b236b4b760491b606482015260840161062e565b60008054604051634b2c2fe160e11b815282916001600160a01b0316906396585fc2906115f0908690600401612725565b606060405180830381865afa15801561160d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116319190612cbf565b9250509150816116a75760405162461bcd60e51b815260206004820152603b60248201527f536c617368496e64696361746f723a2063616c6c6572206d757374206265206a60448201527a185a5b1959081a5b881d1a194818dd5c9c995b9d081c195c9a5bd9602a1b606482015260840161062e565b60008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116fb573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061171f9190612a1f565b6001600160a01b038516600090815260db6020908152604080832084845290915290205490915060ff16156117b25760405162461bcd60e51b815260206004820152603360248201527f536c617368496e64696361746f723a2076616c696461746f7220686173206261604482015272696c6564206f75742070726576696f75736c7960681b606482015260840161062e565b6001600160a01b038416600090815260dc602052604081205460df549091906117db9085612cf4565b90508082101561184b5760405162461bcd60e51b815260206004820152603560248201527f536c617368496e64696361746f723a20696e73756666696369656e7420637265604482015274191a5d081cd8dbdc99481d1bc818985a5b081bdd5d605a1b606482015260840161062e565b600054604051630adaf5ef60e11b81526001600160a01b03909116906315b5ebde9061187d9089908790600401612d0b565b600060405180830381600087803b15801561189757600080fd5b505af11580156118ab573d6000803e3d6000fd5b505050506001600160a01b038616600090815260dc6020526040812080548392906118d7908490612b31565b90915550506001600160a01b038616600090815260a4602090815260408083208684529091528120556001600160a01b038616600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a2505050505050565b611975611e91565b6001600160a01b0316336001600160a01b0316146119a55760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b6000036119d057604051637bcd509160e01b815260040160405180910390fd5b610c47816121ae565b6060816001600160401b038111156119f3576119f3612956565b604051908082528060200260200182016040528015611a1c578160200160208202803683370190505b50905060005b8151811015611aa65760dc6000858584818110611a4157611a4161296c565b9050602002016020810190611a5691906125f8565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611a8957611a8961296c565b602090810291909101015280611a9e81612998565b915050611a22565b5092915050565b60a3544311611b495760405162461bcd60e51b815260206004820152605c60248201527f536c617368496e64696361746f723a2063616e6e6f7420736c6173682061207660448201527f616c696461746f72207477696365206f7220736c617368206d6f72652074686160648201527b6e206f6e652076616c696461746f7220696e206f6e6520626c6f636b60201b608482015260a40161062e565b4360a355334114611bb85760405162461bcd60e51b815260206004820152603360248201527f536c617368556e617661696c6162696c6974793a206d6574686f642063616c6c6044820152726572206d75737420626520636f696e6261736560681b606482015260840161062e565b611bc181612407565b15610c475760008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611c1a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c3e9190612a1f565b6001600160a01b038316600090815260a4602090815260408083208484529091528120805492935090918290611c7390612998565b91905081905590506000611c894360a85461250f565b905060a6548203611d3357836001600160a01b0316600080516020612d99833981519152600285604051611cbe929190612b44565b60405180910390a26000805460a754604051630bde081360e21b81526001600160a01b0390921692632f78204c92611cfc9289928792600401612b70565b600060405180830381600087803b158015611d1657600080fd5b505af1158015611d2a573d6000803e3d6000fd5b50505050610643565b60a5548203610643576000611d488585610bac565b905080611ded57846001600160a01b0316600080516020612d99833981519152600186604051611d79929190612b44565b60405180910390a260008054604051630bde081360e21b81526001600160a01b0390911691632f78204c91611db691899181908190600401612b70565b600060405180830381600087803b158015611dd057600080fd5b505af1158015611de4573d6000803e3d6000fd5b50505050611e8a565b846001600160a01b0316600080516020612d99833981519152600786604051611e17929190612b44565b60405180910390a260005460a754604051630bde081360e21b81526001600160a01b0390921691632f78204c91611e579189918791600190600401612b70565b600060405180830381600087803b158015611e7157600080fd5b505af1158015611e85573d6000803e3d6000fd5b505050505b5050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b828411158015611ed157506127108411155b8015611edf57506127108311155b611f2b5760405162461bcd60e51b815260206004820152601e60248201527f536c617368496e64696361746f723a20696e76616c696420726174696f730000604482015260640161062e565b606d849055606e839055606f82905560708190556040517fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b90611f75908690869086908690612647565b60405180910390a150505050565b600081831015611f935781610bd4565b5090919050565b6040516000906067906001908390611fbe908a908a908a908a908a90602401612d4d565b60408051601f198184030181529190526020810180516001600160e01b0316637fc3567760e01b1790528051909150611ff5612539565b602083016020828483895afa61200a57600094505b503d61201557600093505b8361203357604051630fc2632160e01b815260040160405180910390fd5b5115159a9950505050505050505050565b606c80546001600160a01b0319166001600160a01b0383161790556040517f31a33f126a5bae3c5bdf6cfc2cd6dcfffe2fe9634bdb09e21c44762993889e3b9061208f908390612725565b60405180910390a150565b60008183116120aa576000610bd4565b610bd48284612b31565b60006120c96120c38486612d85565b8361252a565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a910160405180910390a15050565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b68361699061208f908390612725565b603580546001600160a01b0319166001600160a01b0383161790556040517ffd6f5f93d69a07c593a09be0b208bff13ab4ffd6017df3b33433d63bdc59b4d79061208f908390612725565b603680546001600160a01b0319166001600160a01b0383161790556040517f9125df97e014f5cc4f107fd784acd35e8e2188ca7c2a0f7caa478365747c1c839061208f908390612725565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b90606001610568565b60a65460a55411156122a95760405162461bcd60e51b815260206004820152602660248201527f536c617368556e617661696c6162696c6974793a20696e76616c696420746872604482015265195cda1bdb1960d21b606482015260840161062e565b60a584905560a683905560a782905560a88190556040517f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa9890611f75908690869086908690612647565b828411156123545760405162461bcd60e51b815260206004820152602860248201527f43726564697453636f72653a20696e76616c6964206372656469742073636f726044820152676520636f6e66696760c01b606482015260840161062e565b6127108111156123bd5760405162461bcd60e51b815260206004820152602e60248201527f43726564697453636f72653a20696e76616c696420637574206f66662070657260448201526d63656e7461676520636f6e66696760901b606482015260840161062e565b60dd84905560de83905560df82905560e08190556040517fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b90611f75908690869086908690612647565b6000336001600160a01b0383161480159061248e5750600054604051633292276760e11b81526001600160a01b03909116906365244ece9061244d908590600401612725565b602060405180830381865afa15801561246a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061248e9190612ca4565b80156105f05750606c54604051630fbeb37f60e01b81526001600160a01b0390911690630fbeb37f906124c79085904390600401612d0b565b602060405180830381865afa1580156124e4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125089190612ca4565b1592915050565b600081600003612520576000610bd4565b610bd48284612d85565b6000818310611f935781610bd4565b60405180602001604052806001906020820280368337509192915050565b60008083601f84011261256957600080fd5b5081356001600160401b0381111561258057600080fd5b6020830191508360208260051b850101111561259b57600080fd5b9250929050565b600080602083850312156125b557600080fd5b82356001600160401b038111156125cb57600080fd5b6125d785828601612557565b90969095509350505050565b6001600160a01b0381168114610c4757600080fd5b60006020828403121561260a57600080fd5b8135610bd4816125e3565b6000806000806080858703121561262b57600080fd5b5050823594602084013594506040840135936060013592509050565b93845260208401929092526040830152606082015260800190565b60008083601f84011261267457600080fd5b5081356001600160401b0381111561268b57600080fd5b60208301915083602082850101111561259b57600080fd5b6000806000806000606086880312156126bb57600080fd5b85356126c6816125e3565b945060208601356001600160401b03808211156126e257600080fd5b6126ee89838a01612662565b9096509450604088013591508082111561270757600080fd5b5061271488828901612662565b969995985093965092949392505050565b6001600160a01b0391909116815260200190565b6000806040838503121561274c57600080fd5b8235612757816125e3565b946020939093013593505050565b60008060006040848603121561277a57600080fd5b83356001600160401b0381111561279057600080fd5b61279c86828701612557565b909790965060209590950135949350505050565b600080604083850312156127c357600080fd5b50508035926020909101359150565b80608081018310156105f057600080fd5b60008060008060008060008060006102a08a8c03121561280257600080fd5b893561280d816125e3565b985060208a013561281d816125e3565b975060408a013561282d816125e3565b965060608a013561283d816125e3565b955061284c8b60808c016127d2565b94506101408a018b81111561286057600080fd5b6101008b0194506101a08b018c81111561287957600080fd5b8194506128868d826127d2565b935050506128988b6102208c016127d2565b90509295985092959850929598565b6000806000606084860312156128bc57600080fd5b83356128c7816125e3565b95602085013595506040909401359392505050565b6000806000606084860312156128f157600080fd5b505081359360208301359350604090920135919050565b600081518084526020808501945080840160005b838110156129385781518752958201959082019060010161291c565b509495945050505050565b602081526000610bd46020830184612908565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016129aa576129aa612982565b5060010190565b8183526000602080850194508260005b858110156129385781356129d4816125e3565b6001600160a01b0316875295820195908201906001016129c1565b604081526000612a036040830185876129b1565b8281036020840152612a158185612908565b9695505050505050565b600060208284031215612a3157600080fd5b5051919050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b604051601f8201601f191681016001600160401b0381118282101715612aa257612aa2612956565b604052919050565b600060a08284031215612abc57600080fd5b60405160a081016001600160401b0381118282101715612ade57612ade612956565b6040528251612aec816125e3565b81526020830151612afc816125e3565b60208201526040830151612b0f816125e3565b6040820152606083810151908201526080928301519281019290925250919050565b818103818111156105f0576105f0612982565b6040810160088410612b6657634e487b7160e01b600052602160045260246000fd5b9281526020015290565b6001600160a01b03949094168452602084019290925260408301521515606082015260800190565b8183823760009101908152919050565b6020815260006120c96020830184866129b1565b80518015158114612bcc57600080fd5b919050565b60006020808385031215612be457600080fd5b82516001600160401b0380821115612bfb57600080fd5b818501915085601f830112612c0f57600080fd5b815181811115612c2157612c21612956565b8060051b9150612c32848301612a7a565b8181529183018401918481019088841115612c4c57600080fd5b938501935b83851015612c7157612c6285612bbc565b82529385019390850190612c51565b98975050505050505050565b606081526000612c916060830186886129b1565b6020830194909452506040015292915050565b600060208284031215612cb657600080fd5b610bd482612bbc565b600080600060608486031215612cd457600080fd5b612cdd84612bbc565b925060208401519150604084015190509250925092565b80820281158282048414176105f0576105f0612982565b6001600160a01b03929092168252602082015260400190565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b0386168152606060208201819052600090612d729083018688612d24565b8281036040840152612c71818587612d24565b808201808211156105f0576105f061298256fe607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d98c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c23480a2646970667358221220bbb9c8a18d14676fde8bc85398a11a7545f7fb8cce3da08ee81c2ef3b251559464736f6c63430008110033", - "deployedBytecode": "0x608060405234801561001057600080fd5b506004361061018b5760003560e01c806307c2d2f614610190578063082e7420146101a55780630e1512ac146101cb5780631079402a146101de5780631a697341146101fb5780631e90b2a01461020e57806323368e471461022157806329ddc3c01461023b5780633d48fd7d1461025e57806346fe93111461026f5780635511cde11461028257806362ffe6cb146102935780637680850c146102a65780637c2b55a0146102b9578063853af1b7146102c057806399103f7b146102d357806399439089146102e6578063b5e337de146102ee578063c008ce3914610301578063c2e524dc14610314578063c6391fa21461032f578063ccbb72ed14610340578063cdf64a7614610353578063cf39d13c14610366578063d1737e2714610379578063d1f992f71461038c578063d2cb215e1461039f578063d3dd2bdf146103b0578063d73e81b8146103d9578063df4b6ee0146103ec578063f1001e7814610410578063f562b3c414610430578063fd422cd014610439575b600080fd5b6101a361019e3660046125a2565b61044c565b005b6101b86101b33660046125f8565b610575565b6040519081526020015b60405180910390f35b6101a36101d9366004612615565b6105f6565b606d54606e54606f546070545b6040516101c29493929190612647565b6101a36102093660046125f8565b610649565b6101a361021c3660046126a3565b610947565b6036546001600160a01b03165b6040516101c29190612725565b61024e610249366004612739565b610bac565b60405190151581526020016101c2565b60a55460a65460a75460a8546101eb565b6101a361027d3660046125f8565b610bdb565b6035546001600160a01b031661022e565b6101b86102a1366004612739565b610c4a565b6101a36102b4366004612765565b610c73565b606761022e565b6101a36102ce3660046127b0565b610fb4565b6101a36102e13660046127e3565b610ffa565b61022e6111a4565b6101a36102fc3660046125f8565b6111b3565b6101a361030f3660046128a7565b61121f565b603854603954604080519283526020830191909152016101c2565b60dd5460de5460df5460e0546101eb565b6101a361034e366004612615565b6112c5565b6101a36103613660046125f8565b611309565b6101a36103743660046128dc565b611375565b6101a3610387366004612615565b6113b8565b6101a361039a3660046125f8565b6113fc565b606c546001600160a01b031661022e565b6101b86103be3660046125f8565b6001600160a01b0316600090815260dc602052604090205490565b6101a36103e73660046125f8565b61196d565b600154600254600354604080519384526020840192909252908201526060016101c2565b61042361041e3660046125a2565b6119d9565b6040516101c29190612943565b6101b860a35481565b6101a36104473660046125f8565b611aad565b336104556111a4565b6001600160a01b03161461047c57604051630e6444a160e31b815260040160405180910390fd5b6000816001600160401b0381111561049657610496612956565b6040519080825280602002602001820160405280156104bf578160200160208202803683370190505b50905060005b828110156105465760008484838181106104e1576104e161296c565b90506020020160208101906104f691906125f8565b6001600160a01b038116600090815260dc602052604081205583519091508390839081106105265761052661296c565b60200260200101600081525050808061053e90612998565b9150506104c5565b50600080516020612db9833981519152838383604051610568939291906129ef565b60405180910390a1505050565b60006105f08260008054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105cc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102a19190612a1f565b92915050565b6105fe611e91565b6001600160a01b0316336001600160a01b0316146106375760405162461bcd60e51b815260040161062e90612a38565b60405180910390fd5b61064384848484611ebf565b50505050565b610651611e91565b6001600160a01b0316336001600160a01b0316146106815760405162461bcd60e51b815260040161062e90612a38565b603554604051636db349d160e11b81526000916001600160a01b03169063db6693a2906106b2908590600401612725565b60a060405180830381865afa1580156106cf573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106f39190612aaa565b6036546040808301519051632623bd4f60e21b815292935060009261077a926001600160a01b03169163988ef53c9161072f9190600401612725565b602060405180830381865afa15801561074c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107709190612a1f565b8360800151611f83565b905060008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107d0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f49190612a1f565b6038549091506108048343612b31565b11801561083557506001600160a01b038416600090815260376020908152604080832084845290915290205460ff16155b6108815760405162461bcd60e51b815260206004820181905260248201527f536c617368427269646765566f74696e673a20696e76616c696420736c617368604482015260640161062e565b6001600160a01b038416600081815260376020908152604080832085845290915290819020805460ff1916600117905551600080516020612d99833981519152906108d0906004908590612b44565b60405180910390a260008054603954604051630bde081360e21b81526001600160a01b0390921692632f78204c9261090f928992918290600401612b70565b600060405180830381600087803b15801561092957600080fd5b505af115801561093d573d6000803e3d6000fd5b5050505050505050565b61094f611e91565b6001600160a01b0316336001600160a01b03161461097f5760405162461bcd60e51b815260040161062e90612a38565b60008484604051610991929190612b98565b60405180910390209050600083836040516109ad929190612b98565b604080519182900390912060008481526004602052919091205490915060ff161580156109e9575060008181526004602052604090205460ff16155b610a495760405162461bcd60e51b815260206004820152602b60248201527f536c617368446f75626c655369676e3a2065766964656e636520616c7265616460448201526a1e481cdd589b5a5d1d195960aa1b606482015260840161062e565b610a568787878787611f9a565b15610ba35760008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610aaf573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ad39190612a1f565b6000848152600460205260408082208054600160ff19918216811790925586845292829020805490931617909155519091506001600160a01b03891690600080516020612d9983398151915290610b2e906003908590612b44565b60405180910390a260005460025460018054604051630bde081360e21b81526001600160a01b0390941693632f78204c93610b6f938e939192600401612b70565b600060405180830381600087803b158015610b8957600080fd5b505af1158015610b9d573d6000803e3d6000fd5b50505050505b50505050505050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b610be3611e91565b6001600160a01b0316336001600160a01b031614610c135760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b600003610c3e57604051637bcd509160e01b815260040160405180910390fd5b610c4781612044565b50565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610bd4565b33610c7c6111a4565b6001600160a01b031614610ca357604051630e6444a160e31b815260040160405180910390fd5b60008060009054906101000a90046001600160a01b03166001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cf7573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d1b9190612a1f565b60008054604051634de2b73560e01b815292935090916001600160a01b0390911690634de2b73590610d539088908890600401612ba8565b600060405180830381865afa158015610d70573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610d989190810190612bd1565b606c5460405163ba30375560e01b81529192506000916001600160a01b039091169063ba30375590610dd4908990899088904390600401612c7d565b600060405180830381865afa158015610df1573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e199190810190612bd1565b90506000856001600160401b03811115610e3557610e35612956565b604051908082528060200260200182016040528015610e5e578160200160208202803683370190505b50905060005b86811015610f81576000888883818110610e8057610e8061296c565b9050602002016020810190610e9591906125f8565b90506000610ea38289610c4a565b90506000868481518110610eb957610eb961296c565b602002602001015190506000868581518110610ed757610ed761296c565b6020026020010151905060008280610eec5750815b610f0157610efc60dd548561209a565b610f04565b60005b6001600160a01b038616600090815260dc602052604090205460de54919250610f2e9183906120b4565b6001600160a01b038616600090815260dc602052604090208190558751889088908110610f5d57610f5d61296c565b60200260200101818152505050505050508080610f7990612998565b915050610e64565b50600080516020612db9833981519152878783604051610fa3939291906129ef565b60405180910390a150505050505050565b610fbc611e91565b6001600160a01b0316336001600160a01b031614610fec5760405162461bcd60e51b815260040161062e90612a38565b610ff682826120d1565b5050565b61011354610100900460ff161580801561101c575061011354600160ff909116105b806110375750303b15801561103757506101135460ff166001145b61109a5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b606482015260840161062e565b610113805460ff1916600117905580156110bf57610113805461ff0019166101001790555b6110c88a612118565b6110d189612044565b6110da88612163565b6110e3876121ae565b6110fc86356020880135604089013560608a0135611ebf565b61110b853560208701356120d1565b61111f8435602086013560408701356121f9565b6111388335602085013560408601356060870135612246565b61115182356020840135604085013560608601356122f3565b801561119857610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6000546001600160a01b031690565b6111bb611e91565b6001600160a01b0316336001600160a01b0316146111eb5760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b60000361121657604051637bcd509160e01b815260040160405180910390fd5b610c4781612163565b336112286111a4565b6001600160a01b03161461124f57604051630e6444a160e31b815260040160405180910390fd5b8160010361128e57826001600160a01b0316600080516020612d99833981519152600583604051611281929190612b44565b60405180910390a2505050565b816002036112c057826001600160a01b0316600080516020612d99833981519152600683604051611281929190612b44565b505050565b6112cd611e91565b6001600160a01b0316336001600160a01b0316146112fd5760405162461bcd60e51b815260040161062e90612a38565b610643848484846122f3565b611311611e91565b6001600160a01b0316336001600160a01b0316146113415760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b60000361136c57604051637bcd509160e01b815260040160405180910390fd5b610c4781612118565b61137d611e91565b6001600160a01b0316336001600160a01b0316146113ad5760405162461bcd60e51b815260040161062e90612a38565b6112c08383836121f9565b6113c0611e91565b6001600160a01b0316336001600160a01b0316146113f05760405162461bcd60e51b815260040161062e90612a38565b61064384848484612246565b600054604051635061f96960e11b81526001600160a01b039091169063a0c3f2d29061142c908490600401612725565b602060405180830381865afa158015611449573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061146d9190612ca4565b6114df5760405162461bcd60e51b815260206004820152603f60248201527f536c617368496e64696361746f723a20636f6e73656e7375732061646472657360448201527f73206d75737420626520612076616c696461746f722063616e64696461746500606482015260840161062e565b6000546040516304d971ab60e01b81526001600160a01b038381166004830152336024830152909116906304d971ab90604401602060405180830381865afa15801561152f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115539190612ca4565b6115bf5760405162461bcd60e51b815260206004820152603760248201527f536c617368496e64696361746f723a206d6574686f642063616c6c6572206d7560448201527639ba10313290309031b0b73234b230ba329030b236b4b760491b606482015260840161062e565b60008054604051634b2c2fe160e11b815282916001600160a01b0316906396585fc2906115f0908690600401612725565b606060405180830381865afa15801561160d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116319190612cbf565b9250509150816116a75760405162461bcd60e51b815260206004820152603b60248201527f536c617368496e64696361746f723a2063616c6c6572206d757374206265206a60448201527a185a5b1959081a5b881d1a194818dd5c9c995b9d081c195c9a5bd9602a1b606482015260840161062e565b60008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116fb573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061171f9190612a1f565b6001600160a01b038516600090815260db6020908152604080832084845290915290205490915060ff16156117b25760405162461bcd60e51b815260206004820152603360248201527f536c617368496e64696361746f723a2076616c696461746f7220686173206261604482015272696c6564206f75742070726576696f75736c7960681b606482015260840161062e565b6001600160a01b038416600090815260dc602052604081205460df549091906117db9085612cf4565b90508082101561184b5760405162461bcd60e51b815260206004820152603560248201527f536c617368496e64696361746f723a20696e73756666696369656e7420637265604482015274191a5d081cd8dbdc99481d1bc818985a5b081bdd5d605a1b606482015260840161062e565b600054604051630adaf5ef60e11b81526001600160a01b03909116906315b5ebde9061187d9089908790600401612d0b565b600060405180830381600087803b15801561189757600080fd5b505af11580156118ab573d6000803e3d6000fd5b505050506001600160a01b038616600090815260dc6020526040812080548392906118d7908490612b31565b90915550506001600160a01b038616600090815260a4602090815260408083208684529091528120556001600160a01b038616600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a2505050505050565b611975611e91565b6001600160a01b0316336001600160a01b0316146119a55760405162461bcd60e51b815260040161062e90612a38565b806001600160a01b03163b6000036119d057604051637bcd509160e01b815260040160405180910390fd5b610c47816121ae565b6060816001600160401b038111156119f3576119f3612956565b604051908082528060200260200182016040528015611a1c578160200160208202803683370190505b50905060005b8151811015611aa65760dc6000858584818110611a4157611a4161296c565b9050602002016020810190611a5691906125f8565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611a8957611a8961296c565b602090810291909101015280611a9e81612998565b915050611a22565b5092915050565b60a3544311611b495760405162461bcd60e51b815260206004820152605c60248201527f536c617368496e64696361746f723a2063616e6e6f7420736c6173682061207660448201527f616c696461746f72207477696365206f7220736c617368206d6f72652074686160648201527b6e206f6e652076616c696461746f7220696e206f6e6520626c6f636b60201b608482015260a40161062e565b4360a355334114611bb85760405162461bcd60e51b815260206004820152603360248201527f536c617368556e617661696c6162696c6974793a206d6574686f642063616c6c6044820152726572206d75737420626520636f696e6261736560681b606482015260840161062e565b611bc181612407565b15610c475760008060009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611c1a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c3e9190612a1f565b6001600160a01b038316600090815260a4602090815260408083208484529091528120805492935090918290611c7390612998565b91905081905590506000611c894360a85461250f565b905060a6548203611d3357836001600160a01b0316600080516020612d99833981519152600285604051611cbe929190612b44565b60405180910390a26000805460a754604051630bde081360e21b81526001600160a01b0390921692632f78204c92611cfc9289928792600401612b70565b600060405180830381600087803b158015611d1657600080fd5b505af1158015611d2a573d6000803e3d6000fd5b50505050610643565b60a5548203610643576000611d488585610bac565b905080611ded57846001600160a01b0316600080516020612d99833981519152600186604051611d79929190612b44565b60405180910390a260008054604051630bde081360e21b81526001600160a01b0390911691632f78204c91611db691899181908190600401612b70565b600060405180830381600087803b158015611dd057600080fd5b505af1158015611de4573d6000803e3d6000fd5b50505050611e8a565b846001600160a01b0316600080516020612d99833981519152600786604051611e17929190612b44565b60405180910390a260005460a754604051630bde081360e21b81526001600160a01b0390921691632f78204c91611e579189918791600190600401612b70565b600060405180830381600087803b158015611e7157600080fd5b505af1158015611e85573d6000803e3d6000fd5b505050505b5050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b828411158015611ed157506127108411155b8015611edf57506127108311155b611f2b5760405162461bcd60e51b815260206004820152601e60248201527f536c617368496e64696361746f723a20696e76616c696420726174696f730000604482015260640161062e565b606d849055606e839055606f82905560708190556040517fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b90611f75908690869086908690612647565b60405180910390a150505050565b600081831015611f935781610bd4565b5090919050565b6040516000906067906001908390611fbe908a908a908a908a908a90602401612d4d565b60408051601f198184030181529190526020810180516001600160e01b0316637fc3567760e01b1790528051909150611ff5612539565b602083016020828483895afa61200a57600094505b503d61201557600093505b8361203357604051630fc2632160e01b815260040160405180910390fd5b5115159a9950505050505050505050565b606c80546001600160a01b0319166001600160a01b0383161790556040517f31a33f126a5bae3c5bdf6cfc2cd6dcfffe2fe9634bdb09e21c44762993889e3b9061208f908390612725565b60405180910390a150565b60008183116120aa576000610bd4565b610bd48284612b31565b60006120c96120c38486612d85565b8361252a565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a910160405180910390a15050565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b68361699061208f908390612725565b603580546001600160a01b0319166001600160a01b0383161790556040517ffd6f5f93d69a07c593a09be0b208bff13ab4ffd6017df3b33433d63bdc59b4d79061208f908390612725565b603680546001600160a01b0319166001600160a01b0383161790556040517f9125df97e014f5cc4f107fd784acd35e8e2188ca7c2a0f7caa478365747c1c839061208f908390612725565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b90606001610568565b60a65460a55411156122a95760405162461bcd60e51b815260206004820152602660248201527f536c617368556e617661696c6162696c6974793a20696e76616c696420746872604482015265195cda1bdb1960d21b606482015260840161062e565b60a584905560a683905560a782905560a88190556040517f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa9890611f75908690869086908690612647565b828411156123545760405162461bcd60e51b815260206004820152602860248201527f43726564697453636f72653a20696e76616c6964206372656469742073636f726044820152676520636f6e66696760c01b606482015260840161062e565b6127108111156123bd5760405162461bcd60e51b815260206004820152602e60248201527f43726564697453636f72653a20696e76616c696420637574206f66662070657260448201526d63656e7461676520636f6e66696760901b606482015260840161062e565b60dd84905560de83905560df82905560e08190556040517fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b90611f75908690869086908690612647565b6000336001600160a01b0383161480159061248e5750600054604051633292276760e11b81526001600160a01b03909116906365244ece9061244d908590600401612725565b602060405180830381865afa15801561246a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061248e9190612ca4565b80156105f05750606c54604051630fbeb37f60e01b81526001600160a01b0390911690630fbeb37f906124c79085904390600401612d0b565b602060405180830381865afa1580156124e4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125089190612ca4565b1592915050565b600081600003612520576000610bd4565b610bd48284612d85565b6000818310611f935781610bd4565b60405180602001604052806001906020820280368337509192915050565b60008083601f84011261256957600080fd5b5081356001600160401b0381111561258057600080fd5b6020830191508360208260051b850101111561259b57600080fd5b9250929050565b600080602083850312156125b557600080fd5b82356001600160401b038111156125cb57600080fd5b6125d785828601612557565b90969095509350505050565b6001600160a01b0381168114610c4757600080fd5b60006020828403121561260a57600080fd5b8135610bd4816125e3565b6000806000806080858703121561262b57600080fd5b5050823594602084013594506040840135936060013592509050565b93845260208401929092526040830152606082015260800190565b60008083601f84011261267457600080fd5b5081356001600160401b0381111561268b57600080fd5b60208301915083602082850101111561259b57600080fd5b6000806000806000606086880312156126bb57600080fd5b85356126c6816125e3565b945060208601356001600160401b03808211156126e257600080fd5b6126ee89838a01612662565b9096509450604088013591508082111561270757600080fd5b5061271488828901612662565b969995985093965092949392505050565b6001600160a01b0391909116815260200190565b6000806040838503121561274c57600080fd5b8235612757816125e3565b946020939093013593505050565b60008060006040848603121561277a57600080fd5b83356001600160401b0381111561279057600080fd5b61279c86828701612557565b909790965060209590950135949350505050565b600080604083850312156127c357600080fd5b50508035926020909101359150565b80608081018310156105f057600080fd5b60008060008060008060008060006102a08a8c03121561280257600080fd5b893561280d816125e3565b985060208a013561281d816125e3565b975060408a013561282d816125e3565b965060608a013561283d816125e3565b955061284c8b60808c016127d2565b94506101408a018b81111561286057600080fd5b6101008b0194506101a08b018c81111561287957600080fd5b8194506128868d826127d2565b935050506128988b6102208c016127d2565b90509295985092959850929598565b6000806000606084860312156128bc57600080fd5b83356128c7816125e3565b95602085013595506040909401359392505050565b6000806000606084860312156128f157600080fd5b505081359360208301359350604090920135919050565b600081518084526020808501945080840160005b838110156129385781518752958201959082019060010161291c565b509495945050505050565b602081526000610bd46020830184612908565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016129aa576129aa612982565b5060010190565b8183526000602080850194508260005b858110156129385781356129d4816125e3565b6001600160a01b0316875295820195908201906001016129c1565b604081526000612a036040830185876129b1565b8281036020840152612a158185612908565b9695505050505050565b600060208284031215612a3157600080fd5b5051919050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b604051601f8201601f191681016001600160401b0381118282101715612aa257612aa2612956565b604052919050565b600060a08284031215612abc57600080fd5b60405160a081016001600160401b0381118282101715612ade57612ade612956565b6040528251612aec816125e3565b81526020830151612afc816125e3565b60208201526040830151612b0f816125e3565b6040820152606083810151908201526080928301519281019290925250919050565b818103818111156105f0576105f0612982565b6040810160088410612b6657634e487b7160e01b600052602160045260246000fd5b9281526020015290565b6001600160a01b03949094168452602084019290925260408301521515606082015260800190565b8183823760009101908152919050565b6020815260006120c96020830184866129b1565b80518015158114612bcc57600080fd5b919050565b60006020808385031215612be457600080fd5b82516001600160401b0380821115612bfb57600080fd5b818501915085601f830112612c0f57600080fd5b815181811115612c2157612c21612956565b8060051b9150612c32848301612a7a565b8181529183018401918481019088841115612c4c57600080fd5b938501935b83851015612c7157612c6285612bbc565b82529385019390850190612c51565b98975050505050505050565b606081526000612c916060830186886129b1565b6020830194909452506040015292915050565b600060208284031215612cb657600080fd5b610bd482612bbc565b600080600060608486031215612cd457600080fd5b612cdd84612bbc565b925060208401519150604084015190509250925092565b80820281158282048414176105f0576105f0612982565b6001600160a01b03929092168252602082015260400190565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b0386168152606060208201819052600090612d729083018688612d24565b8281036040840152612c71818587612d24565b808201808211156105f0576105f061298256fe607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d98c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c23480a2646970667358221220bbb9c8a18d14676fde8bc85398a11a7545f7fb8cce3da08ee81c2ef3b251559464736f6c63430008110033", + "numDeployments": 4, + "solcInputHash": "0e13282b1de32a862f3ea9c3dc0543e9", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallPrecompiled\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeJailedInTheCurrentPeriod\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrEvidenceAlreadySubmitted\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientCreditScoreToBailOut\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidArguments\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCreditScoreConfig\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCutOffPercentageConfig\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidRatios\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidSlash\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidThreshold\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrValidatorHasBailedOutPreviously\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"usedCreditScore\",\"type\":\"uint256\"}],\"name\":\"BailedOut\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier1\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier2\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailDurationForMissingVotesRatioTier2\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"skipBridgeOperatorSlashingThreshold\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeVotingThreshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeVotingSlashAmount\",\"type\":\"uint256\"}],\"name\":\"BridgeVotingSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"gainCreditScore\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxCreditScore\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bailOutCostMultiplier\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"cutOffPercentageAfterBailout\",\"type\":\"uint256\"}],\"name\":\"CreditScoreConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"validators\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"creditScores\",\"type\":\"uint256[]\"}],\"name\":\"CreditScoresUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashDoubleSignAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"doubleSigningJailUntilBlock\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"doubleSigningOffsetLimitBlock\",\"type\":\"uint256\"}],\"name\":\"DoubleSignSlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashFastFinalityAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"fastFinalityJailUntilBlock\",\"type\":\"uint256\"}],\"name\":\"FastFinalitySlashingConfigsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"enum IBaseSlash.SlashType\",\"name\":\"slashType\",\"type\":\"uint8\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"}],\"name\":\"Slashed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unavailabilityTier1Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"unavailabilityTier2Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"slashAmountForUnavailabilityTier2Threshold\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"jailDurationForUnavailabilityTier2Threshold\",\"type\":\"uint256\"}],\"name\":\"UnavailabilitySlashingConfigsUpdated\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"bailOut\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"checkBailedOutAtPeriod\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"}],\"name\":\"currentUnavailabilityIndicator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"}],\"name\":\"execResetCreditScores\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_tier\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"execSlashBridgeOperator\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeOperatorSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier1_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"missingVotesRatioTier2_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"jailDurationForMissingVotesRatioTier2_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"skipBridgeOperatorSlashingThreshold_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getBridgeVotingSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"bridgeVotingThreshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"bridgeVotingSlashAmount_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"}],\"name\":\"getCreditScore\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCreditScoreConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"gainCreditScore_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"maxCreditScore_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"bailOutCostMultiplier_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"cutOffPercentageAfterBailout_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getDoubleSignSlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"slashDoubleSignAmount_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"doubleSigningJailUntilBlock_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"doubleSigningOffsetLimitBlock_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getFastFinalitySlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"slashFastFinalityAmount_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"fastFinalityJailUntilBlock_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"}],\"name\":\"getManyCreditScores\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_resultList\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validator\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"getUnavailabilityIndicator\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getUnavailabilitySlashingConfigs\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"unavailabilityTier1Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"unavailabilityTier2Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"slashAmountForUnavailabilityTier2Threshold_\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"jailDurationForUnavailabilityTier2Threshold_\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__maintenanceContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninTrustedOrganizationContract\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"__roninGovernanceAdminContract\",\"type\":\"address\"},{\"internalType\":\"uint256[4]\",\"name\":\"_bridgeOperatorSlashingConfigs\",\"type\":\"uint256[4]\"},{\"internalType\":\"uint256[2]\",\"name\":\"_bridgeVotingSlashingConfigs\",\"type\":\"uint256[2]\"},{\"internalType\":\"uint256[3]\",\"name\":\"_doubleSignSlashingConfigs\",\"type\":\"uint256[3]\"},{\"internalType\":\"uint256[4]\",\"name\":\"_unavailabilitySlashingConfigs\",\"type\":\"uint256[4]\"},{\"internalType\":\"uint256[4]\",\"name\":\"_creditScoreConfigs\",\"type\":\"uint256[4]\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"roninGovernanceAdminContract\",\"type\":\"address\"}],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"profileContract\",\"type\":\"address\"}],\"name\":\"initializeV3\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"lastUnavailabilitySlashedBlock\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompileValidateDoubleSignAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"precompileValidateFastFinalityAddress\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_ratioTier1\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_ratioTier2\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailDurationTier2\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_skipSlashingThreshold\",\"type\":\"uint256\"}],\"name\":\"setBridgeOperatorSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_slashAmount\",\"type\":\"uint256\"}],\"name\":\"setBridgeVotingSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_gainScore\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxScore\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_bailOutMultiplier\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_cutOffPercentage\",\"type\":\"uint256\"}],\"name\":\"setCreditScoreConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_slashAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailUntilBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_offsetLimitBlock\",\"type\":\"uint256\"}],\"name\":\"setDoubleSignSlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"slashAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"jailUntilBlock\",\"type\":\"uint256\"}],\"name\":\"setFastFinalitySlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_tier1Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_tier2Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_slashAmountForTier2Threshold\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_jailDurationForTier2Threshold\",\"type\":\"uint256\"}],\"name\":\"setUnavailabilitySlashingConfigs\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"slashBridgeVoting\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"_header1\",\"type\":\"bytes\"},{\"internalType\":\"bytes\",\"name\":\"_header2\",\"type\":\"bytes\"}],\"name\":\"slashDoubleSign\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"consensusAddr\",\"type\":\"address\"},{\"internalType\":\"bytes\",\"name\":\"voterPublicKey\",\"type\":\"bytes\"},{\"internalType\":\"uint256\",\"name\":\"targetBlockNumber\",\"type\":\"uint256\"},{\"internalType\":\"bytes32[2]\",\"name\":\"targetBlockHash\",\"type\":\"bytes32[2]\"},{\"internalType\":\"bytes[][2]\",\"name\":\"listOfPublicKey\",\"type\":\"bytes[][2]\"},{\"internalType\":\"bytes[2]\",\"name\":\"aggregatedSignature\",\"type\":\"bytes[2]\"}],\"name\":\"slashFastFinality\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_validatorAddr\",\"type\":\"address\"}],\"name\":\"slashUnavailability\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_validators\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"updateCreditScores\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallPrecompiled()\":[{\"details\":\"Error of call to precompile fails.\"}],\"ErrCallerMustBeJailedInTheCurrentPeriod()\":[{\"details\":\"Error thrown when the caller must be jailed in the current period.\"}],\"ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock()\":[{\"details\":\"Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrEvidenceAlreadySubmitted()\":[{\"details\":\"Error thrown when evidence has already been submitted.\"}],\"ErrInsufficientCreditScoreToBailOut()\":[{\"details\":\"Error thrown when the caller's credit score is insufficient to bail out a situation.\"}],\"ErrInvalidArguments(bytes4)\":[{\"details\":\"Error indicating that arguments are invalid.\"}],\"ErrInvalidCreditScoreConfig()\":[{\"details\":\"Error thrown when an invalid credit score configuration is provided.\"}],\"ErrInvalidCutOffPercentageConfig()\":[{\"details\":\"Error thrown when an invalid cut-off percentage configuration is provided.\"}],\"ErrInvalidRatios()\":[{\"details\":\"Error thrown when invalid ratios are provided.\"}],\"ErrInvalidSlash()\":[{\"details\":\"Error thrown when an invalid slash is encountered.\"}],\"ErrInvalidThreshold(bytes4)\":[{\"details\":\"Error indicating that the provided threshold is invalid for a specific function signature.\",\"params\":{\"msgSig\":\"The function signature (bytes4) that the invalid threshold applies to.\"}}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrValidatorHasBailedOutPreviously()\":[{\"details\":\"Error thrown when a validator has previously bailed out.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"bailOut(address)\":{\"details\":\"A slashed validator use this method to get out of jail. Requirements: - The `_consensusAddr` must be a validator. - Only validator's admin can call this method. Emits the event `BailedOut`.\"},\"checkBailedOutAtPeriod(address,uint256)\":{\"details\":\"Returns the whether the `_validator` has been bailed out at the `_period`.\"},\"currentUnavailabilityIndicator(address)\":{\"details\":\"Returns the current unavailability indicator of a block producer.\"},\"execResetCreditScores(address[])\":{\"details\":\"Resets the credit score for the revoked validators. Requirements: - Only validator contract can call this method. - This method is only called at the end of each period. Emits the event `CreditScoresUpdated`.\"},\"execSlashBridgeOperator(address,uint256,uint256)\":{\"details\":\"Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\",\"params\":{\"_tier\":\"The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1` and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2` Requirements: - Only validator contract can invoke this method. - Should be called only at the end of period. - Should be called only when there is slash of bridge operator. Emits the event `Slashed`.\"}},\"getBridgeOperatorSlashingConfigs()\":{\"details\":\"Returns the configs related to bridge operator slashing.\",\"returns\":{\"jailDurationForMissingVotesRatioTier2_\":\"The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\",\"missingVotesRatioTier1_\":\"The bridge reward will be deprecated if (s)he missed more than this ratio.\",\"missingVotesRatioTier2_\":\"The bridge reward and mining reward will be deprecated and the corresponding block producer will be put in jail if (s)he misses more than this ratio.\",\"skipBridgeOperatorSlashingThreshold_\":\"The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\"}},\"getBridgeVotingSlashingConfigs()\":{\"details\":\"Returns the configs related to bridge voting slashing.\",\"returns\":{\"bridgeVotingSlashAmount_\":\"The amount of RON to slash bridge voting.\",\"bridgeVotingThreshold_\":\"The threshold to slash when a trusted organization does not vote for bridge operators.\"}},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getCreditScore(address)\":{\"details\":\"Returns the current credit score of the validator.\"},\"getCreditScoreConfigs()\":{\"details\":\"Returns the configs related to credit score.\",\"returns\":{\"bailOutCostMultiplier_\":\"The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\",\"cutOffPercentageAfterBailout_\":\"The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\",\"gainCreditScore_\":\"The score to gain per period.\",\"maxCreditScore_\":\"The max number of credit score that a validator can hold.\"}},\"getDoubleSignSlashingConfigs()\":{\"details\":\"Returns the configs related to block producer slashing.\",\"params\":{\"_doubleSigningOffsetLimitBlock\":\"The number of block that the current block is at most far from the double signing block.\"},\"returns\":{\"doubleSigningJailUntilBlock_\":\"The block number that the punished validator will be jailed until, due to double signing.\",\"slashDoubleSignAmount_\":\"The amount of RON to slash double sign.\"}},\"getFastFinalitySlashingConfigs()\":{\"details\":\"Returns the configs related to block producer slashing.\",\"returns\":{\"fastFinalityJailUntilBlock_\":\"The block number that the punished validator will be jailed until, due to malicious fast finality.\",\"slashFastFinalityAmount_\":\"The amount of RON to slash fast finality.\"}},\"getManyCreditScores(address[])\":{\"details\":\"Returns the current credit score of a list of validators.\"},\"getUnavailabilityIndicator(address,uint256)\":{\"details\":\"Helper for CreditScore contract to query indicator of the validator.\"},\"getUnavailabilitySlashingConfigs()\":{\"details\":\"Returns the configs related to block producer slashing.\",\"returns\":{\"jailDurationForUnavailabilityTier2Threshold_\":\"The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\",\"slashAmountForUnavailabilityTier2Threshold_\":\"The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with tier-2 or tier-3.\",\"unavailabilityTier1Threshold_\":\"The mining reward will be deprecated, if (s)he missed more than this threshold. This threshold is applied for tier-1 and tier-3 slash.\",\"unavailabilityTier2Threshold_\":\" The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\"}},\"initialize(address,address,address,address,uint256[4],uint256[2],uint256[3],uint256[4],uint256[4])\":{\"details\":\"Initializes the contract storage.\"},\"precompileValidateDoubleSignAddress()\":{\"details\":\"Gets the address of the precompile of validating double sign evidence\"},\"precompileValidateFastFinalityAddress()\":{\"details\":\"Gets the address of the precompile of validating double sign evidence\"},\"setBridgeOperatorSlashingConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash bridge operators. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.\",\"params\":{\"_jailDurationTier2\":\"The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\",\"_ratioTier1\":\"The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map to 0%-100%.\",\"_ratioTier2\":\"The bridge reward and mining reward will be deprecated and the corresponding block producer will be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\",\"_skipSlashingThreshold\":\"The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\"}},\"setBridgeVotingSlashingConfigs(uint256,uint256)\":{\"details\":\"Sets the configs to slash bridge voting. Requirements: - The method caller is admin. Emits the event `BridgeVotingSlashingConfigsUpdated`.\",\"params\":{\"_slashAmount\":\"The amount of RON to slash bridge voting.\",\"_threshold\":\"The threshold to slash when a trusted organization does not vote for bridge operators.\"}},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setCreditScoreConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to credit score. Requirements: - The method caller is admin. Emits the event `CreditScoreConfigsUpdated`.\",\"params\":{\"_bailOutMultiplier\":\"The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\",\"_cutOffPercentage\":\"The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\",\"_gainScore\":\"The score to gain per period.\",\"_maxScore\":\"The max number of credit score that a validator can hold.\"}},\"setDoubleSignSlashingConfigs(uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `DoubleSignSlashingConfigsUpdated`.\",\"params\":{\"_doubleSigningOffsetLimitBlock\":\"The number of block that the current block is at most far from the double signing block.\",\"_jailUntilBlock\":\"The block number that the punished validator will be jailed until, due to double signing.\",\"_slashAmount\":\"The amount of RON to slash double sign.\"}},\"setFastFinalitySlashingConfigs(uint256,uint256)\":{\"details\":\"Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `FastFinalitySlashingConfigsUpdated`.\",\"params\":{\"jailUntilBlock\":\"The block number that the punished validator will be jailed until, due to fast finality.\",\"slashAmount\":\"The amount of RON to slash fast finality.\"}},\"setUnavailabilitySlashingConfigs(uint256,uint256,uint256,uint256)\":{\"details\":\"Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.\",\"params\":{\"_jailDurationForTier2Threshold\":\"The number of blocks to jail a block producer when (s)he is slashed tier-2.\",\"_slashAmountForTier2Threshold\":\"The amount of RON to deduct from self-staking of a block producer when (s)he is slashed tier-2.\",\"_tier1Threshold\":\"The mining reward will be deprecated, if (s)he missed more than this threshold.\",\"_tier2Threshold\":\"The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted self-staking if (s)he misses more than this threshold.\"}},\"slashBridgeVoting(address)\":{\"details\":\"Slashes for bridge voter governance. Emits the event `Slashed`.\"},\"slashDoubleSign(address,bytes,bytes)\":{\"details\":\"Slashes for double signing. Requirements: - The method caller is coinbase. Emits the event `Slashed` if the double signing evidence of the two headers valid.\"},\"slashFastFinality(address,bytes,uint256,bytes32[2],bytes[][2],bytes[2])\":{\"details\":\"Slashes for fast finality. Requirements: - Only whitelisted addresses are allowed to call. Emits the event `Slashed` if the fast finality evidence of the two headers valid.\"},\"slashUnavailability(address)\":{\"details\":\"Slashes for unavailability by increasing the counter of block producer `_consensusAddr`. Requirements: - The method caller is coinbase. Emits the event `Slashed` when the threshold is reached.\"},\"updateCreditScores(address[],uint256)\":{\"details\":\"Updates the credit score for the validators. Requirements: - Only validator contract can call this method. - This method is only called at the end of each period. Emits the event `CreditScoresUpdated`.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/slash-indicator/SlashIndicator.sol\":\"SlashIndicator\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Strings.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev String operations.\\n */\\nlibrary Strings {\\n bytes16 private constant _HEX_SYMBOLS = \\\"0123456789abcdef\\\";\\n uint8 private constant _ADDRESS_LENGTH = 20;\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\\n */\\n function toString(uint256 value) internal pure returns (string memory) {\\n // Inspired by OraclizeAPI's implementation - MIT licence\\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\\n\\n if (value == 0) {\\n return \\\"0\\\";\\n }\\n uint256 temp = value;\\n uint256 digits;\\n while (temp != 0) {\\n digits++;\\n temp /= 10;\\n }\\n bytes memory buffer = new bytes(digits);\\n while (value != 0) {\\n digits -= 1;\\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\\n value /= 10;\\n }\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\\n */\\n function toHexString(uint256 value) internal pure returns (string memory) {\\n if (value == 0) {\\n return \\\"0x00\\\";\\n }\\n uint256 temp = value;\\n uint256 length = 0;\\n while (temp != 0) {\\n length++;\\n temp >>= 8;\\n }\\n return toHexString(value, length);\\n }\\n\\n /**\\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\\n */\\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\\n bytes memory buffer = new bytes(2 * length + 2);\\n buffer[0] = \\\"0\\\";\\n buffer[1] = \\\"x\\\";\\n for (uint256 i = 2 * length + 1; i > 1; --i) {\\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\\n value >>= 4;\\n }\\n require(value == 0, \\\"Strings: hex length insufficient\\\");\\n return string(buffer);\\n }\\n\\n /**\\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\\n */\\n function toHexString(address addr) internal pure returns (string memory) {\\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\\n }\\n}\\n\",\"keccak256\":\"0xaf159a8b1923ad2a26d516089bceca9bdeaeacd04be50983ea00ba63070f08a3\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Strings.sol\\\";\\n\\n/**\\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\\n *\\n * These functions can be used to verify that a message was signed by the holder\\n * of the private keys of a given address.\\n */\\nlibrary ECDSA {\\n enum RecoverError {\\n NoError,\\n InvalidSignature,\\n InvalidSignatureLength,\\n InvalidSignatureS,\\n InvalidSignatureV\\n }\\n\\n function _throwError(RecoverError error) private pure {\\n if (error == RecoverError.NoError) {\\n return; // no error: do nothing\\n } else if (error == RecoverError.InvalidSignature) {\\n revert(\\\"ECDSA: invalid signature\\\");\\n } else if (error == RecoverError.InvalidSignatureLength) {\\n revert(\\\"ECDSA: invalid signature length\\\");\\n } else if (error == RecoverError.InvalidSignatureS) {\\n revert(\\\"ECDSA: invalid signature 's' value\\\");\\n } else if (error == RecoverError.InvalidSignatureV) {\\n revert(\\\"ECDSA: invalid signature 'v' value\\\");\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature` or error string. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n *\\n * Documentation for signature generation:\\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\\n if (signature.length == 65) {\\n bytes32 r;\\n bytes32 s;\\n uint8 v;\\n // ecrecover takes the signature parameters, and the only way to get them\\n // currently is to use assembly.\\n /// @solidity memory-safe-assembly\\n assembly {\\n r := mload(add(signature, 0x20))\\n s := mload(add(signature, 0x40))\\n v := byte(0, mload(add(signature, 0x60)))\\n }\\n return tryRecover(hash, v, r, s);\\n } else {\\n return (address(0), RecoverError.InvalidSignatureLength);\\n }\\n }\\n\\n /**\\n * @dev Returns the address that signed a hashed message (`hash`) with\\n * `signature`. This address can then be used for verification purposes.\\n *\\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\\n * this function rejects them by requiring the `s` value to be in the lower\\n * half order, and the `v` value to be either 27 or 28.\\n *\\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\\n * verification to be secure: it is possible to craft signatures that\\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\\n * this is by receiving a hash of the original message (which may otherwise\\n * be too long), and then calling {toEthSignedMessageHash} on it.\\n */\\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, signature);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\\n *\\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address, RecoverError) {\\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\\n uint8 v = uint8((uint256(vs) >> 255) + 27);\\n return tryRecover(hash, v, r, s);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\\n *\\n * _Available since v4.2._\\n */\\n function recover(\\n bytes32 hash,\\n bytes32 r,\\n bytes32 vs\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n *\\n * _Available since v4.3._\\n */\\n function tryRecover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address, RecoverError) {\\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\\n // the valid range for s in (301): 0 < s < secp256k1n \\u00f7 2 + 1, and for v in (302): v \\u2208 {27, 28}. Most\\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\\n //\\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\\n // these malleable signatures as well.\\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\\n return (address(0), RecoverError.InvalidSignatureS);\\n }\\n if (v != 27 && v != 28) {\\n return (address(0), RecoverError.InvalidSignatureV);\\n }\\n\\n // If the signature is valid (and not malleable), return the signer address\\n address signer = ecrecover(hash, v, r, s);\\n if (signer == address(0)) {\\n return (address(0), RecoverError.InvalidSignature);\\n }\\n\\n return (signer, RecoverError.NoError);\\n }\\n\\n /**\\n * @dev Overload of {ECDSA-recover} that receives the `v`,\\n * `r` and `s` signature fields separately.\\n */\\n function recover(\\n bytes32 hash,\\n uint8 v,\\n bytes32 r,\\n bytes32 s\\n ) internal pure returns (address) {\\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\\n _throwError(error);\\n return recovered;\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\\n // 32 is the length in bytes of hash,\\n // enforced by the type signature above\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n32\\\", hash));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Message, created from `s`. This\\n * produces hash corresponding to the one signed with the\\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\\n * JSON-RPC method as part of EIP-191.\\n *\\n * See {recover}.\\n */\\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19Ethereum Signed Message:\\\\n\\\", Strings.toString(s.length), s));\\n }\\n\\n /**\\n * @dev Returns an Ethereum Signed Typed Data, created from a\\n * `domainSeparator` and a `structHash`. This produces hash corresponding\\n * to the one signed with the\\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\\n * JSON-RPC method as part of EIP-712.\\n *\\n * See {recover}.\\n */\\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\\n return keccak256(abi.encodePacked(\\\"\\\\x19\\\\x01\\\", domainSeparator, structHash));\\n }\\n}\\n\",\"keccak256\":\"0xdb7f5c28fc61cda0bd8ab60ce288e206b791643bcd3ba464a70cbec18895a2f5\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/IBridgeAdminProposal.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { BridgeOperatorsBallot } from \\\"../libraries/BridgeOperatorsBallot.sol\\\";\\n\\ninterface IBridgeAdminProposal {\\n /// @dev Emitted when the bridge operators are approved.\\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\\n\\n /**\\n * @dev Returns the last voted block of the bridge voter.\\n */\\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\\n\\n /**\\n * @dev Returns the synced bridge operator set info.\\n */\\n function lastSyncedBridgeOperatorSetInfo()\\n external\\n view\\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\\n}\\n\",\"keccak256\":\"0x38caf9faa1e53ca37b08813a8933760b1a975f821b391e7696c7ee38b69bf8c7\",\"license\":\"MIT\"},\"contracts/interfaces/IMaintenance.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IMaintenance {\\n /**\\n * @dev Error thrown when attempting to schedule an already scheduled event.\\n */\\n error ErrAlreadyScheduled();\\n\\n /**\\n * @dev Error thrown when referring to a non-existent schedule.\\n */\\n error ErrUnexistedSchedule();\\n\\n /**\\n * @dev Error thrown when the end block of a schedule is out of range.\\n */\\n error ErrEndBlockOutOfRange();\\n\\n /**\\n * @dev Error thrown when the start block of a schedule is out of range.\\n */\\n error ErrStartBlockOutOfRange();\\n\\n /**\\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\\n */\\n error ErrAlreadyOnMaintenance();\\n\\n /**\\n * @dev Error thrown when attempting an action before the cooldown period has ended.\\n */\\n error ErrCooldownTimeNotYetEnded();\\n\\n /**\\n * @dev Error thrown when the total number of schedules exceeds the limit.\\n */\\n error ErrTotalOfSchedulesExceeded();\\n\\n /**\\n * @dev Error thrown when an invalid maintenance duration is specified.\\n */\\n error ErrInvalidMaintenanceDuration();\\n\\n /**\\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\\n */\\n error ErrInvalidMaintenanceDurationConfig();\\n\\n /**\\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\\n */\\n error ErrInvalidOffsetToStartScheduleConfigs();\\n\\n struct Schedule {\\n uint256 from;\\n uint256 to;\\n uint256 lastUpdatedBlock;\\n uint256 requestTimestamp;\\n }\\n\\n /// @dev Emitted when a maintenance is scheduled.\\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\\n /// @dev Emitted when a schedule of maintenance is cancelled.\\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\\n /// @dev Emitted when the maintenance config is updated.\\n event MaintenanceConfigUpdated(\\n uint256 minMaintenanceDurationInBlock,\\n uint256 maxMaintenanceDurationInBlock,\\n uint256 minOffsetToStartSchedule,\\n uint256 maxOffsetToStartSchedule,\\n uint256 maxSchedules,\\n uint256 cooldownSecsToMaintain\\n );\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\\n */\\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\\n */\\n function checkMaintainedInBlockRange(\\n address _consensusAddr,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool);\\n\\n /**\\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\\n */\\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\\n */\\n function checkManyMaintainedInBlockRange(\\n address[] calldata _addrList,\\n uint256 _fromBlock,\\n uint256 _toBlock\\n ) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\\n */\\n function checkScheduled(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator `_consensusAddr`\\n */\\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\\n */\\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\\n\\n /**\\n * @dev Returns the total of current schedules.\\n */\\n function totalSchedule() external view returns (uint256 _count);\\n\\n /**\\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The max duration is larger than the min duration.\\n * - The max offset is larger than the min offset.\\n *\\n * Emits the event `MaintenanceConfigUpdated`.\\n *\\n */\\n function setMaintenanceConfig(\\n uint256 _minMaintenanceDurationInBlock,\\n uint256 _maxMaintenanceDurationInBlock,\\n uint256 _minOffsetToStartSchedule,\\n uint256 _maxOffsetToStartSchedule,\\n uint256 _maxSchedules,\\n uint256 _cooldownSecsToMaintain\\n ) external;\\n\\n /**\\n * @dev Returns the min duration for maintenance in block.\\n */\\n function minMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max duration for maintenance in block.\\n */\\n function maxMaintenanceDurationInBlock() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the min block number that the schedule can start\\n */\\n function minOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev The offset to the max block number that the schedule can start\\n */\\n function maxOffsetToStartSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Returns the max number of scheduled maintenances.\\n */\\n function maxSchedule() external view returns (uint256);\\n\\n /**\\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\\n * - The total number of schedules is not larger than `maxSchedules()`.\\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\\n * - The end block is larger than the start block.\\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\\n * - The start block is at the start of an epoch.\\n * - The end block is at the end of an epoch.\\n *\\n * Emits the event `MaintenanceScheduled`.\\n *\\n */\\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\\n\\n /**\\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\\n *\\n * Requirements:\\n * - The candidate `_consensusAddr` is the block producer.\\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\\n *\\n * Emits the event `MaintenanceScheduleCancelled`.\\n */\\n function cancelSchedule(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0xe30d31be54b9f9044c6a5d1393f04f9093d619a705d00276359853a086a91e8a\",\"license\":\"MIT\"},\"contracts/interfaces/IProfile.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../utils/RoleAccess.sol\\\";\\n\\ninterface IProfile {\\n struct CandidateProfile {\\n /**\\n * @dev Primary key of the profile, use for backward querying.\\n *\\n * {Staking} Contract: index of pool\\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\\n *\\n */\\n address id;\\n /// @dev Consensus address.\\n address consensus;\\n /// @dev Pool admin address.\\n address admin;\\n /// @dev Treasury address.\\n address payable treasury;\\n /// @dev Address to voting proposal.\\n address governor;\\n /// @dev Public key for fast finality.\\n bytes pubkey;\\n }\\n\\n /// @dev Event emitted when a profile with `id` is added.\\n event ProfileAdded(address indexed id);\\n /// @dev Event emitted when a address in a profile is changed.\\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\\n /// @dev Event emitted when the pubkey of the `id` is changed.\\n event PubkeyChanged(address indexed id, bytes pubkey);\\n\\n /// @dev Error of already existed profile.\\n error ErrExistentProfile();\\n /// @dev Error of non existed profile.\\n error ErrNonExistentProfile();\\n /// @dev Error when create a new profile whose id and consensus are not identical.\\n error ErrIdAndConsensusDiffer();\\n /**\\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\\n * and with value type of `infoType`.\\n */\\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\\n error ErrDuplicatedPubkey(bytes pubkey);\\n error ErrZeroAddress(RoleAccess infoType);\\n error ErrZeroPubkey();\\n\\n /// @dev Getter to query full `profile` from `id` address.\\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\\n\\n /**\\n * @notice Add a new profile.\\n *\\n * @dev Requirements:\\n * - The profile must not be existent before.\\n * - Only contract admin can call this method.\\n */\\n function addNewProfile(CandidateProfile memory profile) external;\\n\\n /**\\n * @notice The candidate admin registers a new profile.\\n *\\n * @dev Requirements:\\n * - The profile must not be existent before.\\n * - Only user with candidate admin role can call this method.\\n */\\n\\n function registerProfile(CandidateProfile memory profile) external;\\n\\n /**\\n * @notice The candidate admin changes the public key.\\n *\\n * @dev Requirements:\\n * - The profile must be existed.\\n * - Only user with candidate admin role can call this method.\\n * - New public key must not be duplicated.\\n */\\n\\n function changePubkey(address id, bytes memory pubkey) external;\\n}\\n\",\"keccak256\":\"0xa22fc36c00bc641b74359a9df037b8b00028ae679b2b5fa48cb23f1c5f07dbcf\",\"license\":\"MIT\"},\"contracts/interfaces/IQuorum.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface IQuorum {\\n /// @dev Emitted when the threshold is updated\\n event ThresholdUpdated(\\n uint256 indexed nonce,\\n uint256 indexed numerator,\\n uint256 indexed denominator,\\n uint256 previousNumerator,\\n uint256 previousDenominator\\n );\\n\\n /**\\n * @dev Returns the threshold.\\n */\\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\\n\\n /**\\n * @dev Checks whether the `_voteWeight` passes the threshold.\\n */\\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\\n\\n /**\\n * @dev Returns the minimum vote weight to pass the threshold.\\n */\\n function minimumVoteWeight() external view returns (uint256);\\n\\n /**\\n * @dev Sets the threshold.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `ThresholdUpdated` event.\\n *\\n */\\n function setThreshold(\\n uint256 _numerator,\\n uint256 _denominator\\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\\n}\\n\",\"keccak256\":\"0x6b7920b04a73a0e1ff7404aa1a3b5fc738fc0b6154839480f666fd69b55123f0\",\"license\":\"MIT\"},\"contracts/interfaces/IRoninTrustedOrganization.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IQuorum.sol\\\";\\n\\ninterface IRoninTrustedOrganization is IQuorum {\\n /**\\n * @dev Error indicating that a query for a duplicate entry was made.\\n */\\n error ErrQueryForDupplicated();\\n\\n /**\\n * @dev Error indicating that a query was made for a non-existent consensus address.\\n */\\n error ErrQueryForNonExistentConsensusAddress();\\n\\n /**\\n * @dev Error indicating that a bridge voter has already been added.\\n * @param voter The address of the bridge voter that is already added.\\n */\\n error ErrBridgeVoterIsAlreadyAdded(address voter);\\n\\n /**\\n * @dev Error indicating that a governor address has already been added.\\n * @param addr The address of the governor that is already added.\\n */\\n error ErrGovernorAddressIsAlreadyAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is not added.\\n * @param addr The address of the consensus contract that is not added.\\n */\\n error ErrConsensusAddressIsNotAdded(address addr);\\n\\n /**\\n * @dev Error indicating that a consensus address is already added.\\n * @param addr The address of the consensus contract that is already added.\\n */\\n error ErrConsensusAddressIsAlreadyAdded(address addr);\\n\\n struct TrustedOrganization {\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address to voting proposal\\n address governor;\\n // Address to voting bridge operators\\n address bridgeVoter;\\n // Its Weight\\n uint256 weight;\\n // The block that the organization was added\\n uint256 addedBlock;\\n }\\n\\n /// @dev Emitted when the trusted organization is added.\\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is updated.\\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\\n /// @dev Emitted when the trusted organization is removed.\\n event TrustedOrganizationsRemoved(address[] orgs);\\n\\n /**\\n * @dev Adds a list of addresses into the trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n * - The field `addedBlock` should be blank.\\n *\\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\\n *\\n */\\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\\n\\n /**\\n * @dev Updates weights for a list of existent trusted organization.\\n *\\n * Requirements:\\n * - The weights should larger than 0.\\n * - The method caller is admin.\\n *\\n * Emits the `TrustedOrganizationUpdated` event.\\n *\\n */\\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\\n\\n /**\\n * @dev Removes a list of addresses from the trusted organization.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\\n *\\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\\n */\\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\\n\\n /**\\n * @dev Returns total weights.\\n */\\n function totalWeight() external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a consensus.\\n */\\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a governor.\\n */\\n function getGovernorWeight(address _governor) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weight of a bridge voter.\\n */\\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the weights of a list of consensus addresses.\\n */\\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of governor addresses.\\n */\\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the weights of a list of bridge voter addresses.\\n */\\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns total weights of the consensus list.\\n */\\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the governor list.\\n */\\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns total weights of the bridge voter list.\\n */\\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\\n\\n /**\\n * @dev Returns the trusted organization at `_index`.\\n */\\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\\n\\n /**\\n * @dev Returns the number of trusted organizations.\\n */\\n function countTrustedOrganization() external view returns (uint256);\\n\\n /**\\n * @dev Returns all of the trusted organizations.\\n */\\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\\n\\n /**\\n * @dev Returns the trusted organization by consensus address.\\n *\\n * Reverts once the consensus address is non-existent.\\n */\\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\\n}\\n\",\"keccak256\":\"0x2eaef3332e209474b24574aeded61091e82a145fcbcf479577535c0cd210e1e5\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/IBaseSlash.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseSlash {\\n enum SlashType {\\n UNKNOWN,\\n UNAVAILABILITY_TIER_1,\\n UNAVAILABILITY_TIER_2,\\n DOUBLE_SIGNING,\\n BRIDGE_VOTING,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\\n UNAVAILABILITY_TIER_3,\\n FAST_FINALITY\\n }\\n\\n /// @dev Error thrown when evidence has already been submitted.\\n error ErrEvidenceAlreadySubmitted();\\n\\n /// @dev Emitted when the validator is slashed.\\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\\n}\\n\",\"keccak256\":\"0x2e09934977e0701a28b7f776f0bd4eefdfd8d6b68134822440b2c756b6b7d1e4\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ICreditScore.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICreditScore {\\n /**\\n * @dev Error thrown when an invalid credit score configuration is provided.\\n */\\n error ErrInvalidCreditScoreConfig();\\n\\n /**\\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\\n */\\n error ErrInvalidCutOffPercentageConfig();\\n\\n /**\\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\\n */\\n error ErrInsufficientCreditScoreToBailOut();\\n\\n /**\\n * @dev Error thrown when a validator has previously bailed out.\\n */\\n error ErrValidatorHasBailedOutPreviously();\\n\\n /**\\n * @dev Error thrown when the caller must be jailed in the current period.\\n */\\n error ErrCallerMustBeJailedInTheCurrentPeriod();\\n\\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\\n event CreditScoreConfigsUpdated(\\n uint256 gainCreditScore,\\n uint256 maxCreditScore,\\n uint256 bailOutCostMultiplier,\\n uint256 cutOffPercentageAfterBailout\\n );\\n /// @dev Emitted the credit score of validators is updated.\\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\\n /// @dev Emitted when a validator bailed out of jail.\\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\\n\\n /**\\n * @dev Updates the credit score for the validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\\n\\n /**\\n * @dev Resets the credit score for the revoked validators.\\n *\\n * Requirements:\\n * - Only validator contract can call this method.\\n * - This method is only called at the end of each period.\\n *\\n * Emits the event `CreditScoresUpdated`.\\n *\\n */\\n function execResetCreditScores(address[] calldata _validators) external;\\n\\n /**\\n * @dev A slashed validator use this method to get out of jail.\\n *\\n * Requirements:\\n * - The `_consensusAddr` must be a validator.\\n * - Only validator's admin can call this method.\\n *\\n * Emits the event `BailedOut`.\\n *\\n */\\n function bailOut(address _consensusAddr) external;\\n\\n /**\\n * @dev Sets the configs to credit score.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CreditScoreConfigsUpdated`.\\n *\\n * @param _gainScore The score to gain per period.\\n * @param _maxScore The max number of credit score that a validator can hold.\\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to credit score.\\n *\\n * @return _gainCreditScore The score to gain per period.\\n * @return _maxCreditScore The max number of credit score that a validator can hold.\\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\\n *\\n */\\n function getCreditScoreConfigs()\\n external\\n view\\n returns (\\n uint256 _gainCreditScore,\\n uint256 _maxCreditScore,\\n uint256 _bailOutCostMultiplier,\\n uint256 _cutOffPercentageAfterBailout\\n );\\n\\n /**\\n * @dev Returns the current credit score of the validator.\\n */\\n function getCreditScore(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the current credit score of a list of validators.\\n */\\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\\n\\n /**\\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x26021ddf339495816692ea9f8545b4054d0ffb9c5ad11049cac4f3718a0bbc2d\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeOperator is IBaseSlash {\\n /**\\n * @dev Error thrown when invalid ratios are provided.\\n */\\n error ErrInvalidRatios();\\n\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\\n * `getBridgeOperatorSlashingConfigs` for param details.\\n */\\n event BridgeOperatorSlashingConfigsUpdated(\\n uint256 missingVotesRatioTier1,\\n uint256 missingVotesRatioTier2,\\n uint256 jailDurationForMissingVotesRatioTier2,\\n uint256 skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\\n *\\n * Requirements:\\n * - Only validator contract can invoke this method.\\n * - Should be called only at the end of period.\\n * - Should be called only when there is slash of bridge operator.\\n *\\n * Emits the event `Slashed`.\\n */\\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\\n\\n /**\\n * @dev Returns the configs related to bridge operator slashing.\\n *\\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\\n * block producer will be put in jail if (s)he misses more than this ratio.\\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\\n * its bridge operator is slashed tier-2.\\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\\n * number of votes in the bridge is too small.\\n *\\n */\\n function getBridgeOperatorSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _missingVotesRatioTier1,\\n uint256 _missingVotesRatioTier2,\\n uint256 _jailDurationForMissingVotesRatioTier2,\\n uint256 _skipBridgeOperatorSlashingThreshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash bridge operators.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\\n * to 0%-100%.\\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\\n * slashed tier-2.\\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\\n * in the bridge is too small.\\n *\\n */\\n function setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x3ea38604baf3bc5a12dd1a243eec2052de9ee2cb171222a2e5b0e5202d301471\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashBridgeVoting is IBaseSlash {\\n /**\\n * @dev Error thrown when an invalid slash is encountered.\\n */\\n error ErrInvalidSlash();\\n\\n /**\\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\\n * details.\\n */\\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Slashes for bridge voter governance.\\n *\\n * Emits the event `Slashed`.\\n */\\n function slashBridgeVoting(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the configs related to bridge voting slashing.\\n *\\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\\n * operators.\\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function getBridgeVotingSlashingConfigs()\\n external\\n view\\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\\n\\n /**\\n * @dev Sets the configs to slash bridge voting.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\\n *\\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\\n * @param _slashAmount The amount of RON to slash bridge voting.\\n *\\n */\\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\\n}\\n\",\"keccak256\":\"0x89751cbf99adf7dbd165fbbba5d6b62b5c47f8486322a7abb27d6d6aef345fae\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashDoubleSign is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\\n * for param details.\\n */\\n event DoubleSignSlashingConfigsUpdated(\\n uint256 slashDoubleSignAmount,\\n uint256 doubleSigningJailUntilBlock,\\n uint256 doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Slashes for double signing.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\\n */\\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\\n * double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function getDoubleSignSlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _slashDoubleSignAmount,\\n uint256 _doubleSigningJailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\\n *\\n * @param _slashAmount The amount of RON to slash double sign.\\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\\n * signing block.\\n *\\n */\\n function setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _doubleSigningOffsetLimitBlock\\n ) external;\\n}\\n\",\"keccak256\":\"0xb1adb41d0b1c8a362b7e669d9975754adbd4ed0f8de912e8455fa70eedd80d35\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashFastFinality.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashFastFinality is IBaseSlash {\\n /**\\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\\n * for param details.\\n */\\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\\n\\n /**\\n * @dev Slashes for fast finality.\\n *\\n * Requirements:\\n * - Only whitelisted addresses are allowed to call.\\n *\\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\\n */\\n function slashFastFinality(\\n address consensusAddr,\\n bytes calldata voterPublicKey,\\n uint256 targetBlockNumber,\\n bytes32[2] calldata targetBlockHash,\\n bytes[][2] calldata listOfPublicKey,\\n bytes[2] calldata aggregatedSignature\\n ) external;\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\\n * malicious fast finality.\\n */\\n function getFastFinalitySlashingConfigs()\\n external\\n view\\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\\n *\\n * @param slashAmount The amount of RON to slash fast finality.\\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\\n *\\n */\\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\\n}\\n\",\"keccak256\":\"0x6d46d8b31cf76709a4bc728f66e784b6c8c1e120489a72f187e40bb392bbc797\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashIndicator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashDoubleSign.sol\\\";\\nimport \\\"./ISlashBridgeVoting.sol\\\";\\nimport \\\"./ISlashBridgeOperator.sol\\\";\\nimport \\\"./ISlashUnavailability.sol\\\";\\nimport \\\"./ICreditScore.sol\\\";\\n\\ninterface ISlashIndicator is\\n ISlashDoubleSign,\\n ISlashBridgeVoting,\\n ISlashBridgeOperator,\\n ISlashUnavailability,\\n ICreditScore\\n{}\\n\",\"keccak256\":\"0xe8b8fde3af614735cb304bc1eb82b05d65ede4df804b5d555787e5d5ecb95ec0\",\"license\":\"MIT\"},\"contracts/interfaces/slash-indicator/ISlashUnavailability.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseSlash.sol\\\";\\n\\ninterface ISlashUnavailability is IBaseSlash {\\n /**\\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\\n */\\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\\n\\n /**\\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\\n * for param details.\\n */\\n event UnavailabilitySlashingConfigsUpdated(\\n uint256 unavailabilityTier1Threshold,\\n uint256 unavailabilityTier2Threshold,\\n uint256 slashAmountForUnavailabilityTier2Threshold,\\n uint256 jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Returns the last block that a block producer is slashed for unavailability.\\n */\\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `Slashed` when the threshold is reached.\\n *\\n */\\n function slashUnavailability(address _consensusAddr) external;\\n\\n /**\\n * @dev Returns the current unavailability indicator of a block producer.\\n */\\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\\n\\n /**\\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\\n\\n /**\\n * @dev Returns the configs related to block producer slashing.\\n *\\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\\n * producer when (s)he is slashed with tier-2 or tier-3.\\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\\n * slashed with tier-2 or tier-3.\\n *\\n */\\n function getUnavailabilitySlashingConfigs()\\n external\\n view\\n returns (\\n uint256 _unavailabilityTier1Threshold,\\n uint256 _unavailabilityTier2Threshold,\\n uint256 _slashAmountForUnavailabilityTier2Threshold,\\n uint256 _jailDurationForUnavailabilityTier2Threshold\\n );\\n\\n /**\\n * @dev Sets the configs to slash block producers.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\\n *\\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\\n * self-staking if (s)he misses more than this threshold.\\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\\n * is slashed tier-2.\\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\\n *\\n */\\n function setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) external;\\n}\\n\",\"keccak256\":\"0x458a7ae130a59b59b7f095fe3d4db8f779e0614041e5615f0afd36c543ac2046\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/BridgeOperatorsBallot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\\\";\\nimport \\\"../utils/CommonErrors.sol\\\";\\n\\nlibrary BridgeOperatorsBallot {\\n /**\\n * @dev Error thrown when an invalid order of the bridge operator is detected.\\n */\\n error ErrInvalidOrderOfBridgeOperator();\\n\\n struct BridgeOperatorSet {\\n uint256 period;\\n uint256 epoch;\\n address[] operators;\\n }\\n\\n // keccak256(\\\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\\\");\\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\\n\\n /**\\n * @dev Verifies whether the ballot is valid or not.\\n *\\n * Requirements:\\n * - The ballot is not for an empty operator set.\\n * - The operator address list is in order.\\n *\\n */\\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\\n\\n address _addr = _ballot.operators[0];\\n for (uint _i = 1; _i < _ballot.operators.length; ) {\\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\\n _addr = _ballot.operators[_i];\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Returns hash of the ballot.\\n */\\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\\n bytes32 operatorsHash;\\n address[] memory operators = self.operators;\\n\\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\\n assembly {\\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\\n let ptr := mload(0x40)\\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\\n mstore(add(ptr, 0x60), operatorsHash)\\n digest_ := keccak256(ptr, 0x80)\\n }\\n }\\n}\\n\",\"keccak256\":\"0x7671f6e599d5a33fa1e97538b1c8e04159337da5701eb6fa07b29d0566f57f81\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\"},\"contracts/precompile-usages/PCUValidateDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\\n /// @dev Gets the address of the precompile of validating double sign evidence\\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\\n return address(0x67);\\n }\\n\\n /**\\n * @dev Validates the two submitted block header if they are produced by the same address\\n *\\n * Note: The recover process is done by pre-compiled contract. This function is marked as\\n * virtual for implementing mocking contract for testing purpose.\\n */\\n function _pcValidateEvidence(\\n address _consensusAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) internal view virtual returns (bool _validEvidence) {\\n address _smc = precompileValidateDoubleSignAddress();\\n bool _success = true;\\n\\n bytes memory _payload = abi.encodeWithSignature(\\n \\\"validatingDoubleSignProof(address,bytes,bytes)\\\",\\n _consensusAddr,\\n _header1,\\n _header2\\n );\\n uint _payloadLength = _payload.length;\\n uint[1] memory _output;\\n\\n assembly {\\n let _payloadStart := add(_payload, 0x20)\\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\\n _success := 0\\n }\\n\\n if iszero(returndatasize()) {\\n _success := 0\\n }\\n }\\n\\n if (!_success) revert ErrCallPrecompiled();\\n return (_output[0] != 0);\\n }\\n}\\n\",\"keccak256\":\"0x9df5b8272e1cd963d776b94e29a69ba1139f0df7404b67c213b3c5ebe19e527b\",\"license\":\"MIT\"},\"contracts/precompile-usages/PCUValidateFastFinality.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\\n /// @dev Gets the address of the precompile of validating double sign evidence\\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\\n return address(0x69);\\n }\\n\\n /**\\n * @dev Validates the proof of malicious voting on fast finality\\n *\\n * Note: The recover process is done by pre-compiled contract. This function is marked as\\n * virtual for implementing mocking contract for testing purpose.\\n */\\n function _pcValidateFastFinalityEvidence(\\n bytes memory voterPublicKey,\\n uint256 targetBlockNumber,\\n bytes32[2] memory targetBlockHash,\\n bytes[][2] memory listOfPublicKey,\\n bytes[2] memory aggregatedSignature\\n ) internal view virtual returns (bool validEvidence) {\\n address smc = precompileValidateFastFinalityAddress();\\n bool success = true;\\n\\n bytes memory payload = abi.encodeWithSignature(\\n \\\"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\\\",\\n voterPublicKey,\\n targetBlockNumber,\\n targetBlockHash,\\n listOfPublicKey,\\n aggregatedSignature\\n );\\n uint payloadLength = payload.length;\\n uint[1] memory output;\\n\\n assembly {\\n let payloadStart := add(payload, 0x20)\\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\\n success := 0\\n }\\n\\n if iszero(returndatasize()) {\\n success := 0\\n }\\n }\\n\\n if (!success) revert ErrCallPrecompiled();\\n return (output[0] != 0);\\n }\\n}\\n\",\"keccak256\":\"0x99a8bb36a8b3fecd3865fdfdda61ecd5daf3e26dba78ff844a2349a8a07d1ace\",\"license\":\"MIT\"},\"contracts/precompile-usages/PrecompiledUsage.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./PrecompiledUsage.sol\\\";\\n\\nabstract contract PrecompiledUsage {\\n /// @dev Error of call to precompile fails.\\n error ErrCallPrecompiled();\\n}\\n\",\"keccak256\":\"0x76facc3f3a8dd573c826bbbfedaa5cd8ef30963fbabd8c163c0c72b6efea5551\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/CreditScore.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/IMaintenance.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ICreditScore.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\nimport { ErrUnauthorized, RoleAccess } from \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract CreditScore is\\n ICreditScore,\\n HasContracts,\\n HasValidatorDeprecated,\\n HasMaintenanceDeprecated,\\n PercentageConsumer\\n{\\n /// @dev Mapping from validator address => period index => whether bailed out before\\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\\n /// @dev Mapping from validator address => credit score\\n mapping(address => uint256) internal _creditScore;\\n\\n /// @dev The max gained number of credit score per period.\\n uint256 internal _gainCreditScore;\\n /// @dev The max number of credit score that a validator can hold.\\n uint256 internal _maxCreditScore;\\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\\n uint256 internal _bailOutCostMultiplier;\\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\\n uint256 internal _cutOffPercentageAfterBailout;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function updateCreditScores(\\n address[] calldata _validators,\\n uint256 _period\\n ) external override onlyContract(ContractType.VALIDATOR) {\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\\n\\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\\n _validators,\\n _periodStartAtBlock,\\n block.number\\n );\\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\\n\\n for (uint _i = 0; _i < _validators.length; ) {\\n address _validator = _validators[_i];\\n\\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\\n bool _isJailedInPeriod = _jaileds[_i];\\n bool _isMaintainingInPeriod = _maintaineds[_i];\\n\\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\\n ? 0\\n : Math.subNonNegative(_gainCreditScore, _indicator);\\n\\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\\n _updatedCreditScores[_i] = _creditScore[_validator];\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\\n }\\n\\n function execResetCreditScores(\\n address[] calldata _validators\\n ) external override onlyContract(ContractType.VALIDATOR) {\\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\\n for (uint _i = 0; _i < _validators.length; ) {\\n address _validator = _validators[_i];\\n delete _creditScore[_validator];\\n delete _updatedCreditScores[_i];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function bailOut(address _consensusAddr) external override {\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\\n\\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\\n\\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\\n\\n uint256 _period = _validatorContract.currentPeriod();\\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\\n\\n uint256 _score = _creditScore[_consensusAddr];\\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\\n\\n _validatorContract.execBailOut(_consensusAddr, _period);\\n\\n _creditScore[_consensusAddr] -= _cost;\\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\\n emit BailedOut(_consensusAddr, _period, _cost);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) external override onlyAdmin {\\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\\n }\\n\\n /**\\n * @dev See `ISlashUnavailability`\\n */\\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getCreditScoreConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 gainCreditScore_,\\n uint256 maxCreditScore_,\\n uint256 bailOutCostMultiplier_,\\n uint256 cutOffPercentageAfterBailout_\\n )\\n {\\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getCreditScore(address _validator) external view override returns (uint256) {\\n return _creditScore[_validator];\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function getManyCreditScores(\\n address[] calldata _validators\\n ) public view override returns (uint256[] memory _resultList) {\\n _resultList = new uint256[](_validators.length);\\n\\n for (uint _i = 0; _i < _resultList.length; ) {\\n _resultList[_i] = _creditScore[_validators[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\\n return _checkBailedOutAtPeriod[_validator][_period];\\n }\\n\\n /**\\n * @dev See `SlashUnavailability`.\\n */\\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\\n\\n /**\\n * @dev See `ICreditScore-setCreditScoreConfigs`.\\n */\\n function _setCreditScoreConfigs(\\n uint256 _gainScore,\\n uint256 _maxScore,\\n uint256 _bailOutMultiplier,\\n uint256 _cutOffPercentage\\n ) internal {\\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\\n\\n _gainCreditScore = _gainScore;\\n _maxCreditScore = _maxScore;\\n _bailOutCostMultiplier = _bailOutMultiplier;\\n _cutOffPercentageAfterBailout = _cutOffPercentage;\\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\\n }\\n}\\n\",\"keccak256\":\"0xb4321e0140e8a0ceb0b41e8a65d6448fbb2a74c56233fb0aa4a7769016d2b5c6\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashBridgeOperator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../extensions/collections/HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\n\\nabstract contract SlashBridgeOperator is\\n ISlashBridgeOperator,\\n HasProxyAdmin,\\n HasContracts,\\n HasValidatorDeprecated,\\n PercentageConsumer\\n{\\n /**\\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\\n * Values 0-10,000 map to 0%-100%.\\n */\\n uint256 internal _missingVotesRatioTier1;\\n /**\\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\\n * more than the ratio. Values 0-10,000 map to 0%-100%.\\n */\\n uint256 internal _missingVotesRatioTier2;\\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\\n uint256 internal _jailDurationForMissingVotesRatioTier2;\\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\\n uint256 internal _skipBridgeOperatorSlashingThreshold;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function getBridgeOperatorSlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 missingVotesRatioTier1_,\\n uint256 missingVotesRatioTier2_,\\n uint256 jailDurationForMissingVotesRatioTier2_,\\n uint256 skipBridgeOperatorSlashingThreshold_\\n )\\n {\\n return (\\n _missingVotesRatioTier1,\\n _missingVotesRatioTier2,\\n _jailDurationForMissingVotesRatioTier2,\\n _skipBridgeOperatorSlashingThreshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) external override onlyAdmin {\\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeOperator\\n */\\n function execSlashBridgeOperator(\\n address _consensusAddr,\\n uint256 _tier,\\n uint256 _period\\n ) external onlyContract(ContractType.VALIDATOR) {\\n if (_tier == 1) {\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\\n } else if (_tier == 2) {\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\\n }\\n }\\n\\n /**\\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\\n */\\n function _setBridgeOperatorSlashingConfigs(\\n uint256 _ratioTier1,\\n uint256 _ratioTier2,\\n uint256 _jailDurationTier2,\\n uint256 _skipSlashingThreshold\\n ) internal {\\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\\n revert ErrInvalidRatios();\\n }\\n\\n _missingVotesRatioTier1 = _ratioTier1;\\n _missingVotesRatioTier2 = _ratioTier2;\\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\\n }\\n}\\n\",\"keccak256\":\"0xb8125efc8cced5cd5e57be1e1ad25553439c6470545ef9eee79fb45d8774b18e\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashBridgeVoting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../libraries/Math.sol\\\";\\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\nimport { IBridgeAdminProposal } from \\\"../../interfaces/IBridgeAdminProposal.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\\\";\\nimport \\\"../../interfaces/IRoninTrustedOrganization.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\n\\n// TODO: remove this from slashing logic of consensus contract\\nabstract contract SlashBridgeVoting is\\n ISlashBridgeVoting,\\n HasContracts,\\n HasValidatorDeprecated,\\n HasTrustedOrgDeprecated,\\n HasGovernanceAdminDeprecated\\n{\\n /// @dev Mapping from validator address => period index => bridge voting slashed\\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\\n uint256 internal _bridgeVotingThreshold;\\n /// @dev The amount of RON to slash bridge voting.\\n uint256 internal _bridgeVotingSlashAmount;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\\n ).getTrustedOrganization(_consensusAddr);\\n uint256 _lastVotedBlock = Math.max(\\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\\n _org.addedBlock\\n );\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 _period = _validatorContract.currentPeriod();\\n\\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\\n revert ErrInvalidSlash();\\n\\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function getBridgeVotingSlashingConfigs()\\n external\\n view\\n override\\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\\n {\\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\\n }\\n\\n /**\\n * @inheritdoc ISlashBridgeVoting\\n */\\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\\n }\\n\\n /**\\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\\n */\\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\\n _bridgeVotingThreshold = _threshold;\\n _bridgeVotingSlashAmount = _slashAmount;\\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\\n }\\n}\\n\",\"keccak256\":\"0x807b11148e3db8b738dda824fa3c333d143cc9f3d5faf44297d81a8556dd14b7\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashDoubleSign.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/slash-indicator/ISlashDoubleSign.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../precompile-usages/PCUValidateDoubleSign.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\n\\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\\n /// @dev The amount of RON to slash double sign.\\n uint256 internal _slashDoubleSignAmount;\\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\\n uint256 internal _doubleSigningJailUntilBlock;\\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\\n * This parameter is exposed for system transaction.\\n **/\\n uint256 internal _doubleSigningOffsetLimitBlock;\\n /// @dev Recording of submitted proof to prevent relay attack.\\n mapping(bytes32 => bool) _submittedEvidence;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[24] private ______gap;\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function slashDoubleSign(\\n address _consensusAddr,\\n bytes calldata _header1,\\n bytes calldata _header2\\n ) external override onlyAdmin {\\n bytes32 _header1Checksum = keccak256(_header1);\\n bytes32 _header2Checksum = keccak256(_header2);\\n\\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\\n revert ErrEvidenceAlreadySubmitted();\\n }\\n\\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 _period = _validatorContract.currentPeriod();\\n _submittedEvidence[_header1Checksum] = true;\\n _submittedEvidence[_header2Checksum] = true;\\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\\n }\\n }\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function getDoubleSignSlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 slashDoubleSignAmount_,\\n uint256 doubleSigningJailUntilBlock_,\\n uint256 doubleSigningOffsetLimitBlock_\\n )\\n {\\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\\n }\\n\\n /**\\n * @inheritdoc ISlashDoubleSign\\n */\\n function setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _offsetLimitBlock\\n ) external override onlyAdmin {\\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\\n }\\n\\n /**\\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\\n */\\n function _setDoubleSignSlashingConfigs(\\n uint256 _slashAmount,\\n uint256 _jailUntilBlock,\\n uint256 _offsetLimitBlock\\n ) internal {\\n _slashDoubleSignAmount = _slashAmount;\\n _doubleSigningJailUntilBlock = _jailUntilBlock;\\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\\n }\\n\\n /**\\n * @dev Returns whether the account `_addr` should be slashed or not.\\n */\\n function _shouldSlash(address _addr) internal view virtual returns (bool);\\n}\\n\",\"keccak256\":\"0x2adce411c8e4ab69c76a5c3be69c7ae3dde7278d560f9db406c4ba4385b056b1\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashFastFinality.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/slash-indicator/ISlashFastFinality.sol\\\";\\nimport { IRoninValidatorSet } from \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport { IProfile } from \\\"../../interfaces/IProfile.sol\\\";\\nimport { IRoninTrustedOrganization } from \\\"../../interfaces/IRoninTrustedOrganization.sol\\\";\\nimport \\\"../../precompile-usages/PCUValidateFastFinality.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\\n /// @dev The amount of RON to slash fast finality.\\n uint256 internal _slashFastFinalityAmount;\\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\\n uint256 internal _fastFinalityJailUntilBlock;\\n /// @dev Recording of submitted proof to prevent relay attack.\\n mapping(bytes32 => bool) internal _processedEvidence;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[21] private ______gap;\\n\\n modifier onlyGoverningValidator() {\\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\\n _;\\n }\\n\\n /**\\n * @inheritdoc ISlashFastFinality\\n */\\n function slashFastFinality(\\n address consensusAddr,\\n bytes calldata voterPublicKey,\\n uint256 targetBlockNumber,\\n bytes32[2] calldata targetBlockHash,\\n bytes[][2] calldata listOfPublicKey,\\n bytes[2] calldata aggregatedSignature\\n ) external override onlyGoverningValidator {\\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\\n\\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\\n\\n if (\\n _pcValidateFastFinalityEvidence(\\n voterPublicKey,\\n targetBlockNumber,\\n targetBlockHash,\\n listOfPublicKey,\\n aggregatedSignature\\n )\\n ) {\\n _processedEvidence[evidenceHash] = true;\\n\\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 period = validatorContract.currentPeriod();\\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\\n validatorContract.execSlash({\\n validatorAddr: consensusAddr,\\n newJailedUntil: _fastFinalityJailUntilBlock,\\n slashAmount: _slashFastFinalityAmount,\\n cannotBailout: true\\n });\\n }\\n }\\n\\n /**\\n * @inheritdoc ISlashFastFinality\\n */\\n function getFastFinalitySlashingConfigs()\\n external\\n view\\n override\\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\\n {\\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\\n }\\n\\n /**\\n * @inheritdoc ISlashFastFinality\\n */\\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\\n }\\n\\n /**\\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\\n */\\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\\n _slashFastFinalityAmount = slashAmount;\\n _fastFinalityJailUntilBlock = jailUntilBlock;\\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\\n }\\n\\n /**\\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\\n */\\n function _getGovernorWeight(address addr) internal view returns (uint256) {\\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\\n }\\n}\\n\",\"keccak256\":\"0xf6b0b7c990ca14465ffe0fac805003f425fa833df505a6f763421251786f77c8\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashIndicator.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashIndicator.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../interfaces/IMaintenance.sol\\\";\\nimport \\\"./SlashDoubleSign.sol\\\";\\nimport \\\"./SlashFastFinality.sol\\\";\\nimport \\\"./SlashBridgeVoting.sol\\\";\\nimport \\\"./SlashBridgeOperator.sol\\\";\\nimport \\\"./SlashUnavailability.sol\\\";\\nimport \\\"./CreditScore.sol\\\";\\n\\ncontract SlashIndicator is\\n ISlashIndicator,\\n SlashDoubleSign,\\n SlashFastFinality,\\n SlashBridgeVoting,\\n SlashBridgeOperator,\\n SlashUnavailability,\\n CreditScore,\\n Initializable\\n{\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n address __maintenanceContract,\\n address __roninTrustedOrganizationContract,\\n address __roninGovernanceAdminContract,\\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\\n uint256[2] calldata _bridgeVotingSlashingConfigs,\\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\\n uint256[3] calldata _doubleSignSlashingConfigs,\\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\\n uint256[4] calldata _unavailabilitySlashingConfigs,\\n // _creditScoreConfigs[0]: _gainCreditScore\\n // _creditScoreConfigs[1]: _maxCreditScore\\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\\n uint256[4] calldata _creditScoreConfigs\\n ) external initializer {\\n _setContract(ContractType.VALIDATOR, __validatorContract);\\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\\n\\n _setBridgeOperatorSlashingConfigs(\\n _bridgeOperatorSlashingConfigs[0],\\n _bridgeOperatorSlashingConfigs[1],\\n _bridgeOperatorSlashingConfigs[2],\\n _bridgeOperatorSlashingConfigs[3]\\n );\\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\\n _setDoubleSignSlashingConfigs(\\n _doubleSignSlashingConfigs[0],\\n _doubleSignSlashingConfigs[1],\\n _doubleSignSlashingConfigs[2]\\n );\\n _setUnavailabilitySlashingConfigs(\\n _unavailabilitySlashingConfigs[0],\\n _unavailabilitySlashingConfigs[1],\\n _unavailabilitySlashingConfigs[2],\\n _unavailabilitySlashingConfigs[3]\\n );\\n _setCreditScoreConfigs(\\n _creditScoreConfigs[0],\\n _creditScoreConfigs[1],\\n _creditScoreConfigs[2],\\n _creditScoreConfigs[3]\\n );\\n }\\n\\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\\n\\n delete ______deprecatedValidator;\\n delete ______deprecatedMaintenance;\\n delete ______deprecatedTrustedOrg;\\n delete ______deprecatedGovernanceAdmin;\\n }\\n\\n function initializeV3(address profileContract) external reinitializer(3) {\\n _setContract(ContractType.PROFILE, profileContract);\\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\\n }\\n\\n /**\\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\\n */\\n function _setUnavailabilityIndicator(\\n address _validator,\\n uint256 _period,\\n uint256 _indicator\\n ) internal override(CreditScore, SlashUnavailability) {\\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\\n }\\n\\n /**\\n * @dev Helper for CreditScore contract to query indicator of the validator.\\n */\\n function getUnavailabilityIndicator(\\n address _validator,\\n uint256 _period\\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\\n }\\n\\n /**\\n * @inheritdoc ICreditScore\\n */\\n function checkBailedOutAtPeriod(\\n address _validator,\\n uint256 _period\\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\\n }\\n\\n /**\\n * @dev Sanity check the address to be slashed\\n */\\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\\n return\\n (msg.sender != _addr) &&\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\\n }\\n}\\n\",\"keccak256\":\"0x816f24425b181c235f79da66bef32609574c1df7d801e705be67db022a2c69d9\",\"license\":\"MIT\"},\"contracts/ronin/slash-indicator/SlashUnavailability.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./CreditScore.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../interfaces/slash-indicator/ISlashUnavailability.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\nimport { ErrInvalidThreshold } from \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\\n /// @dev The last block that a validator is slashed for unavailability.\\n uint256 public lastUnavailabilitySlashedBlock;\\n /// @dev Mapping from validator address => period index => unavailability indicator.\\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\\n\\n /**\\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\\n */\\n uint256 internal _unavailabilityTier1Threshold;\\n /**\\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\\n */\\n uint256 internal _unavailabilityTier2Threshold;\\n /**\\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\\n * tier-2 or tier-3.\\n **/\\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n modifier oncePerBlock() {\\n if (block.number <= lastUnavailabilitySlashedBlock) {\\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\\n }\\n\\n lastUnavailabilitySlashedBlock = block.number;\\n _;\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\\n\\n if (!_shouldSlash(_validatorAddr)) {\\n // Should return instead of throwing error since this is a part of system transaction.\\n return;\\n }\\n\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n uint256 _period = _validatorContract.currentPeriod();\\n uint256 _count;\\n unchecked {\\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\\n }\\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\\n\\n if (_count == _unavailabilityTier2Threshold) {\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\\n _validatorContract.execSlash(\\n _validatorAddr,\\n _newJailedUntilBlock,\\n _slashAmountForUnavailabilityTier2Threshold,\\n false\\n );\\n } else if (_count == _unavailabilityTier1Threshold) {\\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\\n if (!_tier1SecondTime) {\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\\n } else {\\n /// Handles tier-3\\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\\n _validatorContract.execSlash(\\n _validatorAddr,\\n _newJailedUntilBlock,\\n _slashAmountForUnavailabilityTier2Threshold,\\n true\\n );\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) external override onlyAdmin {\\n _setUnavailabilitySlashingConfigs(\\n _tier1Threshold,\\n _tier2Threshold,\\n _slashAmountForTier2Threshold,\\n _jailDurationForTier2Threshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function getUnavailabilitySlashingConfigs()\\n external\\n view\\n override\\n returns (\\n uint256 unavailabilityTier1Threshold_,\\n uint256 unavailabilityTier2Threshold_,\\n uint256 slashAmountForUnavailabilityTier2Threshold_,\\n uint256 jailDurationForUnavailabilityTier2Threshold_\\n )\\n {\\n return (\\n _unavailabilityTier1Threshold,\\n _unavailabilityTier2Threshold,\\n _slashAmountForUnavailabilityTier2Threshold,\\n _jailDurationForUnavailabilityTier2Threshold\\n );\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\\n return\\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\\n }\\n\\n /**\\n * @inheritdoc ISlashUnavailability\\n */\\n function getUnavailabilityIndicator(\\n address _validator,\\n uint256 _period\\n ) public view virtual override returns (uint256) {\\n return _unavailabilityIndicator[_validator][_period];\\n }\\n\\n /**\\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\\n */\\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\\n _unavailabilityIndicator[_validator][_period] = _indicator;\\n }\\n\\n /**\\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\\n */\\n function _setUnavailabilitySlashingConfigs(\\n uint256 _tier1Threshold,\\n uint256 _tier2Threshold,\\n uint256 _slashAmountForTier2Threshold,\\n uint256 _jailDurationForTier2Threshold\\n ) internal {\\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\\n\\n _unavailabilityTier1Threshold = _tier1Threshold;\\n _unavailabilityTier2Threshold = _tier2Threshold;\\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\\n emit UnavailabilitySlashingConfigsUpdated(\\n _tier1Threshold,\\n _tier2Threshold,\\n _slashAmountForTier2Threshold,\\n _jailDurationForTier2Threshold\\n );\\n }\\n\\n /**\\n * @dev Returns whether the account `_addr` should be slashed or not.\\n */\\n function _shouldSlash(address _addr) internal view virtual returns (bool);\\n\\n /**\\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\\n */\\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\\n}\\n\",\"keccak256\":\"0x77e1f62b033c810f9847fefeca1b7b4e3cf7b5dd754928fd765da57512a29b4d\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/DeprecatedSlots.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\n/**\\n * @title Deprecated Contracts\\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\\n * They provide functionality related to various aspects of a smart contract but have been marked\\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\\n */\\ncontract HasSlashIndicatorDeprecated {\\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\\n address internal ______deprecatedSlashIndicator;\\n}\\n\\ncontract HasStakingVestingDeprecated {\\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\\n address internal ______deprecatedStakingVesting;\\n}\\n\\ncontract HasBridgeDeprecated {\\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\\n address internal ______deprecatedBridge;\\n}\\n\\ncontract HasValidatorDeprecated {\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address internal ______deprecatedValidator;\\n}\\n\\ncontract HasStakingDeprecated {\\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\\n address internal ______deprecatedStakingContract;\\n}\\n\\ncontract HasMaintenanceDeprecated {\\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\\n address internal ______deprecatedMaintenance;\\n}\\n\\ncontract HasTrustedOrgDeprecated {\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address internal ______deprecatedTrustedOrg;\\n}\\n\\ncontract HasGovernanceAdminDeprecated {\\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\\n address internal ______deprecatedGovernanceAdmin;\\n}\\n\\ncontract HasBridgeTrackingDeprecated {\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address internal ______deprecatedBridgeTracking;\\n}\\n\",\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x60806040523480156200001157600080fd5b506200001c62000022565b620000e7565b61011354610100900460ff1615620000905760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b6101135460ff9081161015620000e557610113805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b6133f780620000f76000396000f3fe608060405234801561001057600080fd5b50600436106101fb5760003560e01c806399103f7b1161011a578063d1cf4343116100ad578063df4b6ee01161007c578063df4b6ee01461046e578063e9bb166614610492578063f1001e7814610499578063f562b3c4146104b9578063fd422cd0146104c257600080fd5b8063d1cf43431461040c578063d1f992f71461041f578063d3dd2bdf14610432578063de981f1b1461045b57600080fd5b8063c6391fa2116100e9578063c6391fa2146103c2578063ccbb72ed146103d3578063cf39d13c146103e6578063d1737e27146103f957600080fd5b806399103f7b1461037e578063a345ecb214610391578063c008ce39146103a4578063c2e524dc146103b757600080fd5b80633101cfcb116101925780637680850c116101615780637680850c1461032a5780637c2b55a01461033d578063853af1b714610358578063865e6fd31461036b57600080fd5b80633101cfcb146102d75780633d48fd7d146102ea578063487e00ea146102fb57806362ffe6cb1461031757600080fd5b80631a697341116101ce5780631a6973411461027b5780631e90b2a01461028e57806329b6eca9146102a157806329ddc3c0146102b457600080fd5b806307c2d2f614610200578063082e7420146102155780630e1512ac1461023b5780631079402a1461024e575b600080fd5b61021361020e3660046125ad565b6104d5565b005b610228610223366004612603565b6105e2565b6040519081526020015b60405180910390f35b610213610249366004612620565b610659565b606d54606e54606f546070545b604080519485526020850193909352918301526060820152608001610232565b610213610289366004612603565b610673565b61021361029c366004612693565b610914565b6102136102af366004612603565b610afc565b6102c76102c2366004612715565b610c20565b6040519015158152602001610232565b6102136102e5366004612603565b610c4f565b60a55460a65460a75460a85461025b565b601d54601e545b60408051928352602083019190915201610232565b610228610325366004612715565b610cfc565b610213610338366004612741565b610d25565b60675b6040516001600160a01b039091168152602001610232565b61021361036636600461278c565b61103b565b6102136103793660046127bd565b611051565b61021361038c366004612816565b61106c565b61021361039f36600461278c565b6111d7565b6102136103b23660046128d4565b6111e9565b603854603954610302565b60dd5460de5460df5460e05461025b565b6102136103e1366004612620565b611273565b6102136103f4366004612909565b611287565b610213610407366004612620565b61129f565b61021361041a366004612935565b6112b3565b61021361042d366004612603565b6115df565b610228610440366004612603565b6001600160a01b0316600090815260dc602052604090205490565b6103406104693660046129f3565b6119ce565b60015460025460035460408051938452602084019290925290820152606001610232565b6069610340565b6104ac6104a73660046125ad565b611a49565b6040516102329190612a49565b61022860a35481565b6102136104d0366004612603565b611b13565b60086104e081611e27565b6000826001600160401b038111156104fa576104fa612a5c565b604051908082528060200260200182016040528015610523578160200160208202803683370190505b50905060005b838110156105a057600085858381811061054557610545612a72565b905060200201602081019061055a9190612603565b6001600160a01b038116600090815260dc6020526040812055835190915083908390811061058a5761058a612a72565b6000602091820292909201015250600101610529565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c234808484836040516105d493929190612ac6565b60405180910390a150505050565b6000610653826105f260086119ce565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561062f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103259190612af6565b92915050565b610661611e73565b61066d84848484611ecf565b50505050565b61067b611e73565b6000610687600a6119ce565b604051636db349d160e11b81526001600160a01b038481166004830152919091169063db6693a29060240160a060405180830381865afa1580156106cf573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106f39190612b94565b9050600061077d610704600b6119ce565b6040808501519051632623bd4f60e21b81526001600160a01b03918216600482015291169063988ef53c90602401602060405180830381865afa15801561074f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107739190612af6565b8360800151611f61565b9050600061078b60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107cd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f19190612af6565b6038549091506108018443612c31565b11158061083157506001600160a01b038516600090815260376020908152604080832084845290915290205460ff165b1561084f57604051632e308a0b60e11b815260040160405180910390fd5b6001600160a01b038516600081815260376020908152604080832085845290915290819020805460ff19166001179055516000805160206133a28339815191529061089e906004908590612c5a565b60405180910390a2603954604051630bde081360e21b81526001600160a01b03841691632f78204c916108db918991600091908290600401612c78565b600060405180830381600087803b1580156108f557600080fd5b505af1158015610909573d6000803e3d6000fd5b505050505050505050565b61091c611e73565b6000848460405161092e929190612ca0565b604051809103902090506000838360405161094a929190612ca0565b604080519182900390912060008481526004602052919091205490915060ff1680610983575060008181526004602052604090205460ff165b156109a15760405163f27b8ec960e01b815260040160405180910390fd5b6109ae8787878787611f78565b15610af35760006109bf60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a01573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a259190612af6565b6000858152600460205260408082208054600160ff19918216811790925587845292829020805490931617909155519091506001600160a01b038a16906000805160206133a283398151915290610a80906003908590612c5a565b60405180910390a260025460018054604051630bde081360e21b81526001600160a01b03861693632f78204c93610abe938f93909190600401612c78565b600060405180830381600087803b158015610ad857600080fd5b505af1158015610aec573d6000803e3d6000fd5b5050505050505b50505050505050565b61011354600290610100900460ff16158015610b2057506101135460ff8083169116105b610b455760405162461bcd60e51b8152600401610b3c90612cb0565b60405180910390fd5b610113805461ffff191660ff831617610100179055600054610b72906008906001600160a01b0316612022565b606c54610b8a906005906001600160a01b0316612022565b610b95600483612022565b603554610bad90600a906001600160a01b0316612022565b600080546001600160a01b0319908116909155606c8054821690556035805482169055603680549091169055610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b61011354600390610100900460ff16158015610c7357506101135460ff8083169116105b610c8f5760405162461bcd60e51b8152600401610b3c90612cb0565b610113805461ffff191660ff831617610100179055610caf600f83612022565b610cbd6001546002546120c6565b610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610c14565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610c48565b6008610d3081611e27565b60003390506000816001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d75573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d999190612af6565b90506000826001600160a01b0316634de2b73588886040518363ffffffff1660e01b8152600401610dcb929190612cfe565b600060405180830381865afa158015610de8573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e109190810190612d45565b90506000610e1e60056119ce565b6001600160a01b031663ba303755898986436040518563ffffffff1660e01b8152600401610e4f9493929190612de1565b600060405180830381865afa158015610e6c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e949190810190612d45565b90506000876001600160401b03811115610eb057610eb0612a5c565b604051908082528060200260200182016040528015610ed9578160200160208202803683370190505b50905060005b88811015610ff45760008a8a83818110610efb57610efb612a72565b9050602002016020810190610f109190612603565b90506000610f1e828b610cfc565b90506000868481518110610f3457610f34612a72565b602002602001015190506000868581518110610f5257610f52612a72565b6020026020010151905060008280610f675750815b610f7c57610f7760dd5485612106565b610f7f565b60005b6001600160a01b038616600090815260dc602052604090205460de54919250610fa9918390612120565b6001600160a01b038616600090815260dc602052604090208190558751889088908110610fd857610fd8612a72565b6020026020010181815250508560010195505050505050610edf565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c2348089898360405161102893929190612ac6565b60405180910390a1505050505050505050565b611043611e73565b61104d828261213d565b5050565b611059611e73565b6110628161217d565b61104d8282612022565b61011354610100900460ff161580801561108e575061011354600160ff909116105b806110a95750303b1580156110a957506101135460ff166001145b6110c55760405162461bcd60e51b8152600401610b3c90612cb0565b610113805460ff1916600117905580156110ea57610113805461ff0019166101001790555b6110f560088b612022565b61110060058a612022565b61110b600488612022565b611116600a89612022565b61112f86356020880135604089013560608a0135611ecf565b61113e8535602087013561213d565b6111528435602086013560408701356121b3565b61116b8335602085013560408601356060870135612208565b6111848235602084013560408501356060860135612294565b80156111cb57610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6111df611e73565b61104d82826120c6565b60086111f481611e27565b8260010361123357836001600160a01b03166000805160206133a2833981519152600584604051611226929190612c5a565b60405180910390a261066d565b8260020361066d57836001600160a01b03166000805160206133a2833981519152600684604051611265929190612c5a565b60405180910390a250505050565b61127b611e73565b61066d84848484612294565b61128f611e73565b61129a8383836121b3565b505050565b6112a7611e73565b61066d84848484612208565b6112bc33612331565b6000036112ec576000356001600160e01b0319166003604051620f948f60ea1b8152600401610b3c929190612e08565b60006112f8600f6119ce565b6040516303d1982560e61b81526001600160a01b038a8116600483015291925060009183169063f466094090602401600060405180830381865afa158015611344573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261136c9190810190612ec6565b60a0015190508080519060200120888860405161138a929190612ca0565b6040518091039020146113be5760405163053265f160e01b81526001600160e01b0319600035166004820152602401610b3c565b6040516bffffffffffffffffffffffff1960608b901b1660208201526034810187905260009060540160408051601f1981840301815291815281516020928301206000818152601f90935291205490915060ff16156114305760405163f27b8ec960e01b815260040160405180910390fd5b6114a689898080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250506040805180820182528c935091508a90600290839083908082843760009201919091525061149891508a9050612fde565b6114a1896130b5565b6123a9565b156111cb576000818152601f60205260408120805460ff191660011790556114ce60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611510573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115349190612af6565b90508b6001600160a01b03166000805160206133a2833981519152600883604051611560929190612c5a565b60405180910390a2816001600160a01b0316632f78204c8d601e54601d5460016040518563ffffffff1660e01b815260040161159f9493929190612c78565b600060405180830381600087803b1580156115b957600080fd5b505af11580156115cd573d6000803e3d6000fd5b50505050505050505050505050505050565b60006115eb60086119ce565b604051635061f96960e11b81526001600160a01b0384811660048301529192509082169063a0c3f2d290602401602060405180830381865afa158015611635573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611659919061310d565b611686576000356001600160e01b0319166008604051620f948f60ea1b8152600401610b3c929190612e08565b6040516304d971ab60e01b81526001600160a01b0383811660048301523360248301528216906304d971ab90604401602060405180830381865afa1580156116d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116f6919061310d565b611723576000356001600160e01b0319166004604051620f948f60ea1b8152600401610b3c929190612e08565b604051634b2c2fe160e11b81526001600160a01b03838116600483015260009182918416906396585fc290602401606060405180830381865afa15801561176e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117929190613128565b9250509150816117b557604051636cd31b5960e01b815260040160405180910390fd5b6000836001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156117f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118199190612af6565b6001600160a01b038616600090815260db6020908152604080832084845290915290205490915060ff161561186157604051637674d6a960e01b815260040160405180910390fd5b6001600160a01b038516600090815260dc602052604081205460df5490919061188a908561315d565b9050808210156118ad5760405163462e593760e11b815260040160405180910390fd5b604051630adaf5ef60e11b81526001600160a01b038881166004830152602482018590528716906315b5ebde90604401600060405180830381600087803b1580156118f757600080fd5b505af115801561190b573d6000803e3d6000fd5b505050506001600160a01b038716600090815260dc602052604081208054839290611937908490612c31565b90915550506001600160a01b038716600090815260a4602090815260408083208684529091528120556001600160a01b038716600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a250505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115611a0557611a05612c44565b60ff1681526020810191909152604001600020546001600160a01b0316905080611a44578160405163409140df60e11b8152600401610b3c9190613188565b919050565b6060816001600160401b03811115611a6357611a63612a5c565b604051908082528060200260200182016040528015611a8c578160200160208202803683370190505b50905060005b8151811015611b0c5760dc6000858584818110611ab157611ab1612a72565b9050602002016020810190611ac69190612603565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611af957611af9612a72565b6020908102919091010152600101611a92565b5092915050565b60a3544311611b355760405163557fd09160e01b815260040160405180910390fd5b4360a355334114611b69576000356001600160e01b0319166002604051620f948f60ea1b8152600401610b3c929190612e08565b611b7281612404565b15611e24576000611b8360086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611bc5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611be99190612af6565b6001600160a01b038416600090815260a460209081526040808320848452909152812080546001019081905560a85492935091611c2790439061251a565b905060a6548203611cd057846001600160a01b03166000805160206133a2833981519152600285604051611c5c929190612c5a565b60405180910390a260a754604051630bde081360e21b81526001600160a01b03861691632f78204c91611c99918991869190600090600401612c78565b600060405180830381600087803b158015611cb357600080fd5b505af1158015611cc7573d6000803e3d6000fd5b50505050611e1f565b60a5548203611e1f576000611ce58685610c20565b905080611d8857856001600160a01b03166000805160206133a2833981519152600186604051611d16929190612c5a565b60405180910390a2604051630bde081360e21b81526001600160a01b03861690632f78204c90611d5190899060009081908190600401612c78565b600060405180830381600087803b158015611d6b57600080fd5b505af1158015611d7f573d6000803e3d6000fd5b50505050611e1d565b856001600160a01b03166000805160206133a2833981519152600786604051611db2929190612c5a565b60405180910390a260a754604051630bde081360e21b81526001600160a01b03871691632f78204c91611def918a91879190600190600401612c78565b600060405180830381600087803b158015611e0957600080fd5b505af11580156111cb573d6000803e3d6000fd5b505b505050505b50565b611e30816119ce565b6001600160a01b0316336001600160a01b031614611e24576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610b3c93929190613196565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611ecd576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b3c929190612e08565b565b82841180611ede575061271084115b80611eea575061271083115b15611f0857604051631cbe1abf60e11b815260040160405180910390fd5b606d849055606e839055606f82905560708190556040805185815260208101859052908101839052606081018290527fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b906080016105d4565b600081831015611f715781610c48565b5090919050565b6040516000906067906001908390611f9c908a908a908a908a908a906024016131f6565b60408051601f198184030181529190526020810180516001600160e01b0316637fc3567760e01b1790528051909150611fd3612544565b602083016020828483895afa611fe857600094505b503d611ff357600093505b8361201157604051630fc2632160e01b815260040160405180910390fd5b5115159a9950505050505050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561205857612058612c44565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f81111561209957612099612c44565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b601d829055601e81905560408051838152602081018390527f381ec200df2ed0875638486318f9f8a84e3550bdc686bf1400c9371a18d087f09101610c14565b6000818311612116576000610c48565b610c488284612c31565b600061213561212f848661323a565b83612535565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a9101610c14565b806001600160a01b03163b600003611e2457604051630bfc64a360e21b81526001600160a01b0382166004820152602401610b3c565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b9060600160405180910390a1505050565b60a65460a554111561223b576040516387f6f09560e01b81526001600160e01b0319600035166004820152602401610b3c565b60a584905560a683905560a782905560a88190556040805185815260208101859052908101839052606081018290527f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa98906080016105d4565b828411156122b55760405163112af4d160e01b815260040160405180910390fd5b6127108111156122d85760405163382c88a360e21b815260040160405180910390fd5b60dd84905560de83905560df82905560e08190556040805185815260208101859052908101839052606081018290527fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b906080016105d4565b600061233d600a6119ce565b604051631af0725f60e31b81526001600160a01b038481166004830152919091169063d78392f890602401602060405180830381865afa158015612385573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106539190612af6565b60405160009060699060019083906123cd908a908a908a908a908a906024016132be565b60408051601f198184030181529190526020810180516001600160e01b0316637b47d06b60e01b1790528051909150611fd3612544565b6000336001600160a01b03831614801590612490575061242460086119ce565b604051633292276760e11b81526001600160a01b03848116600483015291909116906365244ece90602401602060405180830381865afa15801561246c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612490919061310d565b801561065357506124a160056119ce565b604051630fbeb37f60e01b81526001600160a01b0384811660048301524360248301529190911690630fbeb37f90604401602060405180830381865afa1580156124ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612513919061310d565b1592915050565b60008160000361252b576000610c48565b610c48828461323a565b6000818310611f715781610c48565b60405180602001604052806001906020820280368337509192915050565b60008083601f84011261257457600080fd5b5081356001600160401b0381111561258b57600080fd5b6020830191508360208260051b85010111156125a657600080fd5b9250929050565b600080602083850312156125c057600080fd5b82356001600160401b038111156125d657600080fd5b6125e285828601612562565b90969095509350505050565b6001600160a01b0381168114611e2457600080fd5b60006020828403121561261557600080fd5b8135610c48816125ee565b6000806000806080858703121561263657600080fd5b5050823594602084013594506040840135936060013592509050565b60008083601f84011261266457600080fd5b5081356001600160401b0381111561267b57600080fd5b6020830191508360208285010111156125a657600080fd5b6000806000806000606086880312156126ab57600080fd5b85356126b6816125ee565b945060208601356001600160401b03808211156126d257600080fd5b6126de89838a01612652565b909650945060408801359150808211156126f757600080fd5b5061270488828901612652565b969995985093965092949392505050565b6000806040838503121561272857600080fd5b8235612733816125ee565b946020939093013593505050565b60008060006040848603121561275657600080fd5b83356001600160401b0381111561276c57600080fd5b61277886828701612562565b909790965060209590950135949350505050565b6000806040838503121561279f57600080fd5b50508035926020909101359150565b803560108110611a4457600080fd5b600080604083850312156127d057600080fd5b6127d9836127ae565b915060208301356127e9816125ee565b809150509250929050565b806080810183101561065357600080fd5b806040810183101561065357600080fd5b60008060008060008060008060006102a08a8c03121561283557600080fd5b8935612840816125ee565b985060208a0135612850816125ee565b975060408a0135612860816125ee565b965060608a0135612870816125ee565b955061287f8b60808c016127f4565b945061288f8b6101008c01612805565b93506101a08a018b8111156128a357600080fd5b6101408b0193506128b48c826127f4565b9250506128c58b6102208c016127f4565b90509295985092959850929598565b6000806000606084860312156128e957600080fd5b83356128f4816125ee565b95602085013595506040909401359392505050565b60008060006060848603121561291e57600080fd5b505081359360208301359350604090920135919050565b600080600080600080600060e0888a03121561295057600080fd5b873561295b816125ee565b965060208801356001600160401b038082111561297757600080fd5b6129838b838c01612652565b909850965060408a0135955086915061299f8b60608c01612805565b945060a08a01359150808211156129b557600080fd5b6129c18b838c01612805565b935060c08a01359150808211156129d757600080fd5b506129e48a828b01612805565b91505092959891949750929550565b600060208284031215612a0557600080fd5b610c48826127ae565b600081518084526020808501945080840160005b83811015612a3e57815187529582019590820190600101612a22565b509495945050505050565b602081526000610c486020830184612a0e565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b8183526000602080850194508260005b85811015612a3e578135612aab816125ee565b6001600160a01b031687529582019590820190600101612a98565b604081526000612ada604083018587612a88565b8281036020840152612aec8185612a0e565b9695505050505050565b600060208284031215612b0857600080fd5b5051919050565b60405160c081016001600160401b0381118282101715612b3157612b31612a5c565b60405290565b604080519081016001600160401b0381118282101715612b3157612b31612a5c565b604051601f8201601f191681016001600160401b0381118282101715612b8157612b81612a5c565b604052919050565b8051611a44816125ee565b600060a08284031215612ba657600080fd5b60405160a081018181106001600160401b0382111715612bc857612bc8612a5c565b6040528251612bd6816125ee565b81526020830151612be6816125ee565b60208201526040830151612bf9816125ee565b6040820152606083810151908201526080928301519281019290925250919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561065357610653612c1b565b634e487b7160e01b600052602160045260246000fd5b6040810160098410612c6e57612c6e612c44565b9281526020015290565b6001600160a01b03949094168452602084019290925260408301521515606082015260800190565b8183823760009101908152919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b602081526000612135602083018486612a88565b60006001600160401b03821115612d2b57612d2b612a5c565b5060051b60200190565b80518015158114611a4457600080fd5b60006020808385031215612d5857600080fd5b82516001600160401b03811115612d6e57600080fd5b8301601f81018513612d7f57600080fd5b8051612d92612d8d82612d12565b612b59565b81815260059190911b82018301908381019087831115612db157600080fd5b928401925b82841015612dd657612dc784612d35565b82529284019290840190612db6565b979650505050505050565b606081526000612df5606083018688612a88565b6020830194909452506040015292915050565b6001600160e01b03198316815260408101600b8310612e2957612e29612c44565b8260208301529392505050565b60006001600160401b03821115612e4f57612e4f612a5c565b50601f01601f191660200190565b60005b83811015612e78578181015183820152602001612e60565b50506000910152565b600082601f830112612e9257600080fd5b8151612ea0612d8d82612e36565b818152846020838601011115612eb557600080fd5b612135826020830160208701612e5d565b600060208284031215612ed857600080fd5b81516001600160401b0380821115612eef57600080fd5b9083019060c08286031215612f0357600080fd5b612f0b612b0f565b8251612f16816125ee565b81526020830151612f26816125ee565b60208201526040830151612f39816125ee565b6040820152612f4a60608401612b89565b6060820152612f5b60808401612b89565b608082015260a083015182811115612f7257600080fd5b612f7e87828601612e81565b60a08301525095945050505050565b600082601f830112612f9e57600080fd5b8135612fac612d8d82612e36565b818152846020838601011115612fc157600080fd5b816020850160208301376000918101602001919091529392505050565b6000612fe8612b37565b806040840136811115612ffa57600080fd5b845b818110156130ab5780356001600160401b038082111561301c5760008081fd5b9087019036601f8301126130305760008081fd5b81356020613040612d8d83612d12565b82815260059290921b840181019181810190368411156130605760008081fd5b8286015b848110156130985780358681111561307c5760008081fd5b61308a3686838b0101612f8d565b845250918301918301613064565b5089525090960195505050602001612ffc565b5090949350505050565b60006130bf612b37565b8060408401368111156130d157600080fd5b845b818110156130ab5780356001600160401b038111156130f25760008081fd5b6130fe36828901612f8d565b855250602093840193016130d3565b60006020828403121561311f57600080fd5b610c4882612d35565b60008060006060848603121561313d57600080fd5b61314684612d35565b925060208401519150604084015190509250925092565b808202811582820484141761065357610653612c1b565b6010811061318457613184612c44565b9052565b602081016106538284613174565b6001600160e01b031984168152606081016131b46020830185613174565b6001600160a01b03929092166040919091015292915050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b038616815260606020820181905260009061321b90830186886131cd565b828103604084015261322e8185876131cd565b98975050505050505050565b8082018082111561065357610653612c1b565b60008151808452613265816020860160208601612e5d565b601f01601f19169290920160200192915050565b600082604081018360005b60028110156132b357838303875261329d83835161324d565b6020978801979093509190910190600101613284565b509095945050505050565b60c0815260006132d160c083018861324d565b60208781850152604084018760005b60028110156132fd578151835291830191908301906001016132e0565b505050838203608085015281604081018760005b600281101561337e578583038452815180518085529086019086850190600581901b8601880160005b8281101561336857601f1988830301845261335682865161324d565b948a0194938a0193915060010161333a565b5096880196955050509185019150600101613311565b505085810360a08701526133928188613279565b9b9a505050505050505050505056fe607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9a2646970667358221220cfddcb1b8394b245c3e114318973b357369f77dc153b73b61838406a63127a0e64736f6c63430008110033", + "deployedBytecode": "0x608060405234801561001057600080fd5b50600436106101fb5760003560e01c806399103f7b1161011a578063d1cf4343116100ad578063df4b6ee01161007c578063df4b6ee01461046e578063e9bb166614610492578063f1001e7814610499578063f562b3c4146104b9578063fd422cd0146104c257600080fd5b8063d1cf43431461040c578063d1f992f71461041f578063d3dd2bdf14610432578063de981f1b1461045b57600080fd5b8063c6391fa2116100e9578063c6391fa2146103c2578063ccbb72ed146103d3578063cf39d13c146103e6578063d1737e27146103f957600080fd5b806399103f7b1461037e578063a345ecb214610391578063c008ce39146103a4578063c2e524dc146103b757600080fd5b80633101cfcb116101925780637680850c116101615780637680850c1461032a5780637c2b55a01461033d578063853af1b714610358578063865e6fd31461036b57600080fd5b80633101cfcb146102d75780633d48fd7d146102ea578063487e00ea146102fb57806362ffe6cb1461031757600080fd5b80631a697341116101ce5780631a6973411461027b5780631e90b2a01461028e57806329b6eca9146102a157806329ddc3c0146102b457600080fd5b806307c2d2f614610200578063082e7420146102155780630e1512ac1461023b5780631079402a1461024e575b600080fd5b61021361020e3660046125ad565b6104d5565b005b610228610223366004612603565b6105e2565b6040519081526020015b60405180910390f35b610213610249366004612620565b610659565b606d54606e54606f546070545b604080519485526020850193909352918301526060820152608001610232565b610213610289366004612603565b610673565b61021361029c366004612693565b610914565b6102136102af366004612603565b610afc565b6102c76102c2366004612715565b610c20565b6040519015158152602001610232565b6102136102e5366004612603565b610c4f565b60a55460a65460a75460a85461025b565b601d54601e545b60408051928352602083019190915201610232565b610228610325366004612715565b610cfc565b610213610338366004612741565b610d25565b60675b6040516001600160a01b039091168152602001610232565b61021361036636600461278c565b61103b565b6102136103793660046127bd565b611051565b61021361038c366004612816565b61106c565b61021361039f36600461278c565b6111d7565b6102136103b23660046128d4565b6111e9565b603854603954610302565b60dd5460de5460df5460e05461025b565b6102136103e1366004612620565b611273565b6102136103f4366004612909565b611287565b610213610407366004612620565b61129f565b61021361041a366004612935565b6112b3565b61021361042d366004612603565b6115df565b610228610440366004612603565b6001600160a01b0316600090815260dc602052604090205490565b6103406104693660046129f3565b6119ce565b60015460025460035460408051938452602084019290925290820152606001610232565b6069610340565b6104ac6104a73660046125ad565b611a49565b6040516102329190612a49565b61022860a35481565b6102136104d0366004612603565b611b13565b60086104e081611e27565b6000826001600160401b038111156104fa576104fa612a5c565b604051908082528060200260200182016040528015610523578160200160208202803683370190505b50905060005b838110156105a057600085858381811061054557610545612a72565b905060200201602081019061055a9190612603565b6001600160a01b038116600090815260dc6020526040812055835190915083908390811061058a5761058a612a72565b6000602091820292909201015250600101610529565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c234808484836040516105d493929190612ac6565b60405180910390a150505050565b6000610653826105f260086119ce565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561062f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103259190612af6565b92915050565b610661611e73565b61066d84848484611ecf565b50505050565b61067b611e73565b6000610687600a6119ce565b604051636db349d160e11b81526001600160a01b038481166004830152919091169063db6693a29060240160a060405180830381865afa1580156106cf573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106f39190612b94565b9050600061077d610704600b6119ce565b6040808501519051632623bd4f60e21b81526001600160a01b03918216600482015291169063988ef53c90602401602060405180830381865afa15801561074f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107739190612af6565b8360800151611f61565b9050600061078b60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107cd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f19190612af6565b6038549091506108018443612c31565b11158061083157506001600160a01b038516600090815260376020908152604080832084845290915290205460ff165b1561084f57604051632e308a0b60e11b815260040160405180910390fd5b6001600160a01b038516600081815260376020908152604080832085845290915290819020805460ff19166001179055516000805160206133a28339815191529061089e906004908590612c5a565b60405180910390a2603954604051630bde081360e21b81526001600160a01b03841691632f78204c916108db918991600091908290600401612c78565b600060405180830381600087803b1580156108f557600080fd5b505af1158015610909573d6000803e3d6000fd5b505050505050505050565b61091c611e73565b6000848460405161092e929190612ca0565b604051809103902090506000838360405161094a929190612ca0565b604080519182900390912060008481526004602052919091205490915060ff1680610983575060008181526004602052604090205460ff165b156109a15760405163f27b8ec960e01b815260040160405180910390fd5b6109ae8787878787611f78565b15610af35760006109bf60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a01573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a259190612af6565b6000858152600460205260408082208054600160ff19918216811790925587845292829020805490931617909155519091506001600160a01b038a16906000805160206133a283398151915290610a80906003908590612c5a565b60405180910390a260025460018054604051630bde081360e21b81526001600160a01b03861693632f78204c93610abe938f93909190600401612c78565b600060405180830381600087803b158015610ad857600080fd5b505af1158015610aec573d6000803e3d6000fd5b5050505050505b50505050505050565b61011354600290610100900460ff16158015610b2057506101135460ff8083169116105b610b455760405162461bcd60e51b8152600401610b3c90612cb0565b60405180910390fd5b610113805461ffff191660ff831617610100179055600054610b72906008906001600160a01b0316612022565b606c54610b8a906005906001600160a01b0316612022565b610b95600483612022565b603554610bad90600a906001600160a01b0316612022565b600080546001600160a01b0319908116909155606c8054821690556035805482169055603680549091169055610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b61011354600390610100900460ff16158015610c7357506101135460ff8083169116105b610c8f5760405162461bcd60e51b8152600401610b3c90612cb0565b610113805461ffff191660ff831617610100179055610caf600f83612022565b610cbd6001546002546120c6565b610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610c14565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610c48565b6008610d3081611e27565b60003390506000816001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d75573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d999190612af6565b90506000826001600160a01b0316634de2b73588886040518363ffffffff1660e01b8152600401610dcb929190612cfe565b600060405180830381865afa158015610de8573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e109190810190612d45565b90506000610e1e60056119ce565b6001600160a01b031663ba303755898986436040518563ffffffff1660e01b8152600401610e4f9493929190612de1565b600060405180830381865afa158015610e6c573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610e949190810190612d45565b90506000876001600160401b03811115610eb057610eb0612a5c565b604051908082528060200260200182016040528015610ed9578160200160208202803683370190505b50905060005b88811015610ff45760008a8a83818110610efb57610efb612a72565b9050602002016020810190610f109190612603565b90506000610f1e828b610cfc565b90506000868481518110610f3457610f34612a72565b602002602001015190506000868581518110610f5257610f52612a72565b6020026020010151905060008280610f675750815b610f7c57610f7760dd5485612106565b610f7f565b60005b6001600160a01b038616600090815260dc602052604090205460de54919250610fa9918390612120565b6001600160a01b038616600090815260dc602052604090208190558751889088908110610fd857610fd8612a72565b6020026020010181815250508560010195505050505050610edf565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c2348089898360405161102893929190612ac6565b60405180910390a1505050505050505050565b611043611e73565b61104d828261213d565b5050565b611059611e73565b6110628161217d565b61104d8282612022565b61011354610100900460ff161580801561108e575061011354600160ff909116105b806110a95750303b1580156110a957506101135460ff166001145b6110c55760405162461bcd60e51b8152600401610b3c90612cb0565b610113805460ff1916600117905580156110ea57610113805461ff0019166101001790555b6110f560088b612022565b61110060058a612022565b61110b600488612022565b611116600a89612022565b61112f86356020880135604089013560608a0135611ecf565b61113e8535602087013561213d565b6111528435602086013560408701356121b3565b61116b8335602085013560408601356060870135612208565b6111848235602084013560408501356060860135612294565b80156111cb57610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6111df611e73565b61104d82826120c6565b60086111f481611e27565b8260010361123357836001600160a01b03166000805160206133a2833981519152600584604051611226929190612c5a565b60405180910390a261066d565b8260020361066d57836001600160a01b03166000805160206133a2833981519152600684604051611265929190612c5a565b60405180910390a250505050565b61127b611e73565b61066d84848484612294565b61128f611e73565b61129a8383836121b3565b505050565b6112a7611e73565b61066d84848484612208565b6112bc33612331565b6000036112ec576000356001600160e01b0319166003604051620f948f60ea1b8152600401610b3c929190612e08565b60006112f8600f6119ce565b6040516303d1982560e61b81526001600160a01b038a8116600483015291925060009183169063f466094090602401600060405180830381865afa158015611344573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261136c9190810190612ec6565b60a0015190508080519060200120888860405161138a929190612ca0565b6040518091039020146113be5760405163053265f160e01b81526001600160e01b0319600035166004820152602401610b3c565b6040516bffffffffffffffffffffffff1960608b901b1660208201526034810187905260009060540160408051601f1981840301815291815281516020928301206000818152601f90935291205490915060ff16156114305760405163f27b8ec960e01b815260040160405180910390fd5b6114a689898080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250506040805180820182528c935091508a90600290839083908082843760009201919091525061149891508a9050612fde565b6114a1896130b5565b6123a9565b156111cb576000818152601f60205260408120805460ff191660011790556114ce60086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611510573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115349190612af6565b90508b6001600160a01b03166000805160206133a2833981519152600883604051611560929190612c5a565b60405180910390a2816001600160a01b0316632f78204c8d601e54601d5460016040518563ffffffff1660e01b815260040161159f9493929190612c78565b600060405180830381600087803b1580156115b957600080fd5b505af11580156115cd573d6000803e3d6000fd5b50505050505050505050505050505050565b60006115eb60086119ce565b604051635061f96960e11b81526001600160a01b0384811660048301529192509082169063a0c3f2d290602401602060405180830381865afa158015611635573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611659919061310d565b611686576000356001600160e01b0319166008604051620f948f60ea1b8152600401610b3c929190612e08565b6040516304d971ab60e01b81526001600160a01b0383811660048301523360248301528216906304d971ab90604401602060405180830381865afa1580156116d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116f6919061310d565b611723576000356001600160e01b0319166004604051620f948f60ea1b8152600401610b3c929190612e08565b604051634b2c2fe160e11b81526001600160a01b03838116600483015260009182918416906396585fc290602401606060405180830381865afa15801561176e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117929190613128565b9250509150816117b557604051636cd31b5960e01b815260040160405180910390fd5b6000836001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156117f5573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118199190612af6565b6001600160a01b038616600090815260db6020908152604080832084845290915290205490915060ff161561186157604051637674d6a960e01b815260040160405180910390fd5b6001600160a01b038516600090815260dc602052604081205460df5490919061188a908561315d565b9050808210156118ad5760405163462e593760e11b815260040160405180910390fd5b604051630adaf5ef60e11b81526001600160a01b038881166004830152602482018590528716906315b5ebde90604401600060405180830381600087803b1580156118f757600080fd5b505af115801561190b573d6000803e3d6000fd5b505050506001600160a01b038716600090815260dc602052604081208054839290611937908490612c31565b90915550506001600160a01b038716600090815260a4602090815260408083208684529091528120556001600160a01b038716600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a250505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115611a0557611a05612c44565b60ff1681526020810191909152604001600020546001600160a01b0316905080611a44578160405163409140df60e11b8152600401610b3c9190613188565b919050565b6060816001600160401b03811115611a6357611a63612a5c565b604051908082528060200260200182016040528015611a8c578160200160208202803683370190505b50905060005b8151811015611b0c5760dc6000858584818110611ab157611ab1612a72565b9050602002016020810190611ac69190612603565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611af957611af9612a72565b6020908102919091010152600101611a92565b5092915050565b60a3544311611b355760405163557fd09160e01b815260040160405180910390fd5b4360a355334114611b69576000356001600160e01b0319166002604051620f948f60ea1b8152600401610b3c929190612e08565b611b7281612404565b15611e24576000611b8360086119ce565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611bc5573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611be99190612af6565b6001600160a01b038416600090815260a460209081526040808320848452909152812080546001019081905560a85492935091611c2790439061251a565b905060a6548203611cd057846001600160a01b03166000805160206133a2833981519152600285604051611c5c929190612c5a565b60405180910390a260a754604051630bde081360e21b81526001600160a01b03861691632f78204c91611c99918991869190600090600401612c78565b600060405180830381600087803b158015611cb357600080fd5b505af1158015611cc7573d6000803e3d6000fd5b50505050611e1f565b60a5548203611e1f576000611ce58685610c20565b905080611d8857856001600160a01b03166000805160206133a2833981519152600186604051611d16929190612c5a565b60405180910390a2604051630bde081360e21b81526001600160a01b03861690632f78204c90611d5190899060009081908190600401612c78565b600060405180830381600087803b158015611d6b57600080fd5b505af1158015611d7f573d6000803e3d6000fd5b50505050611e1d565b856001600160a01b03166000805160206133a2833981519152600786604051611db2929190612c5a565b60405180910390a260a754604051630bde081360e21b81526001600160a01b03871691632f78204c91611def918a91879190600190600401612c78565b600060405180830381600087803b158015611e0957600080fd5b505af11580156111cb573d6000803e3d6000fd5b505b505050505b50565b611e30816119ce565b6001600160a01b0316336001600160a01b031614611e24576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610b3c93929190613196565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611ecd576000356001600160e01b0319166001604051620f948f60ea1b8152600401610b3c929190612e08565b565b82841180611ede575061271084115b80611eea575061271083115b15611f0857604051631cbe1abf60e11b815260040160405180910390fd5b606d849055606e839055606f82905560708190556040805185815260208101859052908101839052606081018290527fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b906080016105d4565b600081831015611f715781610c48565b5090919050565b6040516000906067906001908390611f9c908a908a908a908a908a906024016131f6565b60408051601f198184030181529190526020810180516001600160e01b0316637fc3567760e01b1790528051909150611fd3612544565b602083016020828483895afa611fe857600094505b503d611ff357600093505b8361201157604051630fc2632160e01b815260040160405180910390fd5b5115159a9950505050505050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561205857612058612c44565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f81111561209957612099612c44565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b601d829055601e81905560408051838152602081018390527f381ec200df2ed0875638486318f9f8a84e3550bdc686bf1400c9371a18d087f09101610c14565b6000818311612116576000610c48565b610c488284612c31565b600061213561212f848661323a565b83612535565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a9101610c14565b806001600160a01b03163b600003611e2457604051630bfc64a360e21b81526001600160a01b0382166004820152602401610b3c565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b9060600160405180910390a1505050565b60a65460a554111561223b576040516387f6f09560e01b81526001600160e01b0319600035166004820152602401610b3c565b60a584905560a683905560a782905560a88190556040805185815260208101859052908101839052606081018290527f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa98906080016105d4565b828411156122b55760405163112af4d160e01b815260040160405180910390fd5b6127108111156122d85760405163382c88a360e21b815260040160405180910390fd5b60dd84905560de83905560df82905560e08190556040805185815260208101859052908101839052606081018290527fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b906080016105d4565b600061233d600a6119ce565b604051631af0725f60e31b81526001600160a01b038481166004830152919091169063d78392f890602401602060405180830381865afa158015612385573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106539190612af6565b60405160009060699060019083906123cd908a908a908a908a908a906024016132be565b60408051601f198184030181529190526020810180516001600160e01b0316637b47d06b60e01b1790528051909150611fd3612544565b6000336001600160a01b03831614801590612490575061242460086119ce565b604051633292276760e11b81526001600160a01b03848116600483015291909116906365244ece90602401602060405180830381865afa15801561246c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612490919061310d565b801561065357506124a160056119ce565b604051630fbeb37f60e01b81526001600160a01b0384811660048301524360248301529190911690630fbeb37f90604401602060405180830381865afa1580156124ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612513919061310d565b1592915050565b60008160000361252b576000610c48565b610c48828461323a565b6000818310611f715781610c48565b60405180602001604052806001906020820280368337509192915050565b60008083601f84011261257457600080fd5b5081356001600160401b0381111561258b57600080fd5b6020830191508360208260051b85010111156125a657600080fd5b9250929050565b600080602083850312156125c057600080fd5b82356001600160401b038111156125d657600080fd5b6125e285828601612562565b90969095509350505050565b6001600160a01b0381168114611e2457600080fd5b60006020828403121561261557600080fd5b8135610c48816125ee565b6000806000806080858703121561263657600080fd5b5050823594602084013594506040840135936060013592509050565b60008083601f84011261266457600080fd5b5081356001600160401b0381111561267b57600080fd5b6020830191508360208285010111156125a657600080fd5b6000806000806000606086880312156126ab57600080fd5b85356126b6816125ee565b945060208601356001600160401b03808211156126d257600080fd5b6126de89838a01612652565b909650945060408801359150808211156126f757600080fd5b5061270488828901612652565b969995985093965092949392505050565b6000806040838503121561272857600080fd5b8235612733816125ee565b946020939093013593505050565b60008060006040848603121561275657600080fd5b83356001600160401b0381111561276c57600080fd5b61277886828701612562565b909790965060209590950135949350505050565b6000806040838503121561279f57600080fd5b50508035926020909101359150565b803560108110611a4457600080fd5b600080604083850312156127d057600080fd5b6127d9836127ae565b915060208301356127e9816125ee565b809150509250929050565b806080810183101561065357600080fd5b806040810183101561065357600080fd5b60008060008060008060008060006102a08a8c03121561283557600080fd5b8935612840816125ee565b985060208a0135612850816125ee565b975060408a0135612860816125ee565b965060608a0135612870816125ee565b955061287f8b60808c016127f4565b945061288f8b6101008c01612805565b93506101a08a018b8111156128a357600080fd5b6101408b0193506128b48c826127f4565b9250506128c58b6102208c016127f4565b90509295985092959850929598565b6000806000606084860312156128e957600080fd5b83356128f4816125ee565b95602085013595506040909401359392505050565b60008060006060848603121561291e57600080fd5b505081359360208301359350604090920135919050565b600080600080600080600060e0888a03121561295057600080fd5b873561295b816125ee565b965060208801356001600160401b038082111561297757600080fd5b6129838b838c01612652565b909850965060408a0135955086915061299f8b60608c01612805565b945060a08a01359150808211156129b557600080fd5b6129c18b838c01612805565b935060c08a01359150808211156129d757600080fd5b506129e48a828b01612805565b91505092959891949750929550565b600060208284031215612a0557600080fd5b610c48826127ae565b600081518084526020808501945080840160005b83811015612a3e57815187529582019590820190600101612a22565b509495945050505050565b602081526000610c486020830184612a0e565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b8183526000602080850194508260005b85811015612a3e578135612aab816125ee565b6001600160a01b031687529582019590820190600101612a98565b604081526000612ada604083018587612a88565b8281036020840152612aec8185612a0e565b9695505050505050565b600060208284031215612b0857600080fd5b5051919050565b60405160c081016001600160401b0381118282101715612b3157612b31612a5c565b60405290565b604080519081016001600160401b0381118282101715612b3157612b31612a5c565b604051601f8201601f191681016001600160401b0381118282101715612b8157612b81612a5c565b604052919050565b8051611a44816125ee565b600060a08284031215612ba657600080fd5b60405160a081018181106001600160401b0382111715612bc857612bc8612a5c565b6040528251612bd6816125ee565b81526020830151612be6816125ee565b60208201526040830151612bf9816125ee565b6040820152606083810151908201526080928301519281019290925250919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561065357610653612c1b565b634e487b7160e01b600052602160045260246000fd5b6040810160098410612c6e57612c6e612c44565b9281526020015290565b6001600160a01b03949094168452602084019290925260408301521515606082015260800190565b8183823760009101908152919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b602081526000612135602083018486612a88565b60006001600160401b03821115612d2b57612d2b612a5c565b5060051b60200190565b80518015158114611a4457600080fd5b60006020808385031215612d5857600080fd5b82516001600160401b03811115612d6e57600080fd5b8301601f81018513612d7f57600080fd5b8051612d92612d8d82612d12565b612b59565b81815260059190911b82018301908381019087831115612db157600080fd5b928401925b82841015612dd657612dc784612d35565b82529284019290840190612db6565b979650505050505050565b606081526000612df5606083018688612a88565b6020830194909452506040015292915050565b6001600160e01b03198316815260408101600b8310612e2957612e29612c44565b8260208301529392505050565b60006001600160401b03821115612e4f57612e4f612a5c565b50601f01601f191660200190565b60005b83811015612e78578181015183820152602001612e60565b50506000910152565b600082601f830112612e9257600080fd5b8151612ea0612d8d82612e36565b818152846020838601011115612eb557600080fd5b612135826020830160208701612e5d565b600060208284031215612ed857600080fd5b81516001600160401b0380821115612eef57600080fd5b9083019060c08286031215612f0357600080fd5b612f0b612b0f565b8251612f16816125ee565b81526020830151612f26816125ee565b60208201526040830151612f39816125ee565b6040820152612f4a60608401612b89565b6060820152612f5b60808401612b89565b608082015260a083015182811115612f7257600080fd5b612f7e87828601612e81565b60a08301525095945050505050565b600082601f830112612f9e57600080fd5b8135612fac612d8d82612e36565b818152846020838601011115612fc157600080fd5b816020850160208301376000918101602001919091529392505050565b6000612fe8612b37565b806040840136811115612ffa57600080fd5b845b818110156130ab5780356001600160401b038082111561301c5760008081fd5b9087019036601f8301126130305760008081fd5b81356020613040612d8d83612d12565b82815260059290921b840181019181810190368411156130605760008081fd5b8286015b848110156130985780358681111561307c5760008081fd5b61308a3686838b0101612f8d565b845250918301918301613064565b5089525090960195505050602001612ffc565b5090949350505050565b60006130bf612b37565b8060408401368111156130d157600080fd5b845b818110156130ab5780356001600160401b038111156130f25760008081fd5b6130fe36828901612f8d565b855250602093840193016130d3565b60006020828403121561311f57600080fd5b610c4882612d35565b60008060006060848603121561313d57600080fd5b61314684612d35565b925060208401519150604084015190509250925092565b808202811582820484141761065357610653612c1b565b6010811061318457613184612c44565b9052565b602081016106538284613174565b6001600160e01b031984168152606081016131b46020830185613174565b6001600160a01b03929092166040919091015292915050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b038616815260606020820181905260009061321b90830186886131cd565b828103604084015261322e8185876131cd565b98975050505050505050565b8082018082111561065357610653612c1b565b60008151808452613265816020860160208601612e5d565b601f01601f19169290920160200192915050565b600082604081018360005b60028110156132b357838303875261329d83835161324d565b6020978801979093509190910190600101613284565b509095945050505050565b60c0815260006132d160c083018861324d565b60208781850152604084018760005b60028110156132fd578151835291830191908301906001016132e0565b505050838203608085015281604081018760005b600281101561337e578583038452815180518085529086019086850190600581901b8601880160005b8281101561336857601f1988830301845261335682865161324d565b948a0194938a0193915060010161333a565b5096880196955050509185019150600101613311565b505085810360a08701526133928188613279565b9b9a505050505050505050505056fe607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9a2646970667358221220cfddcb1b8394b245c3e114318973b357369f77dc153b73b61838406a63127a0e64736f6c63430008110033", "devdoc": { "errors": { "ErrCallPrecompiled()": [ @@ -1004,27 +1137,89 @@ "details": "Error of call to precompile fails." } ], - "ErrCallerMustBeGovernanceAdminContract()": [ + "ErrCallerMustBeJailedInTheCurrentPeriod()": [ + { + "details": "Error thrown when the caller must be jailed in the current period." + } + ], + "ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock()": [ + { + "details": "Error thrown when attempting to slash a validator twice or slash more than one validator in one block." + } + ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrEvidenceAlreadySubmitted()": [ { - "details": "Error of method caller must be goverance admin contract." + "details": "Error thrown when evidence has already been submitted." } ], - "ErrCallerMustBeMaintenanceContract()": [ + "ErrInsufficientCreditScoreToBailOut()": [ { - "details": "Error of method caller must be maintenance contract." + "details": "Error thrown when the caller's credit score is insufficient to bail out a situation." } ], - "ErrCallerMustBeRoninTrustedOrgContract()": [ + "ErrInvalidArguments(bytes4)": [ { - "details": "Error of method caller must be Ronin trusted org contract." + "details": "Error indicating that arguments are invalid." } ], - "ErrCallerMustBeValidatorContract()": [ + "ErrInvalidCreditScoreConfig()": [ { - "details": "Error of method caller must be validator contract." + "details": "Error thrown when an invalid credit score configuration is provided." } ], - "ErrZeroCodeContract()": [ + "ErrInvalidCutOffPercentageConfig()": [ + { + "details": "Error thrown when an invalid cut-off percentage configuration is provided." + } + ], + "ErrInvalidRatios()": [ + { + "details": "Error thrown when invalid ratios are provided." + } + ], + "ErrInvalidSlash()": [ + { + "details": "Error thrown when an invalid slash is encountered." + } + ], + "ErrInvalidThreshold(bytes4)": [ + { + "details": "Error indicating that the provided threshold is invalid for a specific function signature.", + "params": { + "msgSig": "The function signature (bytes4) that the invalid threshold applies to." + } + } + ], + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } + } + ], + "ErrValidatorHasBailedOutPreviously()": [ + { + "details": "Error thrown when a validator has previously bailed out." + } + ], + "ErrZeroCodeContract(address)": [ { "details": "Error of set to non-contract." } @@ -1066,6 +1261,15 @@ "bridgeVotingThreshold_": "The threshold to slash when a trusted organization does not vote for bridge operators." } }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, "getCreditScore(address)": { "details": "Returns the current credit score of the validator." }, @@ -1088,6 +1292,13 @@ "slashDoubleSignAmount_": "The amount of RON to slash double sign." } }, + "getFastFinalitySlashingConfigs()": { + "details": "Returns the configs related to block producer slashing.", + "returns": { + "fastFinalityJailUntilBlock_": "The block number that the punished validator will be jailed until, due to malicious fast finality.", + "slashFastFinalityAmount_": "The amount of RON to slash fast finality." + } + }, "getManyCreditScores(address[])": { "details": "Returns the current credit score of a list of validators." }, @@ -1106,17 +1317,11 @@ "initialize(address,address,address,address,uint256[4],uint256[2],uint256[3],uint256[4],uint256[4])": { "details": "Initializes the contract storage." }, - "maintenanceContract()": { - "details": "Returns the maintenance contract." - }, "precompileValidateDoubleSignAddress()": { "details": "Gets the address of the precompile of validating double sign evidence" }, - "roninGovernanceAdminContract()": { - "details": "Returns the ronin governance admin contract." - }, - "roninTrustedOrganizationContract()": { - "details": "Returns the ronin trusted organization contract." + "precompileValidateFastFinalityAddress()": { + "details": "Gets the address of the precompile of validating double sign evidence" }, "setBridgeOperatorSlashingConfigs(uint256,uint256,uint256,uint256)": { "details": "Sets the configs to slash bridge operators. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.", @@ -1134,6 +1339,13 @@ "_threshold": "The threshold to slash when a trusted organization does not vote for bridge operators." } }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, "setCreditScoreConfigs(uint256,uint256,uint256,uint256)": { "details": "Sets the configs to credit score. Requirements: - The method caller is admin. Emits the event `CreditScoreConfigsUpdated`.", "params": { @@ -1151,14 +1363,12 @@ "_slashAmount": "The amount of RON to slash double sign." } }, - "setMaintenanceContract(address)": { - "details": "Sets the maintenance contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `MaintenanceContractUpdated`." - }, - "setRoninGovernanceAdminContract(address)": { - "details": "Sets the ronin governance admin contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninGovernanceAdminContractUpdated`." - }, - "setRoninTrustedOrganizationContract(address)": { - "details": "Sets the ronin trusted organization contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `RoninTrustedOrganizationContractUpdated`." + "setFastFinalitySlashingConfigs(uint256,uint256)": { + "details": "Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `FastFinalitySlashingConfigsUpdated`.", + "params": { + "jailUntilBlock": "The block number that the punished validator will be jailed until, due to fast finality.", + "slashAmount": "The amount of RON to slash fast finality." + } }, "setUnavailabilitySlashingConfigs(uint256,uint256,uint256,uint256)": { "details": "Sets the configs to slash block producers. Requirements: - The method caller is admin. Emits the event `BridgeOperatorSlashingConfigsUpdated`.", @@ -1169,23 +1379,20 @@ "_tier2Threshold": "The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted self-staking if (s)he misses more than this threshold." } }, - "setValidatorContract(address)": { - "details": "Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`." - }, "slashBridgeVoting(address)": { "details": "Slashes for bridge voter governance. Emits the event `Slashed`." }, "slashDoubleSign(address,bytes,bytes)": { "details": "Slashes for double signing. Requirements: - The method caller is coinbase. Emits the event `Slashed` if the double signing evidence of the two headers valid." }, + "slashFastFinality(address,bytes,uint256,bytes32[2],bytes[][2],bytes[2])": { + "details": "Slashes for fast finality. Requirements: - Only whitelisted addresses are allowed to call. Emits the event `Slashed` if the fast finality evidence of the two headers valid." + }, "slashUnavailability(address)": { "details": "Slashes for unavailability by increasing the counter of block producer `_consensusAddr`. Requirements: - The method caller is coinbase. Emits the event `Slashed` when the threshold is reached." }, "updateCreditScores(address[],uint256)": { "details": "Updates the credit score for the validators. Requirements: - Only validator contract can call this method. - This method is only called at the end of each period. Emits the event `CreditScoresUpdated`." - }, - "validatorContract()": { - "details": "Returns the validator contract." } }, "version": 1 @@ -1198,15 +1405,15 @@ "storageLayout": { "storage": [ { - "astId": 7051, + "astId": 41900, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", - "label": "_validatorContract", + "label": "______deprecatedValidator", "offset": 0, "slot": "0", - "type": "t_contract(IRoninValidatorSet)11967" + "type": "t_address" }, { - "astId": 26721, + "astId": 32915, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_slashDoubleSignAmount", "offset": 0, @@ -1214,7 +1421,7 @@ "type": "t_uint256" }, { - "astId": 26724, + "astId": 32918, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_doubleSigningJailUntilBlock", "offset": 0, @@ -1222,7 +1429,7 @@ "type": "t_uint256" }, { - "astId": 26727, + "astId": 32921, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_doubleSigningOffsetLimitBlock", "offset": 0, @@ -1230,7 +1437,7 @@ "type": "t_uint256" }, { - "astId": 26732, + "astId": 32926, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_submittedEvidence", "offset": 0, @@ -1238,31 +1445,63 @@ "type": "t_mapping(t_bytes32,t_bool)" }, { - "astId": 26737, + "astId": 32931, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "______gap", "offset": 0, "slot": "5", - "type": "t_array(t_uint256)48_storage" + "type": "t_array(t_uint256)24_storage" }, { - "astId": 6735, + "astId": 33116, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", - "label": "_roninTrustedOrganizationContract", + "label": "_slashFastFinalityAmount", + "offset": 0, + "slot": "29", + "type": "t_uint256" + }, + { + "astId": 33119, + "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", + "label": "_fastFinalityJailUntilBlock", + "offset": 0, + "slot": "30", + "type": "t_uint256" + }, + { + "astId": 33124, + "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", + "label": "_processedEvidence", + "offset": 0, + "slot": "31", + "type": "t_mapping(t_bytes32,t_bool)" + }, + { + "astId": 33129, + "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", + "label": "______gap", + "offset": 0, + "slot": "32", + "type": "t_array(t_uint256)21_storage" + }, + { + "astId": 41912, + "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", + "label": "______deprecatedTrustedOrg", "offset": 0, "slot": "53", - "type": "t_contract(IRoninTrustedOrganization)10182" + "type": "t_address" }, { - "astId": 6656, + "astId": 41916, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", - "label": "_roninGovernanceAdminContract", + "label": "______deprecatedGovernanceAdmin", "offset": 0, "slot": "54", - "type": "t_contract(IRoninGovernanceAdmin)10003" + "type": "t_address" }, { - "astId": 26563, + "astId": 32733, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_bridgeVotingSlashed", "offset": 0, @@ -1270,7 +1509,7 @@ "type": "t_mapping(t_address,t_mapping(t_uint256,t_bool))" }, { - "astId": 26566, + "astId": 32736, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_bridgeVotingThreshold", "offset": 0, @@ -1278,7 +1517,7 @@ "type": "t_uint256" }, { - "astId": 26569, + "astId": 32739, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_bridgeVotingSlashAmount", "offset": 0, @@ -1286,7 +1525,7 @@ "type": "t_uint256" }, { - "astId": 26574, + "astId": 32744, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "______gap", "offset": 0, @@ -1294,15 +1533,15 @@ "type": "t_array(t_uint256)50_storage" }, { - "astId": 6544, + "astId": 41908, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", - "label": "_maintenanceContract", + "label": "______deprecatedMaintenance", "offset": 0, "slot": "108", - "type": "t_contract(IMaintenance)9657" + "type": "t_address" }, { - "astId": 26395, + "astId": 32554, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_missingVotesRatioTier1", "offset": 0, @@ -1310,7 +1549,7 @@ "type": "t_uint256" }, { - "astId": 26398, + "astId": 32557, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_missingVotesRatioTier2", "offset": 0, @@ -1318,7 +1557,7 @@ "type": "t_uint256" }, { - "astId": 26401, + "astId": 32560, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_jailDurationForMissingVotesRatioTier2", "offset": 0, @@ -1326,7 +1565,7 @@ "type": "t_uint256" }, { - "astId": 26404, + "astId": 32563, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_skipBridgeOperatorSlashingThreshold", "offset": 0, @@ -1334,7 +1573,7 @@ "type": "t_uint256" }, { - "astId": 26409, + "astId": 32568, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "______gap", "offset": 0, @@ -1342,7 +1581,7 @@ "type": "t_array(t_uint256)50_storage" }, { - "astId": 27147, + "astId": 33693, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "lastUnavailabilitySlashedBlock", "offset": 0, @@ -1350,7 +1589,7 @@ "type": "t_uint256" }, { - "astId": 27154, + "astId": 33700, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_unavailabilityIndicator", "offset": 0, @@ -1358,7 +1597,7 @@ "type": "t_mapping(t_address,t_mapping(t_uint256,t_uint256))" }, { - "astId": 27157, + "astId": 33703, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_unavailabilityTier1Threshold", "offset": 0, @@ -1366,7 +1605,7 @@ "type": "t_uint256" }, { - "astId": 27160, + "astId": 33706, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_unavailabilityTier2Threshold", "offset": 0, @@ -1374,7 +1613,7 @@ "type": "t_uint256" }, { - "astId": 27163, + "astId": 33709, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_slashAmountForUnavailabilityTier2Threshold", "offset": 0, @@ -1382,7 +1621,7 @@ "type": "t_uint256" }, { - "astId": 27166, + "astId": 33712, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_jailDurationForUnavailabilityTier2Threshold", "offset": 0, @@ -1390,7 +1629,7 @@ "type": "t_uint256" }, { - "astId": 27171, + "astId": 33717, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "______gap", "offset": 0, @@ -1398,7 +1637,7 @@ "type": "t_array(t_uint256)50_storage" }, { - "astId": 25870, + "astId": 31985, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_checkBailedOutAtPeriod", "offset": 0, @@ -1406,7 +1645,7 @@ "type": "t_mapping(t_address,t_mapping(t_uint256,t_bool))" }, { - "astId": 25875, + "astId": 31990, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_creditScore", "offset": 0, @@ -1414,7 +1653,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 25878, + "astId": 31993, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_gainCreditScore", "offset": 0, @@ -1422,7 +1661,7 @@ "type": "t_uint256" }, { - "astId": 25881, + "astId": 31996, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_maxCreditScore", "offset": 0, @@ -1430,7 +1669,7 @@ "type": "t_uint256" }, { - "astId": 25884, + "astId": 31999, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_bailOutCostMultiplier", "offset": 0, @@ -1438,7 +1677,7 @@ "type": "t_uint256" }, { - "astId": 25887, + "astId": 32002, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "_cutOffPercentageAfterBailout", "offset": 0, @@ -1446,7 +1685,7 @@ "type": "t_uint256" }, { - "astId": 25892, + "astId": 32007, "contract": "contracts/ronin/slash-indicator/SlashIndicator.sol:SlashIndicator", "label": "______gap", "offset": 0, @@ -1476,11 +1715,17 @@ "label": "address", "numberOfBytes": "20" }, - "t_array(t_uint256)48_storage": { + "t_array(t_uint256)21_storage": { "base": "t_uint256", "encoding": "inplace", - "label": "uint256[48]", - "numberOfBytes": "1536" + "label": "uint256[21]", + "numberOfBytes": "672" + }, + "t_array(t_uint256)24_storage": { + "base": "t_uint256", + "encoding": "inplace", + "label": "uint256[24]", + "numberOfBytes": "768" }, "t_array(t_uint256)50_storage": { "base": "t_uint256", @@ -1498,26 +1743,6 @@ "label": "bytes32", "numberOfBytes": "32" }, - "t_contract(IMaintenance)9657": { - "encoding": "inplace", - "label": "contract IMaintenance", - "numberOfBytes": "20" - }, - "t_contract(IRoninGovernanceAdmin)10003": { - "encoding": "inplace", - "label": "contract IRoninGovernanceAdmin", - "numberOfBytes": "20" - }, - "t_contract(IRoninTrustedOrganization)10182": { - "encoding": "inplace", - "label": "contract IRoninTrustedOrganization", - "numberOfBytes": "20" - }, - "t_contract(IRoninValidatorSet)11967": { - "encoding": "inplace", - "label": "contract IRoninValidatorSet", - "numberOfBytes": "20" - }, "t_mapping(t_address,t_mapping(t_uint256,t_bool))": { "encoding": "mapping", "key": "t_address", diff --git a/deployments/ronin-mainnet/StakingLogic.json b/deployments/ronin-mainnet/StakingLogic.json index 03532a5fa..220122138 100644 --- a/deployments/ronin-mainnet/StakingLogic.json +++ b/deployments/ronin-mainnet/StakingLogic.json @@ -1,5 +1,5 @@ { - "address": "0x9B0E61e629EB44875CFf534DE0c176078CaC502f", + "address": "0x8Ae952d538e9c25120e9c75FBA0718750f81313a", "abi": [ { "inputs": [], @@ -17,11 +17,6 @@ "name": "ErrAdminOfAnyActivePoolForbidden", "type": "error" }, - { - "inputs": [], - "name": "ErrCallerMustBeValidatorContract", - "type": "error" - }, { "inputs": [ { @@ -43,6 +38,28 @@ "name": "ErrCannotTransferRON", "type": "error" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrDuplicated", + "type": "error" + }, { "inputs": [ { @@ -55,7 +72,23 @@ "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "currentBalance", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "sendAmount", + "type": "uint256" + } + ], "name": "ErrInsufficientBalance", "type": "error" }, @@ -95,7 +128,13 @@ "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], "name": "ErrRecipientRevert", "type": "error" }, @@ -110,8 +149,19 @@ "type": "error" }, { - "inputs": [], - "name": "ErrThreeOperationAddrsNotDistinct", + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", "type": "error" }, { @@ -124,6 +174,27 @@ "name": "ErrUndelegateZeroAmount", "type": "error" }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, { "inputs": [], "name": "ErrUnstakeTooEarly", @@ -135,7 +206,13 @@ "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, @@ -163,6 +240,25 @@ "name": "CommissionRateRangeUpdated", "type": "event" }, + { + "anonymous": false, + "inputs": [ + { + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" + } + ], + "name": "ContractUpdated", + "type": "event" + }, { "anonymous": false, "inputs": [ @@ -534,19 +630,6 @@ "name": "UserRewardUpdated", "type": "event" }, - { - "anonymous": false, - "inputs": [ - { - "indexed": false, - "internalType": "address", - "name": "", - "type": "address" - } - ], - "name": "ValidatorContractUpdated", - "type": "event" - }, { "anonymous": false, "inputs": [ @@ -607,11 +690,6 @@ "name": "_treasuryAddr", "type": "address" }, - { - "internalType": "address", - "name": "_bridgeOperatorAddr", - "type": "address" - }, { "internalType": "uint256", "name": "_commissionRate", @@ -793,6 +871,25 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -1027,6 +1124,13 @@ "stateMutability": "nonpayable", "type": "function" }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [ { @@ -1152,12 +1256,17 @@ { "inputs": [ { - "internalType": "uint256", - "name": "_cooldownSecs", - "type": "uint256" + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "addr", + "type": "address" } ], - "name": "setCooldownSecsToUndelegate", + "name": "setContract", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -1166,11 +1275,11 @@ "inputs": [ { "internalType": "uint256", - "name": "_threshold", + "name": "_cooldownSecs", "type": "uint256" } ], - "name": "setMinValidatorStakingAmount", + "name": "setCooldownSecsToUndelegate", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -1178,12 +1287,12 @@ { "inputs": [ { - "internalType": "address", - "name": "_addr", - "type": "address" + "internalType": "uint256", + "name": "_threshold", + "type": "uint256" } ], - "name": "setValidatorContract", + "name": "setMinValidatorStakingAmount", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -1216,18 +1325,28 @@ }, { "inputs": [ + { + "internalType": "address", + "name": "_candidateAdmin", + "type": "address" + }, { "internalType": "address", "name": "_consensusAddr", "type": "address" }, + { + "internalType": "address payable", + "name": "_treasuryAddr", + "type": "address" + }, { "internalType": "uint256", - "name": "_amount", + "name": "_commissionRate", "type": "uint256" } ], - "name": "undelegate", + "name": "tmp_re_applyValidatorCandidate", "outputs": [], "stateMutability": "nonpayable", "type": "function" @@ -1245,22 +1364,27 @@ "type": "uint256" } ], - "name": "unstake", + "name": "undelegate", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { - "inputs": [], - "name": "validatorContract", - "outputs": [ + "inputs": [ { "internalType": "address", - "name": "", + "name": "_consensusAddr", "type": "address" + }, + { + "internalType": "uint256", + "name": "_amount", + "type": "uint256" } ], - "stateMutability": "view", + "name": "unstake", + "outputs": [], + "stateMutability": "nonpayable", "type": "function" }, { @@ -1281,41 +1405,41 @@ "type": "receive" } ], - "transactionHash": "0x444895ac6c2bb77d6e40f8c5c62ac2ed1fb1035d50ebb54188e765f07bc92c3c", + "transactionHash": "0xf995b41bfa786b6d7cb3c982b95b31f642776ab0a5d6ea385554ed9416105f66", "receipt": { "to": null, "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", - "contractAddress": "0x9B0E61e629EB44875CFf534DE0c176078CaC502f", - "transactionIndex": 4, - "gasUsed": "3401979", - "logsBloom": "0x00000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000", - "blockHash": "0x0b85db7e156f579d042f91eb71f83c63530f4639abec4ec1acba3fc61e3c0ec2", - "transactionHash": "0x444895ac6c2bb77d6e40f8c5c62ac2ed1fb1035d50ebb54188e765f07bc92c3c", + "contractAddress": "0x8Ae952d538e9c25120e9c75FBA0718750f81313a", + "transactionIndex": 2, + "gasUsed": "3291345", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000008000000010000000000000000000000000000000000000000000000000000000000000080000002000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0xeaa2c60a105805f88f56586d1d65943d3500a1324596ba7ccdd9a96693e1d796", + "transactionHash": "0xf995b41bfa786b6d7cb3c982b95b31f642776ab0a5d6ea385554ed9416105f66", "logs": [ { - "transactionIndex": 4, - "blockNumber": 24127462, - "transactionHash": "0x444895ac6c2bb77d6e40f8c5c62ac2ed1fb1035d50ebb54188e765f07bc92c3c", - "address": "0x9B0E61e629EB44875CFf534DE0c176078CaC502f", + "transactionIndex": 2, + "blockNumber": 28538540, + "transactionHash": "0xf995b41bfa786b6d7cb3c982b95b31f642776ab0a5d6ea385554ed9416105f66", + "address": "0x8Ae952d538e9c25120e9c75FBA0718750f81313a", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 6, - "blockHash": "0x0b85db7e156f579d042f91eb71f83c63530f4639abec4ec1acba3fc61e3c0ec2" + "logIndex": 8, + "blockHash": "0xeaa2c60a105805f88f56586d1d65943d3500a1324596ba7ccdd9a96693e1d796" } ], - "blockNumber": 24127462, - "cumulativeGasUsed": "5056208", + "blockNumber": 28538540, + "cumulativeGasUsed": "3883863", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 2, - "solcInputHash": "85b953b22882c536a643bf4b61b3153b", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"ErrAdminOfAnyActivePoolForbidden\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeValidatorContract\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"string\",\"name\":\"extraInfo\",\"type\":\"string\"}],\"name\":\"ErrCannotInitTransferRON\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCannotTransferRON\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"}],\"name\":\"ErrInactivePool\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientDelegatingAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientStakingAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidArrays\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidPoolShare\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrOnlyPoolAdminAllowed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrPoolAdminForbidden\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrStakingAmountLeft\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrThreeInteractionAddrsNotEqual\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrThreeOperationAddrsNotDistinct\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUndelegateTooEarly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUndelegateZeroAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnstakeTooEarly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnstakeZeroAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroValue\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minRate\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxRate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateRangeUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minSecs\",\"type\":\"uint256\"}],\"name\":\"CooldownSecsToUndelegateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"delegator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Delegated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"}],\"name\":\"MinValidatorStakingAmountUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"PoolApproved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"shares\",\"type\":\"uint256\"}],\"name\":\"PoolSharesUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"validator\",\"type\":\"address[]\"}],\"name\":\"PoolsDeprecated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"}],\"name\":\"PoolsUpdateConflicted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"rewards\",\"type\":\"uint256[]\"}],\"name\":\"PoolsUpdateFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"aRps\",\"type\":\"uint256[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"shares\",\"type\":\"uint256[]\"}],\"name\":\"PoolsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"user\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"RewardClaimed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Staked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingAmountDeductFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingAmountTransferFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"delegator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Undelegated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Unstaked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"user\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"debited\",\"type\":\"uint256\"}],\"name\":\"UserRewardUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"ValidatorContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"secs\",\"type\":\"uint256\"}],\"name\":\"WaitingSecsToRevokeUpdated\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADDITION_GAS\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"PERIOD_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_bridgeOperatorAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"applyValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrs\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_amounts\",\"type\":\"uint256[]\"}],\"name\":\"bulkUndelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrList\",\"type\":\"address[]\"}],\"name\":\"claimRewards\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"cooldownSecsToUndelegate\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"delegate\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrList\",\"type\":\"address[]\"},{\"internalType\":\"address\",\"name\":\"_consensusAddrDst\",\"type\":\"address\"}],\"name\":\"delegateRewards\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"execDeductStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_actualDeductingAmount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_pools\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_newPeriod\",\"type\":\"uint256\"}],\"name\":\"execDeprecatePools\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrs\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_rewards\",\"type\":\"uint256[]\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"execRecordRewards\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCommissionRateRange\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_pools\",\"type\":\"address[]\"}],\"name\":\"getManySelfStakings\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_selfStakings\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_poolAddrs\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_userList\",\"type\":\"address[]\"}],\"name\":\"getManyStakingAmounts\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_stakingAmounts\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_poolList\",\"type\":\"address[]\"}],\"name\":\"getManyStakingTotals\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_stakingAmounts\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAdminAddr\",\"type\":\"address\"}],\"name\":\"getPoolAddressOf\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"}],\"name\":\"getPoolDetail\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_stakingAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_stakingTotal\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"}],\"name\":\"getReward\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"},{\"internalType\":\"address[]\",\"name\":\"_poolAddrList\",\"type\":\"address[]\"}],\"name\":\"getRewards\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_rewards\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"}],\"name\":\"getStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"}],\"name\":\"getStakingTotal\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__minValidatorStakingAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxCommissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__cooldownSecsToUndelegate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__waitingSecsToRevoke\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAdminAddr\",\"type\":\"address\"}],\"name\":\"isAdminOfActivePool\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minValidatorStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddrSrc\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddrDst\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"redelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"requestEmergencyExit\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"requestRenounce\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_effectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"requestUpdateCommissionRate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_minRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxRate\",\"type\":\"uint256\"}],\"name\":\"setCommissionRateRange\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_cooldownSecs\",\"type\":\"uint256\"}],\"name\":\"setCooldownSecsToUndelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_threshold\",\"type\":\"uint256\"}],\"name\":\"setMinValidatorStakingAmount\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setValidatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_secs\",\"type\":\"uint256\"}],\"name\":\"setWaitingSecsToRevoke\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"stake\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"undelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"unstake\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"waitingSecsToRevoke\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrAdminOfAnyActivePoolForbidden(address)\":[{\"details\":\"Error of admin of any active pool cannot delegate.\"}],\"ErrCallerMustBeValidatorContract()\":[{\"details\":\"Error of method caller must be validator contract.\"}],\"ErrCannotInitTransferRON(address,string)\":[{\"details\":\"Error of cannot transfer RON to specified target.\"}],\"ErrCannotTransferRON()\":[{\"details\":\"Error of cannot transfer RON.\"}],\"ErrInactivePool(address)\":[{\"details\":\"Error of querying inactive pool.\"}],\"ErrInsufficientBalance()\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInsufficientDelegatingAmount()\":[{\"details\":\"Error of undelegating insufficient amount.\"}],\"ErrInsufficientStakingAmount()\":[{\"details\":\"Error of insufficient staking amount for unstaking.\"}],\"ErrInvalidArrays()\":[{\"details\":\"Error of length of input arrays are not of the same.\"}],\"ErrInvalidCommissionRate()\":[{\"details\":\"Error of setting commission rate exceeds max allowed.\"}],\"ErrInvalidPoolShare()\":[{\"details\":\"Error of invalid pool share.\"}],\"ErrOnlyPoolAdminAllowed()\":[{\"details\":\"Error of no one is allowed to call but the pool's admin.\"}],\"ErrPoolAdminForbidden()\":[{\"details\":\"Error of pool admin is not allowed to call.\"}],\"ErrRecipientRevert()\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrStakingAmountLeft()\":[{\"details\":\"Error of invalid staking amount left after deducted.\"}],\"ErrThreeInteractionAddrsNotEqual()\":[{\"details\":\"Error of three interaction addresses must be of the same in applying for validator candidate.\"}],\"ErrThreeOperationAddrsNotDistinct()\":[{\"details\":\"Error of three operation addresses must be distinct in applying for validator candidate.\"}],\"ErrUndelegateTooEarly()\":[{\"details\":\"Error of undelegating too early.\"}],\"ErrUndelegateZeroAmount()\":[{\"details\":\"Error of undelegating zero amount.\"}],\"ErrUnstakeTooEarly()\":[{\"details\":\"Error of unstaking too early.\"}],\"ErrUnstakeZeroAmount()\":[{\"details\":\"Error of unstaking zero amount.\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}],\"ErrZeroValue()\":[{\"details\":\"Error of receiving zero message value.\"}]},\"kind\":\"dev\",\"methods\":{\"applyValidatorCandidate(address,address,address,address,uint256)\":{\"details\":\"Proposes a candidate to become a validator. Requirements: - The method caller is able to receive RON. - The treasury is able to receive RON. - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`. Emits the event `PoolApproved`.\",\"params\":{\"_candidateAdmin\":\"the candidate admin will be stored in the validator contract, used for calling function that affects to its candidate, e.g. scheduling maintenance.\"}},\"bulkUndelegate(address[],uint256[])\":{\"details\":\"Bulk unstakes from a list of candidates. Requirements: - The method caller is not the pool admin. Emits the events `Undelegated`.\"},\"claimRewards(address[])\":{\"details\":\"Claims the reward of method caller. Emits the `RewardClaimed` event.\"},\"cooldownSecsToUndelegate()\":{\"details\":\"Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\"},\"delegate(address)\":{\"details\":\"Stakes for a validator candidate `_consensusAddr`. Requirements: - The consensus address is a validator candidate. - The method caller is not the pool admin. Emits the `Delegated` event.\"},\"delegateRewards(address[],address)\":{\"details\":\"Claims the rewards and delegates them to the consensus address. Requirements: - The method caller is not the pool admin. - The consensus address `_consensusAddrDst` is a validator candidate. Emits the `RewardClaimed` event and the `Delegated` event.\"},\"execDeductStakingAmount(address,uint256)\":{\"details\":\"Deducts from staking amount of the validator `_consensusAddr` for `_amount`. Requirements: - The method caller must be validator contract. Emits the event `Unstaked`.\"},\"execDeprecatePools(address[],uint256)\":{\"details\":\"Deprecates the pool. - Deduct self-staking amount of the pool admin to zero. - Transfer the deducted amount to the pool admin. - Deactivate the pool admin address in the mapping of active pool admins Requirements: - The method caller is validator contract. Emits the event `PoolsDeprecated` and `Unstaked` events. Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\"},\"execRecordRewards(address[],uint256[],uint256)\":{\"details\":\"Records the amount of rewards `_rewards` for the pools `_consensusAddrs`. Requirements: - The method caller must be validator contract. Emits the event `PoolsUpdated` once the contract recorded the rewards successfully. Emits the event `PoolsUpdateFailed` once the input array lengths are not equal. Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period. Note: This method should be called once at the period ending.\"},\"getCommissionRateRange()\":{\"details\":\"Returns the commission rate range that the candidate can set.\"},\"getManySelfStakings(address[])\":{\"details\":\"Returns the self-staking amounts of the pools.\"},\"getManyStakingAmounts(address[],address[])\":{\"details\":\"Returns the staking amounts of the users.\"},\"getManyStakingTotals(address[])\":{\"details\":\"Returns the total staking amounts of all users for the pools `_poolAddrs`.\"},\"getPoolAddressOf(address)\":{\"details\":\"Returns the consensus address corresponding to the pool admin.\"},\"getPoolDetail(address)\":{\"details\":\"Returns the staking pool detail.\"},\"getReward(address,address)\":{\"details\":\"Returns the reward amount that user claimable.\"},\"getRewards(address,address[])\":{\"details\":\"Returns the claimable reward of the user `_user`.\"},\"getStakingAmount(address,address)\":{\"details\":\"Returns the staking amount of an user.\"},\"getStakingTotal(address)\":{\"details\":\"Returns the total staking amount of all users for a pool.\"},\"initialize(address,uint256,uint256,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"isAdminOfActivePool(address)\":{\"details\":\"Returns whether the `_poolAdminAddr` is currently active.\"},\"minValidatorStakingAmount()\":{\"details\":\"Returns the minimum threshold for being a validator candidate.\"},\"redelegate(address,address,uint256)\":{\"details\":\"Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`. Requirements: - The method caller is not the pool admin. - The consensus address `_consensusAddrDst` is a validator candidate. Emits the `Undelegated` event and the `Delegated` event.\"},\"requestEmergencyExit(address)\":{\"details\":\"Renounces being a validator candidate and takes back the delegating/staking amount. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin.\"},\"requestRenounce(address)\":{\"details\":\"Renounces being a validator candidate and takes back the delegating/staking amount. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin.\"},\"requestUpdateCommissionRate(address,uint256,uint256)\":{\"details\":\"Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}. - The `_rate` must be in range of [0_00; 100_00]. Emits the event `CommissionRateUpdated`.\"},\"setCommissionRateRange(uint256,uint256)\":{\"details\":\"Sets the commission rate range that a candidate can set. Requirements: - The method caller is admin. Emits the `CommissionRateRangeUpdated` event.\"},\"setCooldownSecsToUndelegate(uint256)\":{\"details\":\"Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated. Requirements: - The method caller is admin. Emits the event `CooldownSecsToUndelegateUpdated`.\"},\"setMinValidatorStakingAmount(uint256)\":{\"details\":\"Sets the minimum threshold for being a validator candidate. Requirements: - The method caller is admin. Emits the `MinValidatorStakingAmountUpdated` event.\"},\"setValidatorContract(address)\":{\"details\":\"Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`.\"},\"setWaitingSecsToRevoke(uint256)\":{\"details\":\"Sets the number of seconds that a candidate must wait to be revoked. Requirements: - The method caller is admin. Emits the event `WaitingSecsToRevokeUpdated`.\"},\"stake(address)\":{\"details\":\"Self-delegates to the validator candidate `_consensusAddr`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. - The `msg.value` is larger than 0. Emits the event `Staked`.\"},\"undelegate(address,uint256)\":{\"details\":\"Unstakes from a validator candidate `_consensusAddr` for `_amount`. Requirements: - The method caller is not the pool admin. Emits the `Undelegated` event.\"},\"unstake(address,uint256)\":{\"details\":\"Unstakes from the validator candidate `_consensusAddr` for `_amount`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. Emits the event `Unstaked`.\"},\"validatorContract()\":{\"details\":\"Returns the validator contract.\"},\"waitingSecsToRevoke()\":{\"details\":\"Returns the number of seconds that a candidate must wait for the renounce request gets affected.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/staking/Staking.sol\":\"Staking\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/security/ReentrancyGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Contract module that helps prevent reentrant calls to a function.\\n *\\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\\n * available, which can be applied to functions to make sure there are no nested\\n * (reentrant) calls to them.\\n *\\n * Note that because there is a single `nonReentrant` guard, functions marked as\\n * `nonReentrant` may not call one another. This can be worked around by making\\n * those functions `private`, and then adding `external` `nonReentrant` entry\\n * points to them.\\n *\\n * TIP: If you would like to learn more about reentrancy and alternative ways\\n * to protect against it, check out our blog post\\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\\n */\\nabstract contract ReentrancyGuard {\\n // Booleans are more expensive than uint256 or any type that takes up a full\\n // word because each write operation emits an extra SLOAD to first read the\\n // slot's contents, replace the bits taken up by the boolean, and then write\\n // back. This is the compiler's defense against contract upgrades and\\n // pointer aliasing, and it cannot be disabled.\\n\\n // The values being non-zero value makes deployment a bit more expensive,\\n // but in exchange the refund on every call to nonReentrant will be lower in\\n // amount. Since refunds are capped to a percentage of the total\\n // transaction's gas, it is best to keep them low in cases like this one, to\\n // increase the likelihood of the full refund coming into effect.\\n uint256 private constant _NOT_ENTERED = 1;\\n uint256 private constant _ENTERED = 2;\\n\\n uint256 private _status;\\n\\n constructor() {\\n _status = _NOT_ENTERED;\\n }\\n\\n /**\\n * @dev Prevents a contract from calling itself, directly or indirectly.\\n * Calling a `nonReentrant` function from another `nonReentrant`\\n * function is not supported. It is possible to prevent this from happening\\n * by making the `nonReentrant` function external, and making it call a\\n * `private` function that does the actual work.\\n */\\n modifier nonReentrant() {\\n // On the first call to nonReentrant, _notEntered will be true\\n require(_status != _ENTERED, \\\"ReentrancyGuard: reentrant call\\\");\\n\\n // Any calls to nonReentrant after this point will fail\\n _status = _ENTERED;\\n\\n _;\\n\\n // By storing the original value once again, a refund is triggered (see\\n // https://eips.ethereum.org/EIPS/eip-2200)\\n _status = _NOT_ENTERED;\\n }\\n}\\n\",\"keccak256\":\"0x0e9621f60b2faabe65549f7ed0f24e8853a45c1b7990d47e8160e523683f3935\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert();\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance();\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable _recipient, uint256 _amount) internal {\\n if (!_sendRON(_recipient, _amount)) revert ErrRecipientRevert();\\n }\\n\\n /**\\n * @dev Send `_amount` RON to the address `_recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n if (address(this).balance < _amount) revert ErrInsufficientBalance();\\n return _unsafeSendRON(_recipient, _amount);\\n }\\n\\n /**\\n * @dev Unsafe send `_amount` RON to the address `_recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRON(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRON(\\n address payable _recipient,\\n uint256 _amount,\\n uint256 _gas\\n ) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount, gas: _gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xbf47d40b2431cf190fa737b803e4cb6fb55aee3f8804470da57a9e340f7914f8\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\n\\ncontract HasValidatorContract is IHasValidatorContract, HasProxyAdmin {\\n IRoninValidatorSet internal _validatorContract;\\n\\n modifier onlyValidatorContract() {\\n if (validatorContract() != msg.sender) revert ErrCallerMustBeValidatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function validatorContract() public view override returns (address) {\\n return address(_validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function setValidatorContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setValidatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function _setValidatorContract(address _addr) internal {\\n _validatorContract = IRoninValidatorSet(_addr);\\n emit ValidatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xf0a7c4c2165ede118c6ba219ee1a20d293d94049b18aa6fc86a2c48661eb654d\",\"license\":\"MIT\"},\"contracts/extensions/consumers/GlobalConfigConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract GlobalConfigConsumer {\\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\\n /// @dev The length of a period in second.\\n uint256 public constant PERIOD_DURATION = 1 days;\\n}\\n\",\"keccak256\":\"0x96d6b1ea4c8e126a8c2468683e7513d195f8e05456d85dd8f259ab049347b527\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasValidatorContract is IHasContract {\\n /// @dev Emitted when the validator contract is updated.\\n event ValidatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be validator contract.\\n error ErrCallerMustBeValidatorContract();\\n\\n /**\\n * @dev Returns the validator contract.\\n */\\n function validatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function setValidatorContract(address) external;\\n}\\n\",\"keccak256\":\"0x35a715f123b0c5dc296d13583f946bef4e485201e122b5170988a7535f114559\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/PeriodWrapperConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface PeriodWrapperConsumer {\\n struct PeriodWrapper {\\n // Inner value.\\n uint256 inner;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n}\\n\",\"keccak256\":\"0xb6777e3c364306eb8d5355583c1aca44de9d351cb40ddf1cea832206d4aad272\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IBaseStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseStaking {\\n struct PoolDetail {\\n // Address of the pool i.e. consensus address of the validator\\n address addr;\\n // Pool admin address\\n address admin;\\n // Self-staking amount\\n uint256 stakingAmount;\\n // Total number of RON staking for the pool\\n uint256 stakingTotal;\\n // Mapping from delegator => delegating amount\\n mapping(address => uint256) delegatingAmount;\\n // Mapping from delegator => the last timestamp that delegator staked\\n mapping(address => uint256) lastDelegatingTimestamp;\\n }\\n\\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\\n event WaitingSecsToRevokeUpdated(uint256 secs);\\n\\n /// @dev Error of cannot transfer RON.\\n error ErrCannotTransferRON();\\n /// @dev Error of receiving zero message value.\\n error ErrZeroValue();\\n /// @dev Error of pool admin is not allowed to call.\\n error ErrPoolAdminForbidden();\\n /// @dev Error of no one is allowed to call but the pool's admin.\\n error ErrOnlyPoolAdminAllowed();\\n /// @dev Error of admin of any active pool cannot delegate.\\n error ErrAdminOfAnyActivePoolForbidden(address admin);\\n /// @dev Error of querying inactive pool.\\n error ErrInactivePool(address poolAddr);\\n /// @dev Error of length of input arrays are not of the same.\\n error ErrInvalidArrays();\\n\\n /**\\n * @dev Returns whether the `_poolAdminAddr` is currently active.\\n */\\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the consensus address corresponding to the pool admin.\\n */\\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\\n\\n /**\\n * @dev Returns the staking pool detail.\\n */\\n function getPoolDetail(address)\\n external\\n view\\n returns (\\n address _admin,\\n uint256 _stakingAmount,\\n uint256 _stakingTotal\\n );\\n\\n /**\\n * @dev Returns the self-staking amounts of the pools.\\n */\\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n */\\n function cooldownSecsToUndelegate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\\n */\\n function waitingSecsToRevoke() external view returns (uint256);\\n\\n /**\\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CooldownSecsToUndelegateUpdated`.\\n *\\n */\\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\\n\\n /**\\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `WaitingSecsToRevokeUpdated`.\\n *\\n */\\n function setWaitingSecsToRevoke(uint256 _secs) external;\\n}\\n\",\"keccak256\":\"0x008b3d42a3104820de7b7edb5ea4b21c75d4417767fc0791f89f00ac9a2cce8d\",\"license\":\"MIT\"},\"contracts/interfaces/staking/ICandidateStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface ICandidateStaking is IRewardPool {\\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\\n event MinValidatorStakingAmountUpdated(uint256 threshold);\\n /// @dev Emitted when the commission rate range is updated.\\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\\n\\n /// @dev Emitted when the pool admin staked for themself.\\n event Staked(address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\\n event Unstaked(address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Emitted when the validator pool is approved.\\n event PoolApproved(address indexed validator, address indexed admin);\\n /// @dev Emitted when the validator pool is deprecated.\\n event PoolsDeprecated(address[] validator);\\n /// @dev Emitted when the staking amount transfer failed.\\n event StakingAmountTransferFailed(\\n address indexed validator,\\n address indexed admin,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\\n event StakingAmountDeductFailed(\\n address indexed validator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Error of cannot transfer RON to specified target.\\n error ErrCannotInitTransferRON(address addr, string extraInfo);\\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\\n error ErrThreeInteractionAddrsNotEqual();\\n /// @dev Error of three operation addresses must be distinct in applying for validator candidate.\\n error ErrThreeOperationAddrsNotDistinct();\\n /// @dev Error of unstaking zero amount.\\n error ErrUnstakeZeroAmount();\\n /// @dev Error of invalid staking amount left after deducted.\\n error ErrStakingAmountLeft();\\n /// @dev Error of insufficient staking amount for unstaking.\\n error ErrInsufficientStakingAmount();\\n /// @dev Error of unstaking too early.\\n error ErrUnstakeTooEarly();\\n /// @dev Error of setting commission rate exceeds max allowed.\\n error ErrInvalidCommissionRate();\\n\\n /**\\n * @dev Returns the minimum threshold for being a validator candidate.\\n */\\n function minValidatorStakingAmount() external view returns (uint256);\\n\\n /**\\n * @dev Returns the commission rate range that the candidate can set.\\n */\\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\\n\\n /**\\n * @dev Sets the minimum threshold for being a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinValidatorStakingAmountUpdated` event.\\n *\\n */\\n function setMinValidatorStakingAmount(uint256) external;\\n\\n /**\\n * @dev Sets the commission rate range that a candidate can set.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `CommissionRateRangeUpdated` event.\\n *\\n */\\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\\n\\n /**\\n * @dev Proposes a candidate to become a validator.\\n *\\n * Requirements:\\n * - The method caller is able to receive RON.\\n * - The treasury is able to receive RON.\\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\\n *\\n * Emits the event `PoolApproved`.\\n *\\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\\n * to its candidate, e.g. scheduling maintenance.\\n *\\n */\\n function applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external payable;\\n\\n /**\\n * @dev Deprecates the pool.\\n * - Deduct self-staking amount of the pool admin to zero.\\n * - Transfer the deducted amount to the pool admin.\\n * - Deactivate the pool admin address in the mapping of active pool admins\\n *\\n * Requirements:\\n * - The method caller is validator contract.\\n *\\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\\n *\\n */\\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\\n\\n /**\\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `msg.value` is larger than 0.\\n *\\n * Emits the event `Staked`.\\n *\\n */\\n function stake(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function unstake(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdated`.\\n *\\n */\\n function requestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestRenounce(address _consensusAddr) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestEmergencyExit(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x5681cd641c0014aa2cc0ae336e110ebd9a5b28419ae387acd720683ba54ca89f\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IDelegatorStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface IDelegatorStaking is IRewardPool {\\n /// @dev Emitted when the delegator staked for a validator candidate.\\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the delegator unstaked from a validator candidate.\\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Error of undelegating zero amount.\\n error ErrUndelegateZeroAmount();\\n /// @dev Error of undelegating insufficient amount.\\n error ErrInsufficientDelegatingAmount();\\n /// @dev Error of undelegating too early.\\n error ErrUndelegateTooEarly();\\n\\n /**\\n * @dev Stakes for a validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Delegated` event.\\n *\\n */\\n function delegate(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Undelegated` event.\\n *\\n */\\n function undelegate(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Bulk unstakes from a list of candidates.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the events `Undelegated`.\\n *\\n */\\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\\n\\n /**\\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `Undelegated` event and the `Delegated` event.\\n *\\n */\\n function redelegate(\\n address _consensusAddrSrc,\\n address _consensusAddrDst,\\n uint256 _amount\\n ) external;\\n\\n /**\\n * @dev Returns the claimable reward of the user `_user`.\\n */\\n function getRewards(address _user, address[] calldata _poolAddrList)\\n external\\n view\\n returns (uint256[] memory _rewards);\\n\\n /**\\n * @dev Claims the reward of method caller.\\n *\\n * Emits the `RewardClaimed` event.\\n *\\n */\\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\\n\\n /**\\n * @dev Claims the rewards and delegates them to the consensus address.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `RewardClaimed` event and the `Delegated` event.\\n *\\n */\\n function delegateRewards(address[] calldata _consensusAddrList, address _consensusAddrDst)\\n external\\n returns (uint256 _amount);\\n}\\n\",\"keccak256\":\"0x5ce840a920ed06139f9e33d306c8ee50b2a81e4bd2ac6ed24b47297c348576b8\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IRewardPool.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/consumers/PeriodWrapperConsumer.sol\\\";\\n\\ninterface IRewardPool is PeriodWrapperConsumer {\\n struct UserRewardFields {\\n // Recorded reward amount.\\n uint256 debited;\\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\\n uint256 aRps;\\n // Lowest staking amount in the period.\\n uint256 lowestAmount;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n\\n struct PoolFields {\\n // Accumulated of the amount rewards per share (one unit staking).\\n uint256 aRps;\\n // The staking total to share reward of the current period.\\n PeriodWrapper shares;\\n }\\n\\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\\n /// @dev Emitted when the user claimed their reward\\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\\n\\n /// @dev Emitted when the pool shares are updated\\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\\n /// @dev Emitted when the pools are updated\\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\\n /// @dev Emitted when the contract fails when updating the pools\\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\\n /// @dev Emitted when the contract fails when updating the pools that already set\\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\\n\\n /// @dev Error of invalid pool share.\\n error ErrInvalidPoolShare();\\n\\n /**\\n * @dev Returns the reward amount that user claimable.\\n */\\n function getReward(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amount of an user.\\n */\\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amounts of the users.\\n */\\n function getManyStakingAmounts(address[] calldata _poolAddrs, address[] calldata _userList)\\n external\\n view\\n returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total staking amount of all users for a pool.\\n */\\n function getStakingTotal(address _poolAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\\n */\\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\\n}\\n\",\"keccak256\":\"0x92315ca9d6d93f55a7752adf2567adb86745f708198bfcd74b9a626b6570208f\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseStaking.sol\\\";\\nimport \\\"./ICandidateStaking.sol\\\";\\nimport \\\"./IDelegatorStaking.sol\\\";\\n\\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\\n /**\\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\\n *\\n * Note: This method should be called once at the period ending.\\n *\\n */\\n function execRecordRewards(\\n address[] calldata _consensusAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) external payable;\\n\\n /**\\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function execDeductStakingAmount(address _consensusAddr, uint256 _amount)\\n external\\n returns (uint256 _actualDeductingAmount);\\n}\\n\",\"keccak256\":\"0xb7942c5032c16ea567ac0bfc07ecacd84840d6de134735ea538aa22fc6da05a5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool) {\\n bytes32 _thisHash;\\n bytes32 _otherHash;\\n\\n assembly {\\n _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n }\\n\\n return _thisHash == _otherHash;\\n }\\n}\\n\",\"keccak256\":\"0xea4ac2b0783926a0e6ae257bc069fa37ea864ce77bfb25dd327d4727a38ad0ea\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(\\n uint256 c,\\n uint256 a,\\n uint256 b\\n ) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(\\n uint256 x1,\\n uint256 x2,\\n uint256 y1,\\n uint256 y2\\n ) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(\\n uint256 a,\\n uint256 b,\\n uint256 upperbound\\n ) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xf719e74bc39be7aceb4e5cc455260f81b2b21e83aa693e0b50c390c9909e08c4\",\"license\":\"UNLICENSED\"},\"contracts/ronin/staking/BaseStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/security/ReentrancyGuard.sol\\\";\\nimport \\\"../../extensions/RONTransferHelper.sol\\\";\\nimport \\\"../../extensions/collections/HasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/staking/IBaseStaking.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"./RewardCalculation.sol\\\";\\n\\nabstract contract BaseStaking is\\n RONTransferHelper,\\n ReentrancyGuard,\\n RewardCalculation,\\n HasValidatorContract,\\n IBaseStaking\\n{\\n /// @dev Mapping from pool address => staking pool detail\\n mapping(address => PoolDetail) internal _stakingPool;\\n\\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n uint256 internal _cooldownSecsToUndelegate;\\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\\n uint256 internal _waitingSecsToRevoke;\\n\\n /// @dev Mapping from admin address of an active pool => consensus address.\\n mapping(address => address) internal _adminOfActivePoolMapping;\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[49] private ______gap;\\n\\n modifier noEmptyValue() {\\n if (msg.value == 0) revert ErrZeroValue();\\n _;\\n }\\n\\n modifier notPoolAdmin(PoolDetail storage _pool, address _delegator) {\\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\\n _;\\n }\\n\\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\\n _;\\n }\\n\\n modifier poolIsActive(address _poolAddr) {\\n if (!_validatorContract.isValidatorCandidate(_poolAddr)) revert ErrInactivePool(_poolAddr);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\\n return _adminOfActivePoolMapping[_poolAdminAddr];\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getPoolDetail(address _poolAddr)\\n external\\n view\\n returns (\\n address _admin,\\n uint256 _stakingAmount,\\n uint256 _stakingTotal\\n )\\n {\\n PoolDetail storage _pool = _stakingPool[_poolAddr];\\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\\n _selfStakings = new uint256[](_pools.length);\\n for (uint _i = 0; _i < _pools.length; _i++) {\\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\\n }\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\\n return _stakingPool[_poolAddr].stakingTotal;\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getManyStakingTotals(address[] calldata _poolList)\\n public\\n view\\n override\\n returns (uint256[] memory _stakingAmounts)\\n {\\n _stakingAmounts = new uint256[](_poolList.length);\\n for (uint _i = 0; _i < _poolList.length; _i++) {\\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\\n }\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\\n return _stakingPool[_poolAddr].delegatingAmount[_user];\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getManyStakingAmounts(address[] calldata _poolAddrs, address[] calldata _userList)\\n external\\n view\\n override\\n returns (uint256[] memory _stakingAmounts)\\n {\\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\\n _stakingAmounts = new uint256[](_poolAddrs.length);\\n for (uint _i = 0; _i < _stakingAmounts.length; _i++) {\\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\\n }\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function cooldownSecsToUndelegate() external view returns (uint256) {\\n return _cooldownSecsToUndelegate;\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function waitingSecsToRevoke() external view returns (uint256) {\\n return _waitingSecsToRevoke;\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\\n _setCooldownSecsToUndelegate(_cooldownSecs);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\\n _setWaitingSecsToRevoke(_secs);\\n }\\n\\n /**\\n * @dev Sets the minium number of seconds to undelegate.\\n *\\n * Emits the event `CooldownSecsToUndelegateUpdated`.\\n *\\n */\\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\\n _cooldownSecsToUndelegate = _cooldownSecs;\\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\\n }\\n\\n /**\\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\\n *\\n * Emits the event `WaitingSecsToRevokeUpdated`.\\n *\\n */\\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\\n _waitingSecsToRevoke = _secs;\\n emit WaitingSecsToRevokeUpdated(_secs);\\n }\\n\\n /**\\n * @dev Changes the delegate amount.\\n */\\n function _changeDelegatingAmount(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _newDelegatingAmount,\\n uint256 _newStakingTotal\\n ) internal {\\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\\n _pool.stakingTotal = _newStakingTotal;\\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\\n }\\n}\\n\",\"keccak256\":\"0xdf7889af5ad6b206a2d4eceb8947fcc26f90b7c8411806ec76eb19bc3363afd0\",\"license\":\"MIT\"},\"contracts/ronin/staking/CandidateStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/consumers/GlobalConfigConsumer.sol\\\";\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../libraries/AddressArrayUtils.sol\\\";\\nimport \\\"../../interfaces/staking/ICandidateStaking.sol\\\";\\nimport \\\"./BaseStaking.sol\\\";\\n\\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\\n /// @dev The minimum threshold for being a validator candidate.\\n uint256 internal _minValidatorStakingAmount;\\n\\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\\n uint256 internal _maxCommissionRate;\\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\\n uint256 internal _minCommissionRate;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[48] ______gap;\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function minValidatorStakingAmount() public view override returns (uint256) {\\n return _minValidatorStakingAmount;\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function getCommissionRateRange() external view override returns (uint256, uint256) {\\n return (_minCommissionRate, _maxCommissionRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\\n _setMinValidatorStakingAmount(_threshold);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\\n _setCommissionRateRange(_minRate, _maxRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external payable override nonReentrant {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\\n\\n uint256 _amount = msg.value;\\n address payable _poolAdmin = payable(msg.sender);\\n _applyValidatorCandidate(\\n _poolAdmin,\\n _candidateAdmin,\\n _consensusAddr,\\n _treasuryAddr,\\n _bridgeOperatorAddr,\\n _commissionRate,\\n _amount\\n );\\n\\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\\n _pool.admin = _poolAdmin;\\n _pool.addr = _consensusAddr;\\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\\n\\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\\n emit PoolApproved(_consensusAddr, _poolAdmin);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\\n _validatorContract.execRequestUpdateCommissionRate(_consensusAddr, _effectiveDaysOnwards, _commissionRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function execDeprecatePools(address[] calldata _pools, uint256 _newPeriod) external override onlyValidatorContract {\\n if (_pools.length == 0) {\\n return;\\n }\\n\\n for (uint _i = 0; _i < _pools.length; _i++) {\\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\\n // Deactivate the pool admin in the active mapping.\\n delete _adminOfActivePoolMapping[_pool.admin];\\n\\n // Deduct and transfer the self staking amount to the pool admin.\\n uint256 _deductingAmount = _pool.stakingAmount;\\n if (_deductingAmount > 0) {\\n _deductStakingAmount(_pool, _deductingAmount);\\n if (!_unsafeSendRON(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\\n }\\n }\\n\\n // Settle the unclaimed reward and transfer to the pool admin.\\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\\n if (_lastRewardAmount > 0) {\\n _unsafeSendRON(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\\n }\\n }\\n\\n emit PoolsDeprecated(_pools);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function unstake(address _consensusAddr, uint256 _amount)\\n external\\n override\\n nonReentrant\\n poolIsActive(_consensusAddr)\\n {\\n if (_amount == 0) revert ErrUnstakeZeroAmount();\\n address _requester = msg.sender;\\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\\n uint256 _remainAmount = _pool.stakingAmount - _amount;\\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\\n\\n _unstake(_pool, _requester, _amount);\\n if (!_unsafeSendRON(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestRenounce(address _consensusAddr)\\n external\\n override\\n poolIsActive(_consensusAddr)\\n onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender)\\n {\\n _validatorContract.execRequestRenounceCandidate(_consensusAddr, _waitingSecsToRevoke);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestEmergencyExit(address _consensusAddr)\\n external\\n override\\n poolIsActive(_consensusAddr)\\n onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender)\\n {\\n _validatorContract.execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-applyValidatorCandidate`\\n */\\n function _applyValidatorCandidate(\\n address payable _poolAdmin,\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate,\\n uint256 _amount\\n ) internal {\\n if (!_unsafeSendRON(_poolAdmin, 0)) revert ErrCannotInitTransferRON(_poolAdmin, \\\"pool admin\\\");\\n if (!_unsafeSendRON(_treasuryAddr, 0)) revert ErrCannotInitTransferRON(_treasuryAddr, \\\"treasury\\\");\\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\\n\\n address[] memory _diffAddrs = new address[](3);\\n _diffAddrs[0] = _poolAdmin;\\n _diffAddrs[1] = _consensusAddr;\\n _diffAddrs[2] = _bridgeOperatorAddr;\\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert ErrThreeOperationAddrsNotDistinct();\\n\\n _validatorContract.execApplyValidatorCandidate(\\n _candidateAdmin,\\n _consensusAddr,\\n _treasuryAddr,\\n _bridgeOperatorAddr,\\n _commissionRate\\n );\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-stake`\\n */\\n function _stake(\\n PoolDetail storage _pool,\\n address _requester,\\n uint256 _amount\\n ) internal onlyPoolAdmin(_pool, _requester) {\\n _pool.stakingAmount += _amount;\\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\\n emit Staked(_pool.addr, _amount);\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-unstake`\\n */\\n function _unstake(\\n PoolDetail storage _pool,\\n address _requester,\\n uint256 _amount\\n ) internal onlyPoolAdmin(_pool, _requester) {\\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\\n revert ErrUnstakeTooEarly();\\n }\\n\\n _pool.stakingAmount -= _amount;\\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\\n emit Unstaked(_pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\\n *\\n * Emits the event `Unstaked`.\\n *\\n * @return The actual deducted amount\\n */\\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\\n\\n /**\\n * @dev Sets the minimum threshold for being a validator candidate.\\n *\\n * Emits the `MinValidatorStakingAmountUpdated` event.\\n *\\n */\\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\\n _minValidatorStakingAmount = _threshold;\\n emit MinValidatorStakingAmountUpdated(_threshold);\\n }\\n\\n /**\\n * @dev Sets the max commission rate that a candidate can set.\\n *\\n * Emits the `MaxCommissionRateUpdated` event.\\n *\\n */\\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\\n _maxCommissionRate = _maxRate;\\n _minCommissionRate = _minRate;\\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\\n }\\n}\\n\",\"keccak256\":\"0x324360faf9e3da3b7a83824c8d0e383da16902965abbee3cb7bf8a7e398dffac\",\"license\":\"MIT\"},\"contracts/ronin/staking/DelegatorStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/staking/IDelegatorStaking.sol\\\";\\nimport \\\"./BaseStaking.sol\\\";\\n\\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\\n address payable _delegator = payable(msg.sender);\\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\\n\\n address payable _delegator = payable(msg.sender);\\n uint256 _total;\\n\\n for (uint _i = 0; _i < _consensusAddrs.length; _i++) {\\n _total += _amounts[_i];\\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\\n }\\n\\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function redelegate(\\n address _consensusAddrSrc,\\n address _consensusAddrDst,\\n uint256 _amount\\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\\n address _delegator = msg.sender;\\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function claimRewards(address[] calldata _consensusAddrList)\\n external\\n override\\n nonReentrant\\n returns (uint256 _amount)\\n {\\n _amount = _claimRewards(msg.sender, _consensusAddrList);\\n _transferRON(payable(msg.sender), _amount);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function delegateRewards(address[] calldata _consensusAddrList, address _consensusAddrDst)\\n external\\n override\\n nonReentrant\\n poolIsActive(_consensusAddrDst)\\n returns (uint256 _amount)\\n {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function getRewards(address _user, address[] calldata _poolAddrList)\\n external\\n view\\n returns (uint256[] memory _rewards)\\n {\\n address _consensusAddr;\\n uint256 _period = _validatorContract.currentPeriod();\\n _rewards = new uint256[](_poolAddrList.length);\\n\\n for (uint256 _i = 0; _i < _poolAddrList.length; _i++) {\\n _consensusAddr = _poolAddrList[_i];\\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\\n }\\n }\\n\\n /**\\n * @dev Delegates from a validator address.\\n *\\n * Requirements:\\n * - The delegator is not the pool admin.\\n *\\n * Emits the `Delegated` event.\\n *\\n * Note: This function does not verify the `msg.value` with the amount.\\n *\\n */\\n function _delegate(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _amount\\n ) internal notPoolAdmin(_pool, _delegator) {\\n _changeDelegatingAmount(\\n _pool,\\n _delegator,\\n _pool.delegatingAmount[_delegator] + _amount,\\n _pool.stakingTotal + _amount\\n );\\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\\n emit Delegated(_delegator, _pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Undelegates from a validator address.\\n *\\n * Requirements:\\n * - The delegator is not the pool admin.\\n * - The amount is larger than 0.\\n * - The delegating amount is larger than or equal to the undelegating amount.\\n *\\n * Emits the `Undelegated` event.\\n *\\n * Note: Consider transferring back the amount of RON after calling this function.\\n *\\n */\\n function _undelegate(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _amount\\n ) private notPoolAdmin(_pool, _delegator) {\\n if (_amount == 0) revert ErrUndelegateZeroAmount();\\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\\n\\n if (\\n _validatorContract.isValidatorCandidate(_pool.addr) &&\\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\\n ) revert ErrUndelegateTooEarly();\\n\\n _changeDelegatingAmount(\\n _pool,\\n _delegator,\\n _pool.delegatingAmount[_delegator] - _amount,\\n _pool.stakingTotal - _amount\\n );\\n emit Undelegated(_delegator, _pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Claims rewards from the pools `_poolAddrList`.\\n * Note: This function does not transfer reward to user.\\n */\\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\\n uint256 _period = _currentPeriod();\\n for (uint256 _i = 0; _i < _poolAddrList.length; _i++) {\\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\\n }\\n }\\n\\n /**\\n * @dev Claims the rewards and delegates them to the consensus address.\\n */\\n function _delegateRewards(\\n address _user,\\n address[] calldata _poolAddrList,\\n address _poolAddrDst\\n ) internal returns (uint256 _amount) {\\n _amount = _claimRewards(_user, _poolAddrList);\\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\\n }\\n}\\n\",\"keccak256\":\"0xbc60590d1ae7fab32f9fddee11cb4a2b39f53d059fb4682d19ead9341f1f7f14\",\"license\":\"MIT\"},\"contracts/ronin/staking/RewardCalculation.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/staking/IRewardPool.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\n\\n/**\\n * @title RewardCalculation contract\\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\\n */\\nabstract contract RewardCalculation is IRewardPool {\\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\\n /// @dev Mapping from the pool address => user address => the reward info of the user\\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\\n /// @dev Mapping from the pool address => reward pool fields\\n mapping(address => PoolFields) private _stakingPool;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\\n\\n /**\\n * @dev Returns the reward amount that user claimable.\\n */\\n function _getReward(\\n address _poolAddr,\\n address _user,\\n uint256 _latestPeriod,\\n uint256 _latestStakingAmount\\n ) internal view returns (uint256) {\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n\\n if (_reward.lastPeriod == _latestPeriod) {\\n return _reward.debited;\\n }\\n\\n uint256 _aRps;\\n uint256 _lastPeriodReward;\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\\n\\n if (_wrappedArps.lastPeriod > 0) {\\n // Calculates the last period reward if the aRps at the period is set\\n _aRps = _wrappedArps.inner;\\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\\n } else {\\n // Fallbacks to the previous aRps in case the aRps is not set\\n _aRps = _reward.aRps;\\n }\\n\\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\\n }\\n\\n /**\\n * @dev Syncs the user reward.\\n *\\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\\n *\\n * Note: The method should be called whenever the user's staking amount changes.\\n *\\n */\\n function _syncUserReward(\\n address _poolAddr,\\n address _user,\\n uint256 _newStakingAmount\\n ) internal {\\n uint256 _period = _currentPeriod();\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n uint256 _lastShares = _pool.shares.inner;\\n\\n // Updates the pool shares if it is outdated\\n if (_pool.shares.lastPeriod < _period) {\\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\\n }\\n\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\\n\\n if (_reward.debited != _debited) {\\n _reward.debited = _debited;\\n emit UserRewardUpdated(_poolAddr, _user, _debited);\\n }\\n\\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\\n _reward.aRps = _pool.aRps;\\n _reward.lastPeriod = _period;\\n\\n if (_pool.shares.inner != _lastShares) {\\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\\n }\\n }\\n\\n /**\\n * @dev Syncs the minimum staking amount of an user in the current period.\\n */\\n function _syncMinStakingAmount(\\n PoolFields storage _pool,\\n UserRewardFields storage _reward,\\n uint256 _latestPeriod,\\n uint256 _newStakingAmount,\\n uint256 _currentStakingAmount\\n ) internal {\\n if (_reward.lastPeriod < _latestPeriod) {\\n _reward.lowestAmount = _currentStakingAmount;\\n }\\n\\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\\n if (_diffAmount > 0) {\\n _reward.lowestAmount = _lowestAmount;\\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\\n _pool.shares.inner -= _diffAmount;\\n }\\n }\\n\\n /**\\n * @dev Claims the settled reward for a specific user.\\n *\\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\\n *\\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\\n *\\n * Note: This method should be called before transferring rewards for the user.\\n *\\n */\\n function _claimReward(\\n address _poolAddr,\\n address _user,\\n uint256 _lastPeriod\\n ) internal returns (uint256 _amount) {\\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\\n emit RewardClaimed(_poolAddr, _user, _amount);\\n\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n _reward.debited = 0;\\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\\n _reward.lastPeriod = _lastPeriod;\\n _reward.aRps = _stakingPool[_poolAddr].aRps;\\n emit UserRewardUpdated(_poolAddr, _user, 0);\\n }\\n\\n /**\\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\\n *\\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\\n *\\n * Note: This method should be called once at the period ending.\\n *\\n */\\n function _recordRewards(\\n address[] memory _poolAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) internal {\\n if (_poolAddrs.length != _rewards.length) {\\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\\n return;\\n }\\n\\n uint256 _rps;\\n uint256 _count;\\n address _poolAddr;\\n uint256 _stakingTotal;\\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\\n address[] memory _conflicted = new address[](_poolAddrs.length);\\n\\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\\n _poolAddr = _poolAddrs[_i];\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n _stakingTotal = getStakingTotal(_poolAddr);\\n\\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\\n _conflicted[_count++] = _poolAddr;\\n continue;\\n }\\n\\n // Updates the pool shares if it is outdated\\n if (_pool.shares.lastPeriod < _period) {\\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\\n }\\n\\n // The rps is 0 if no one stakes for the pool\\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\\n _aRps[_i - _count] = _pool.aRps += _rps;\\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\\n _pool.shares.inner = _stakingTotal;\\n _shares[_i - _count] = _pool.shares.inner;\\n _poolAddrs[_i - _count] = _poolAddr;\\n }\\n\\n if (_count > 0) {\\n assembly {\\n mstore(_conflicted, _count)\\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\\n }\\n emit PoolsUpdateConflicted(_period, _conflicted);\\n }\\n\\n if (_poolAddrs.length > 0) {\\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\\n }\\n }\\n\\n /**\\n * @dev Returns the current period.\\n */\\n function _currentPeriod() internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0x492fc376e3a866dca702f22f25fe30d3005c28cace7503822ac7e73606611278\",\"license\":\"MIT\"},\"contracts/ronin/staking/Staking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"../../interfaces/staking/IStaking.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"./CandidateStaking.sol\\\";\\nimport \\\"./DelegatorStaking.sol\\\";\\n\\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\\n constructor() {\\n _disableInitializers();\\n }\\n\\n receive() external payable onlyValidatorContract {}\\n\\n fallback() external payable onlyValidatorContract {}\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 __minValidatorStakingAmount,\\n uint256 __maxCommissionRate,\\n uint256 __cooldownSecsToUndelegate,\\n uint256 __waitingSecsToRevoke\\n ) external initializer {\\n _setValidatorContract(__validatorContract);\\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\\n _setCommissionRateRange(0, __maxCommissionRate);\\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\\n }\\n\\n /**\\n * @inheritdoc IStaking\\n */\\n function execRecordRewards(\\n address[] calldata _consensusAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) external payable override onlyValidatorContract {\\n _recordRewards(_consensusAddrs, _rewards, _period);\\n }\\n\\n /**\\n * @inheritdoc IStaking\\n */\\n function execDeductStakingAmount(address _consensusAddr, uint256 _amount)\\n external\\n override\\n onlyValidatorContract\\n returns (uint256 _actualDeductingAmount)\\n {\\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\\n address payable _validatorContractAddr = payable(validatorContract());\\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\\n emit StakingAmountDeductFailed(\\n _consensusAddr,\\n _validatorContractAddr,\\n _actualDeductingAmount,\\n address(this).balance\\n );\\n }\\n }\\n\\n /**\\n * @inheritdoc RewardCalculation\\n */\\n function _currentPeriod() internal view virtual override returns (uint256) {\\n return _validatorContract.currentPeriod();\\n }\\n\\n /**\\n * @inheritdoc CandidateStaking\\n */\\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount)\\n internal\\n override\\n returns (uint256 _actualDeductingAmount)\\n {\\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\\n\\n _pool.stakingAmount -= _actualDeductingAmount;\\n _changeDelegatingAmount(\\n _pool,\\n _pool.admin,\\n _pool.stakingAmount,\\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\\n );\\n emit Unstaked(_pool.addr, _actualDeductingAmount);\\n }\\n}\\n\",\"keccak256\":\"0x6c126a036c4cc2b6946b3ffa83b6620e517eef682b6415dd76763d341e321c8a\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x60806040523480156200001157600080fd5b5060016000556200002162000027565b620000e9565b60d154610100900460ff1615620000945760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60d15460ff9081161015620000e75760d1805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b613bb880620000f96000396000f3fe6080604052600436106101b95760003560e01c806303827884146101f95780630682e8fa14610222578063095f647514610237578063097e4a9d146102645780631658c86e1461028457806326476204146102a45780632715805e146102b75780633d8e846e146102d757806342e0c408146102f757806342ef3c34146103275780634530d202146103475780634d99dd161461036f578063574734471461038f5780635c19a95c146103af5780636558954f146103c2578063679a6e43146103d95780636b091695146103f95780636bd8f8041461041957806376664b6514610439578063888b9ae914610459578063895ab74214610479578063909791dd1461049957806391f8723f146104ae578063924f081e146104ce5780639488e4e9146104ee578063969ffc141461050e578063994390891461052e578063aa15a6fd14610550578063acd79c4614610570578063af24542914610583578063c2a672e014610598578063c5087003146105b8578063cdf64a76146105f1578063d01b8eed14610611578063e22d1c9d1461066c578063e5376f541461068c578063f92ad2191461069f578063f9f031df146106bf576101f0565b366101f057336101c76106df565b6001600160a01b0316146101ee57604051630e6444a160e31b815260040160405180910390fd5b005b336101c76106df565b34801561020557600080fd5b5061020f6104b081565b6040519081526020015b60405180910390f35b34801561022e57600080fd5b5060385461020f565b34801561024357600080fd5b5061025761025236600461334b565b6106ee565b60405161021991906133f1565b34801561027057600080fd5b5061020f61027f366004613419565b610830565b34801561029057600080fd5b506101ee61029f36600461346f565b610935565b6101ee6102b236600461346f565b610a73565b3480156102c357600080fd5b5061020f6102d2366004613493565b610b4b565b3480156102e357600080fd5b506102576102f23660046134bf565b610c0b565b34801561030357600080fd5b5061031761031236600461346f565b610d4f565b6040519015158152602001610219565b34801561033357600080fd5b50610257610342366004613513565b610d6f565b34801561035357600080fd5b50606e54606d5460408051928352602083019190915201610219565b34801561037b57600080fd5b506101ee61038a366004613493565b610e3e565b34801561039b57600080fd5b506101ee6103aa366004613554565b610eba565b6101ee6103bd36600461346f565b610efc565b3480156103ce57600080fd5b5061020f6201518081565b3480156103e557600080fd5b506101ee6103f4366004613576565b610ff9565b34801561040557600080fd5b5061020f61041436600461358f565b61103d565b34801561042557600080fd5b506101ee6104343660046135c8565b61105f565b34801561044557600080fd5b5061020f61045436600461358f565b61116a565b34801561046557600080fd5b506101ee610474366004613576565b611199565b34801561048557600080fd5b5061020f61049436600461346f565b6111da565b3480156104a557600080fd5b50606c5461020f565b3480156104ba57600080fd5b506102576104c9366004613513565b6111f8565b3480156104da57600080fd5b506101ee6104e9366004613609565b6112a2565b3480156104fa57600080fd5b506101ee61050936600461334b565b611411565b34801561051a57600080fd5b506101ee610529366004613576565b61154a565b34801561053a57600080fd5b506105436106df565b604051610219919061363e565b34801561055c57600080fd5b506101ee61056b36600461346f565b61158b565b6101ee61057e366004613652565b611691565b34801561058f57600080fd5b5060395461020f565b3480156105a457600080fd5b506101ee6105b3366004613493565b611709565b3480156105c457600080fd5b506105436105d336600461346f565b6001600160a01b039081166000908152603a60205260409020541690565b3480156105fd57600080fd5b506101ee61060c36600461346f565b611849565b34801561061d57600080fd5b5061065d61062c36600461346f565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604051610219939291906136c5565b34801561067857600080fd5b506101ee6106873660046136e6565b6118b5565b6101ee61069a366004613731565b611aa5565b3480156106ab57600080fd5b506101ee6106ba366004613795565b611be6565b3480156106cb57600080fd5b5061020f6106da366004613513565b611d23565b6036546001600160a01b031690565b6060838214610710576040516376081a7b60e11b815260040160405180910390fd5b836001600160401b03811115610728576107286137d9565b604051908082528060200260200182016040528015610751578160200160208202803683370190505b50905060005b81518110156108275760376000878784818110610776576107766137ef565b905060200201602081019061078b919061346f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060040160008585848181106107c2576107c26137ef565b90506020020160208101906107d7919061346f565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061080a5761080a6137ef565b60209081029190910101528061081f8161381b565b915050610757565b50949350505050565b600060026000540361085d5760405162461bcd60e51b815260040161085490613834565b60405180910390fd5b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d29061089290849060040161363e565b602060405180830381865afa1580156108af573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108d3919061386b565b6108f25780604051630fd0c64560e11b8152600401610854919061363e565b6108fb33610d4f565b1561091b5733604051632fc6bfb160e21b8152600401610854919061363e565b61092733868686611da3565b600160005595945050505050565b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d29061096590849060040161363e565b602060405180830381865afa158015610982573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109a6919061386b565b6109c55780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b038083166000908152603760205260409020600181015490913391168114610a0757604051637bc65bd760e11b815260040160405180910390fd5b60365460395460405163dd716ad360e01b81526001600160a01b039092169163dd716ad391610a3b9188919060040161388d565b600060405180830381600087803b158015610a5557600080fd5b505af1158015610a69573d6000803e3d6000fd5b5050505050505050565b34600003610a9457604051636dfcbde560e11b815260040160405180910390fd5b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d290610ac490849060040161363e565b602060405180830381865afa158015610ae1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b05919061386b565b610b245780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b0382166000908152603760205260409020610b47903334611e10565b5050565b600033610b566106df565b6001600160a01b031614610b7d57604051630e6444a160e31b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260409020610b9f9083611ee3565b90506000610bab6106df565b9050610bb78183611f6e565b610c0457604080518381524760208201526001600160a01b0380841692908716917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b5092915050565b6060600080603660009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c63573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c8791906138a6565b9050836001600160401b03811115610ca157610ca16137d9565b604051908082528060200260200182016040528015610cca578160200160208202803683370190505b50925060005b84811015610d4557858582818110610cea57610cea6137ef565b9050602002016020810190610cff919061346f565b9250610d16838884610d11878c61116a565b611fca565b848281518110610d2857610d286137ef565b602090810291909101015280610d3d8161381b565b915050610cd0565b5050509392505050565b6001600160a01b039081166000908152603a602052604090205416151590565b6060816001600160401b03811115610d8957610d896137d9565b604051908082528060200260200182016040528015610db2578160200160208202803683370190505b50905060005b82811015610c045760376000858584818110610dd657610dd66137ef565b9050602002016020810190610deb919061346f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060020154828281518110610e2157610e216137ef565b602090810291909101015280610e368161381b565b915050610db8565b600260005403610e605760405162461bcd60e51b815260040161085490613834565b600260009081556001600160a01b03831681526037602052604090203390610e899082846120c6565b610e938183612326565b610eb057604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b610ec2612353565b6001600160a01b0316336001600160a01b031614610ef25760405162461bcd60e51b8152600401610854906138bf565b610b478282612381565b34600003610f1d57604051636dfcbde560e11b815260040160405180910390fd5b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d290610f4d90849060040161363e565b602060405180830381865afa158015610f6a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f8e919061386b565b610fad5780604051630fd0c64560e11b8152600401610854919061363e565b610fb633610d4f565b15610fd65733604051632fc6bfb160e21b8152600401610854919061363e565b6001600160a01b0382166000908152603760205260409020610b479033346123f5565b611001612353565b6001600160a01b0316336001600160a01b0316146110315760405162461bcd60e51b8152600401610854906138bf565b61103a816124bd565b50565b6000611056838361104c6124f9565b610d11878761116a565b90505b92915050565b6002600054036110815760405162461bcd60e51b815260040161085490613834565b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d2906110b690849060040161363e565b602060405180830381865afa1580156110d3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110f7919061386b565b6111165780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b0384166000908152603760205260409020339061113b9082856120c6565b6001600160a01b038416600090815260376020526040902061115e9082856123f5565b50506001600055505050565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b6111a1612353565b6001600160a01b0316336001600160a01b0316146111d15760405162461bcd60e51b8152600401610854906138bf565b61103a8161256b565b6001600160a01b031660009081526037602052604090206003015490565b6060816001600160401b03811115611212576112126137d9565b60405190808252806020026020018201604052801561123b578160200160208202803683370190505b50905060005b82811015610c045761127384848381811061125e5761125e6137ef565b9050602002016020810190610494919061346f565b828281518110611285576112856137ef565b60209081029190910101528061129a8161381b565b915050611241565b603654604051635061f96960e11b815284916001600160a01b03169063a0c3f2d2906112d290849060040161363e565b602060405180830381865afa1580156112ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611313919061386b565b6113325780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b03808516600090815260376020526040902060018101549091339116811461137457604051637bc65bd760e11b815260040160405180910390fd5b606d548411806113855750606e5484105b156113a357604051631b8454a360e21b815260040160405180910390fd5b60365460405163e5125a1d60e01b81526001600160a01b039091169063e5125a1d906113d7908990899089906004016136c5565b600060405180830381600087803b1580156113f157600080fd5b505af1158015611405573d6000803e3d6000fd5b50505050505050505050565b6002600054036114335760405162461bcd60e51b815260040161085490613834565b60026000558215806114455750828114155b15611463576040516376081a7b60e11b815260040160405180910390fd5b336000805b8581101561151557848482818110611482576114826137ef565b90506020020135826114949190613901565b9150611503603760008989858181106114af576114af6137ef565b90506020020160208101906114c4919061346f565b6001600160a01b03166001600160a01b03168152602001908152602001600020848787858181106114f7576114f76137ef565b905060200201356120c6565b8061150d8161381b565b915050611468565b506115208282612326565b61153d57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b611552612353565b6001600160a01b0316336001600160a01b0316146115825760405162461bcd60e51b8152600401610854906138bf565b61103a816125a0565b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d2906115bb90849060040161363e565b602060405180830381865afa1580156115d8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115fc919061386b565b61161b5780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b03808316600090815260376020526040902060018101549091339116811461165d57604051637bc65bd760e11b815260040160405180910390fd5b60365460395460405163a7c2f11960e01b81526001600160a01b039092169163a7c2f11991610a3b9188919060040161388d565b3361169a6106df565b6001600160a01b0316146116c157604051630e6444a160e31b815260040160405180910390fd5b6117028585808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508792508691508590506125d5565b5050505050565b60026000540361172b5760405162461bcd60e51b815260040161085490613834565b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d29061176090849060040161363e565b602060405180830381865afa15801561177d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a1919061386b565b6117c05780604051630fd0c64560e11b8152600401610854919061363e565b816000036117e1576040516331d9f7d760e01b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061180c908690613914565b9050606c548110156118315760405163ef0a995760e01b815260040160405180910390fd5b61183c828487612a13565b61152083866104b0612b15565b611851612353565b6001600160a01b0316336001600160a01b0316146118815760405162461bcd60e51b8152600401610854906138bf565b806001600160a01b03163b6000036118ac57604051637bcd509160e01b815260040160405180910390fd5b61103a81612b75565b336118be6106df565b6001600160a01b0316146118e557604051630e6444a160e31b815260040160405180910390fd5b8115611aa05760005b82811015611a655760006037600086868581811061190e5761190e6137ef565b9050602002016020810190611923919061346f565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a909352912080546001600160a01b0319169055600281015490915080156119ea5761197a8282611ee3565b506001820154611996906001600160a01b0316826104b0612b15565b6119ea5760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b6000611a2a878786818110611a0157611a016137ef565b9050602002016020810190611a16919061346f565b60018501546001600160a01b031687612bc0565b90508015611a4f576001830154611a4d906001600160a01b0316826104b0612b15565b505b5050508080611a5d9061381b565b9150506118ee565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d88383604051611a97929190613927565b60405180910390a15b505050565b600260005403611ac75760405162461bcd60e51b815260040161085490613834565b6002600055611ad533610d4f565b15611af55733604051632fc6bfb160e21b8152600401610854919061363e565b606d54811180611b065750606e5481105b15611b2457604051631b8454a360e21b815260040160405180910390fd5b3433611b3581888888888888612cc0565b6001600160a01b0380871660008181526037602081815260408084206001810180549789166001600160a01b0319988916811790915581548816871782558552603a835290842080549096168517909555929091529052611b97818385611e10565b816001600160a01b0316876001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a350506001600055505050505050565b60d154610100900460ff1615808015611c06575060d154600160ff909116105b80611c205750303b158015611c20575060d15460ff166001145b611c835760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610854565b60d1805460ff191660011790558015611ca65760d1805461ff0019166101001790555b611caf86612b75565b611cb8856124bd565b611cc3600085612381565b611ccc8361256b565b611cd5826125a0565b8015611d1b5760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b505050505050565b6000600260005403611d475760405162461bcd60e51b815260040161085490613834565b6002600081905550611d8c33848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f4c92505050565b9050611d983382612faf565b600160005592915050565b6000611de285858580806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f4c92505050565b6001600160a01b0383166000908152603760205260409020909150611e089086836123f5565b949350505050565b6001830154839083906001600160a01b03808316911614611e4457604051637bc65bd760e11b815260040160405180910390fd5b82856002016000828254611e589190613901565b92505081905550611e7e85858760020154868960030154611e799190613901565b612fd6565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d90611ed49086815260200190565b60405180910390a25050505050565b6000611ef3836002015483613011565b905080836002016000828254611f099190613914565b9091555050600183015460028401546003850154611f399286926001600160a01b0390911691611e799086613027565b82546040518281526001600160a01b0390911690600080516020613b438339815191529060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611fbb576040519150601f19603f3d011682016040523d82523d6000602084013e611fc0565b606091505b5090949350505050565b6001600160a01b0380851660009081526002602090815260408083209387168352929052908120600381015484900361200557549050611e08565b6001600160a01b03861660009081526003602081815260408084206001808452828620948701548652939092528320918201548392901561206a57805460018601549094506120549085613914565b85600201546120639190613975565b9250612072565b846001015493505b8154600090612082908690613914565b61208c9089613975565b9050670de0b6b3a76400006120a18286613901565b6120ab919061398c565b86546120b79190613901565b9b9a5050505050505050505050565b6001830154839083906001600160a01b038083169116036120fa57604051639feb934760e01b815260040160405180910390fd5b8260000361211b57604051637ab0c6ad60e11b815260040160405180910390fd5b6001600160a01b038416600090815260048601602052604090205483111561215657604051630695534560e31b815260040160405180910390fd5b6036548554604051635061f96960e11b81526001600160a01b039283169263a0c3f2d2926121899291169060040161363e565b602060405180830381865afa1580156121a6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121ca919061386b565b801561224b575060365485546040516328bde1e160e01b81526001600160a01b03928316926328bde1e1926122049291169060040161363e565b60e060405180830381865afa158015612221573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061224591906139be565b60a00151155b801561227e57506038546001600160a01b0385166000908152600587016020526040902054429161227b91613901565b10155b1561229c5760405163f19f52bd60e01b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020546122da90869086906122ca908790613914565b868960030154611e799190613914565b84546040518481526001600160a01b03918216918616907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c906020015b60405180910390a35050505050565b600081471015612349576040516304611a4560e11b815260040160405180910390fd5b6110568383611f6e565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b61271081118061239057508082115b156123ae57604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b6001830154839083906001600160a01b0380831691160361242957604051639feb934760e01b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020546124679086908690612457908790613901565b868960030154611e799190613901565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b906123179087815260200190565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be2906020015b60405180910390a150565b6036546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa158015612542573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061256691906138a6565b905090565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a906020016124ee565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c678906020016124ee565b8351821461261e57807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a585858560405161261193929190613aa2565b60405180910390a2612a0d565b600080600080600088516001600160401b0381111561263f5761263f6137d9565b604051908082528060200260200182016040528015612668578160200160208202803683370190505b509050600089516001600160401b03811115612686576126866137d9565b6040519080825280602002602001820160405280156126af578160200160208202803683370190505b50905060008a516001600160401b038111156126cd576126cd6137d9565b6040519080825280602002602001820160405280156126f6578160200160208202803683370190505b50905060005b8b51811015612978578b8181518110612717576127176137ef565b60200260200101519550600060036000886001600160a01b03166001600160a01b031681526020019081526020016000209050612753876111da565b6001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a90036127c75786838961278f8161381b565b9a50815181106127a1576127a16137ef565b60200260200101906001600160a01b031690816001600160a01b03168152505050612966565b60028101548a11156127f557604080518082019091528681526020018a905260018101869055600281018a90555b60018101541561283f5760018101548c8c84818110612816576128166137ef565b90506020020135670de0b6b3a76400006128309190613975565b61283a919061398c565b612842565b60005b9850888160000160008282546128589190613901565b918290555090508561286a8a85613914565b8151811061287a5761287a6137ef565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c81526020019081526020016000206000820151816000015560208201518160010155905050858160010160000181905550806001016000015484898461290d9190613914565b8151811061291d5761291d6137ef565b6020908102919091010152868d6129348a85613914565b81518110612944576129446137ef565b60200260200101906001600160a01b031690816001600160a01b031681525050505b806129708161381b565b9150506126fc565b5085156129c157858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a3826040516129b89190613aec565b60405180910390a25b8a5115612a0557877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c85856040516129fc93929190613aff565b60405180910390a25b505050505050505b50505050565b6001830154839083906001600160a01b03808316911614612a4757604051637bc65bd760e11b815260040160405180910390fd5b8460020154831115612a6c57604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b03851660009081526005870160205260409020544291612a9591613901565b1115612ab4576040516303db082960e11b815260040160405180910390fd5b82856002016000828254612ac89190613914565b92505081905550612ae985858760020154868960030154611e799190613914565b84546040518481526001600160a01b0390911690600080516020613b4383398151915290602001611ed4565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114612b65576040519150601f19603f3d011682016040523d82523d6000602084013e612b6a565b606091505b509095945050505050565b603680546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169906124ee90839061363e565b600080612bcd858561116a565b9050612bdb85858584611fca565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b784604051612c2291815260200190565b60405180910390a36001600160a01b03808616600081815260026020908152604080832094891683529381528382208281559282526003905291909120612c6c9082868580613041565b60038181018590556001600160a01b0387811660008181526020938452604080822054600187015551908152918816929091600080516020613b63833981519152910160405180910390a350509392505050565b612ccb876000611f6e565b612d16576040805163338f030160e01b81526001600160a01b03891660048201526024810191909152600a6044820152693837b7b61030b236b4b760b11b6064820152608401610854565b612d21846000611f6e565b612d6a576040805163338f030160e01b81526001600160a01b038616600482015260248101919091526008604482015267747265617375727960c01b6064820152608401610854565b606c54811015612d8d57604051630a8d7fa760e21b815260040160405180910390fd5b856001600160a01b0316876001600160a01b0316141580612dc05750836001600160a01b0316866001600160a01b031614155b15612dde5760405163dc1d04ff60e01b815260040160405180910390fd5b60408051600380825260808201909252600091602082016060803683370190505090508781600081518110612e1557612e156137ef565b60200260200101906001600160a01b031690816001600160a01b0316815250508581600181518110612e4957612e496137ef565b60200260200101906001600160a01b031690816001600160a01b0316815250508381600281518110612e7d57612e7d6137ef565b60200260200101906001600160a01b031690816001600160a01b031681525050612ea6816130d3565b15612ec4576040516329d55f9360e11b815260040160405180910390fd5b6036546040516302209ca560e31b81526001600160a01b0389811660048301528881166024830152878116604483015286811660648301526084820186905290911690631104e5289060a401600060405180830381600087803b158015612f2a57600080fd5b505af1158015612f3e573d6000803e3d6000fd5b505050505050505050505050565b600080612f576124f9565b905060005b8351811015612fa757612f89848281518110612f7a57612f7a6137ef565b60200260200101518684612bc0565b612f939084613901565b925080612f9f8161381b565b915050612f5c565b505092915050565b612fb98282612326565b610b4757604051630c3e69bb60e11b815260040160405180910390fd5b8354612fec906001600160a01b0316848461319a565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b60008183106130205781611056565b5090919050565b6000818311613037576000611056565b6110568284613914565b828460030154101561305557600284018190555b6000613065856002015484613011565b905060008186600201546130799190613914565b905080156130ca576002860182905560018701548111156130ad576040516352e521bf60e11b815260040160405180910390fd5b808760010160000160008282546130c49190613914565b90915550505b50505050505050565b600081516000036130e657506000919050565b60005b600183516130f79190613914565b81101561319157600061310b826001613901565b90505b835181101561317e57838181518110613129576131296137ef565b60200260200101516001600160a01b031684838151811061314c5761314c6137ef565b60200260200101516001600160a01b03160361316c575060019392505050565b806131768161381b565b91505061310e565b50806131898161381b565b9150506130e9565b50600092915050565b60006131a46124f9565b6001600160a01b03851660009081526003602052604090206001810154600282015492935090918311156131ff5760405180604001604052806131e6886111da565b8152602090810185905281516001850155015160028301555b6001600160a01b038087166000908152600260209081526040808320938916835292905290812090613231888861116a565b9050600061324189898885611fca565b83549091508114613281578083556040518181526001600160a01b0389811691908b1690600080516020613b638339815191529060200160405180910390a35b61328e8584888a86613041565b84546001808501919091556003840187905585015484146132f557886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c87600101600001546040516132ec91815260200190565b60405180910390a35b505050505050505050565b60008083601f84011261331257600080fd5b5081356001600160401b0381111561332957600080fd5b6020830191508360208260051b850101111561334457600080fd5b9250929050565b6000806000806040858703121561336157600080fd5b84356001600160401b038082111561337857600080fd5b61338488838901613300565b9096509450602087013591508082111561339d57600080fd5b506133aa87828801613300565b95989497509550505050565b600081518084526020808501945080840160005b838110156133e6578151875295820195908201906001016133ca565b509495945050505050565b60208152600061105660208301846133b6565b6001600160a01b038116811461103a57600080fd5b60008060006040848603121561342e57600080fd5b83356001600160401b0381111561344457600080fd5b61345086828701613300565b909450925050602084013561346481613404565b809150509250925092565b60006020828403121561348157600080fd5b813561348c81613404565b9392505050565b600080604083850312156134a657600080fd5b82356134b181613404565b946020939093013593505050565b6000806000604084860312156134d457600080fd5b83356134df81613404565b925060208401356001600160401b038111156134fa57600080fd5b61350686828701613300565b9497909650939450505050565b6000806020838503121561352657600080fd5b82356001600160401b0381111561353c57600080fd5b61354885828601613300565b90969095509350505050565b6000806040838503121561356757600080fd5b50508035926020909101359150565b60006020828403121561358857600080fd5b5035919050565b600080604083850312156135a257600080fd5b82356135ad81613404565b915060208301356135bd81613404565b809150509250929050565b6000806000606084860312156135dd57600080fd5b83356135e881613404565b925060208401356135f881613404565b929592945050506040919091013590565b60008060006060848603121561361e57600080fd5b833561362981613404565b95602085013595506040909401359392505050565b6001600160a01b0391909116815260200190565b60008060008060006060868803121561366a57600080fd5b85356001600160401b038082111561368157600080fd5b61368d89838a01613300565b909750955060208801359150808211156136a657600080fd5b506136b388828901613300565b96999598509660400135949350505050565b6001600160a01b039390931683526020830191909152604082015260600190565b6000806000604084860312156136fb57600080fd5b83356001600160401b0381111561371157600080fd5b61371d86828701613300565b909790965060209590950135949350505050565b600080600080600060a0868803121561374957600080fd5b853561375481613404565b9450602086013561376481613404565b9350604086013561377481613404565b9250606086013561378481613404565b949793965091946080013592915050565b600080600080600060a086880312156137ad57600080fd5b85356137b881613404565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006001820161382d5761382d613805565b5060010190565b6020808252601f908201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604082015260600190565b60006020828403121561387d57600080fd5b8151801515811461348c57600080fd5b6001600160a01b03929092168252602082015260400190565b6000602082840312156138b857600080fd5b5051919050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b8082018082111561105957611059613805565b8181038181111561105957611059613805565b60208082528181018390526000908460408401835b8681101561396a57823561394f81613404565b6001600160a01b03168252918301919083019060010161393c565b509695505050505050565b808202811582820484141761105957611059613805565b6000826139a957634e487b7160e01b600052601260045260246000fd5b500490565b80516139b981613404565b919050565b600060e082840312156139d057600080fd5b60405160e081016001600160401b0381118282101715613a0057634e487b7160e01b600052604160045260246000fd5b604052613a0c836139ae565b8152613a1a602084016139ae565b6020820152613a2b604084016139ae565b6040820152613a3c606084016139ae565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b600081518084526020808501945080840160005b838110156133e65781516001600160a01b031687529582019590820190600101613a7d565b604081526000613ab56040830186613a69565b82810360208401528381526001600160fb1b03841115613ad457600080fd5b8360051b808660208401370160200195945050505050565b6020815260006110566020830184613a69565b606081526000613b126060830186613a69565b8281036020840152613b2481866133b6565b90508281036040840152613b3881856133b6565b969550505050505056fe0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f75aa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ada264697066735822122084a2646a7e3b284e947649e3c4cea51c75829bcabae922a4d19175bd5ef9292564736f6c63430008110033", - "deployedBytecode": "0x6080604052600436106101b95760003560e01c806303827884146101f95780630682e8fa14610222578063095f647514610237578063097e4a9d146102645780631658c86e1461028457806326476204146102a45780632715805e146102b75780633d8e846e146102d757806342e0c408146102f757806342ef3c34146103275780634530d202146103475780634d99dd161461036f578063574734471461038f5780635c19a95c146103af5780636558954f146103c2578063679a6e43146103d95780636b091695146103f95780636bd8f8041461041957806376664b6514610439578063888b9ae914610459578063895ab74214610479578063909791dd1461049957806391f8723f146104ae578063924f081e146104ce5780639488e4e9146104ee578063969ffc141461050e578063994390891461052e578063aa15a6fd14610550578063acd79c4614610570578063af24542914610583578063c2a672e014610598578063c5087003146105b8578063cdf64a76146105f1578063d01b8eed14610611578063e22d1c9d1461066c578063e5376f541461068c578063f92ad2191461069f578063f9f031df146106bf576101f0565b366101f057336101c76106df565b6001600160a01b0316146101ee57604051630e6444a160e31b815260040160405180910390fd5b005b336101c76106df565b34801561020557600080fd5b5061020f6104b081565b6040519081526020015b60405180910390f35b34801561022e57600080fd5b5060385461020f565b34801561024357600080fd5b5061025761025236600461334b565b6106ee565b60405161021991906133f1565b34801561027057600080fd5b5061020f61027f366004613419565b610830565b34801561029057600080fd5b506101ee61029f36600461346f565b610935565b6101ee6102b236600461346f565b610a73565b3480156102c357600080fd5b5061020f6102d2366004613493565b610b4b565b3480156102e357600080fd5b506102576102f23660046134bf565b610c0b565b34801561030357600080fd5b5061031761031236600461346f565b610d4f565b6040519015158152602001610219565b34801561033357600080fd5b50610257610342366004613513565b610d6f565b34801561035357600080fd5b50606e54606d5460408051928352602083019190915201610219565b34801561037b57600080fd5b506101ee61038a366004613493565b610e3e565b34801561039b57600080fd5b506101ee6103aa366004613554565b610eba565b6101ee6103bd36600461346f565b610efc565b3480156103ce57600080fd5b5061020f6201518081565b3480156103e557600080fd5b506101ee6103f4366004613576565b610ff9565b34801561040557600080fd5b5061020f61041436600461358f565b61103d565b34801561042557600080fd5b506101ee6104343660046135c8565b61105f565b34801561044557600080fd5b5061020f61045436600461358f565b61116a565b34801561046557600080fd5b506101ee610474366004613576565b611199565b34801561048557600080fd5b5061020f61049436600461346f565b6111da565b3480156104a557600080fd5b50606c5461020f565b3480156104ba57600080fd5b506102576104c9366004613513565b6111f8565b3480156104da57600080fd5b506101ee6104e9366004613609565b6112a2565b3480156104fa57600080fd5b506101ee61050936600461334b565b611411565b34801561051a57600080fd5b506101ee610529366004613576565b61154a565b34801561053a57600080fd5b506105436106df565b604051610219919061363e565b34801561055c57600080fd5b506101ee61056b36600461346f565b61158b565b6101ee61057e366004613652565b611691565b34801561058f57600080fd5b5060395461020f565b3480156105a457600080fd5b506101ee6105b3366004613493565b611709565b3480156105c457600080fd5b506105436105d336600461346f565b6001600160a01b039081166000908152603a60205260409020541690565b3480156105fd57600080fd5b506101ee61060c36600461346f565b611849565b34801561061d57600080fd5b5061065d61062c36600461346f565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604051610219939291906136c5565b34801561067857600080fd5b506101ee6106873660046136e6565b6118b5565b6101ee61069a366004613731565b611aa5565b3480156106ab57600080fd5b506101ee6106ba366004613795565b611be6565b3480156106cb57600080fd5b5061020f6106da366004613513565b611d23565b6036546001600160a01b031690565b6060838214610710576040516376081a7b60e11b815260040160405180910390fd5b836001600160401b03811115610728576107286137d9565b604051908082528060200260200182016040528015610751578160200160208202803683370190505b50905060005b81518110156108275760376000878784818110610776576107766137ef565b905060200201602081019061078b919061346f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060040160008585848181106107c2576107c26137ef565b90506020020160208101906107d7919061346f565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061080a5761080a6137ef565b60209081029190910101528061081f8161381b565b915050610757565b50949350505050565b600060026000540361085d5760405162461bcd60e51b815260040161085490613834565b60405180910390fd5b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d29061089290849060040161363e565b602060405180830381865afa1580156108af573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108d3919061386b565b6108f25780604051630fd0c64560e11b8152600401610854919061363e565b6108fb33610d4f565b1561091b5733604051632fc6bfb160e21b8152600401610854919061363e565b61092733868686611da3565b600160005595945050505050565b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d29061096590849060040161363e565b602060405180830381865afa158015610982573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906109a6919061386b565b6109c55780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b038083166000908152603760205260409020600181015490913391168114610a0757604051637bc65bd760e11b815260040160405180910390fd5b60365460395460405163dd716ad360e01b81526001600160a01b039092169163dd716ad391610a3b9188919060040161388d565b600060405180830381600087803b158015610a5557600080fd5b505af1158015610a69573d6000803e3d6000fd5b5050505050505050565b34600003610a9457604051636dfcbde560e11b815260040160405180910390fd5b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d290610ac490849060040161363e565b602060405180830381865afa158015610ae1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b05919061386b565b610b245780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b0382166000908152603760205260409020610b47903334611e10565b5050565b600033610b566106df565b6001600160a01b031614610b7d57604051630e6444a160e31b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260409020610b9f9083611ee3565b90506000610bab6106df565b9050610bb78183611f6e565b610c0457604080518381524760208201526001600160a01b0380841692908716917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b5092915050565b6060600080603660009054906101000a90046001600160a01b03166001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610c63573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c8791906138a6565b9050836001600160401b03811115610ca157610ca16137d9565b604051908082528060200260200182016040528015610cca578160200160208202803683370190505b50925060005b84811015610d4557858582818110610cea57610cea6137ef565b9050602002016020810190610cff919061346f565b9250610d16838884610d11878c61116a565b611fca565b848281518110610d2857610d286137ef565b602090810291909101015280610d3d8161381b565b915050610cd0565b5050509392505050565b6001600160a01b039081166000908152603a602052604090205416151590565b6060816001600160401b03811115610d8957610d896137d9565b604051908082528060200260200182016040528015610db2578160200160208202803683370190505b50905060005b82811015610c045760376000858584818110610dd657610dd66137ef565b9050602002016020810190610deb919061346f565b6001600160a01b03166001600160a01b0316815260200190815260200160002060020154828281518110610e2157610e216137ef565b602090810291909101015280610e368161381b565b915050610db8565b600260005403610e605760405162461bcd60e51b815260040161085490613834565b600260009081556001600160a01b03831681526037602052604090203390610e899082846120c6565b610e938183612326565b610eb057604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b610ec2612353565b6001600160a01b0316336001600160a01b031614610ef25760405162461bcd60e51b8152600401610854906138bf565b610b478282612381565b34600003610f1d57604051636dfcbde560e11b815260040160405180910390fd5b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d290610f4d90849060040161363e565b602060405180830381865afa158015610f6a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f8e919061386b565b610fad5780604051630fd0c64560e11b8152600401610854919061363e565b610fb633610d4f565b15610fd65733604051632fc6bfb160e21b8152600401610854919061363e565b6001600160a01b0382166000908152603760205260409020610b479033346123f5565b611001612353565b6001600160a01b0316336001600160a01b0316146110315760405162461bcd60e51b8152600401610854906138bf565b61103a816124bd565b50565b6000611056838361104c6124f9565b610d11878761116a565b90505b92915050565b6002600054036110815760405162461bcd60e51b815260040161085490613834565b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d2906110b690849060040161363e565b602060405180830381865afa1580156110d3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110f7919061386b565b6111165780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b0384166000908152603760205260409020339061113b9082856120c6565b6001600160a01b038416600090815260376020526040902061115e9082856123f5565b50506001600055505050565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b6111a1612353565b6001600160a01b0316336001600160a01b0316146111d15760405162461bcd60e51b8152600401610854906138bf565b61103a8161256b565b6001600160a01b031660009081526037602052604090206003015490565b6060816001600160401b03811115611212576112126137d9565b60405190808252806020026020018201604052801561123b578160200160208202803683370190505b50905060005b82811015610c045761127384848381811061125e5761125e6137ef565b9050602002016020810190610494919061346f565b828281518110611285576112856137ef565b60209081029190910101528061129a8161381b565b915050611241565b603654604051635061f96960e11b815284916001600160a01b03169063a0c3f2d2906112d290849060040161363e565b602060405180830381865afa1580156112ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611313919061386b565b6113325780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b03808516600090815260376020526040902060018101549091339116811461137457604051637bc65bd760e11b815260040160405180910390fd5b606d548411806113855750606e5484105b156113a357604051631b8454a360e21b815260040160405180910390fd5b60365460405163e5125a1d60e01b81526001600160a01b039091169063e5125a1d906113d7908990899089906004016136c5565b600060405180830381600087803b1580156113f157600080fd5b505af1158015611405573d6000803e3d6000fd5b50505050505050505050565b6002600054036114335760405162461bcd60e51b815260040161085490613834565b60026000558215806114455750828114155b15611463576040516376081a7b60e11b815260040160405180910390fd5b336000805b8581101561151557848482818110611482576114826137ef565b90506020020135826114949190613901565b9150611503603760008989858181106114af576114af6137ef565b90506020020160208101906114c4919061346f565b6001600160a01b03166001600160a01b03168152602001908152602001600020848787858181106114f7576114f76137ef565b905060200201356120c6565b8061150d8161381b565b915050611468565b506115208282612326565b61153d57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b611552612353565b6001600160a01b0316336001600160a01b0316146115825760405162461bcd60e51b8152600401610854906138bf565b61103a816125a0565b603654604051635061f96960e11b815282916001600160a01b03169063a0c3f2d2906115bb90849060040161363e565b602060405180830381865afa1580156115d8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115fc919061386b565b61161b5780604051630fd0c64560e11b8152600401610854919061363e565b6001600160a01b03808316600090815260376020526040902060018101549091339116811461165d57604051637bc65bd760e11b815260040160405180910390fd5b60365460395460405163a7c2f11960e01b81526001600160a01b039092169163a7c2f11991610a3b9188919060040161388d565b3361169a6106df565b6001600160a01b0316146116c157604051630e6444a160e31b815260040160405180910390fd5b6117028585808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152508792508691508590506125d5565b5050505050565b60026000540361172b5760405162461bcd60e51b815260040161085490613834565b6002600055603654604051635061f96960e11b815283916001600160a01b03169063a0c3f2d29061176090849060040161363e565b602060405180830381865afa15801561177d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117a1919061386b565b6117c05780604051630fd0c64560e11b8152600401610854919061363e565b816000036117e1576040516331d9f7d760e01b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061180c908690613914565b9050606c548110156118315760405163ef0a995760e01b815260040160405180910390fd5b61183c828487612a13565b61152083866104b0612b15565b611851612353565b6001600160a01b0316336001600160a01b0316146118815760405162461bcd60e51b8152600401610854906138bf565b806001600160a01b03163b6000036118ac57604051637bcd509160e01b815260040160405180910390fd5b61103a81612b75565b336118be6106df565b6001600160a01b0316146118e557604051630e6444a160e31b815260040160405180910390fd5b8115611aa05760005b82811015611a655760006037600086868581811061190e5761190e6137ef565b9050602002016020810190611923919061346f565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a909352912080546001600160a01b0319169055600281015490915080156119ea5761197a8282611ee3565b506001820154611996906001600160a01b0316826104b0612b15565b6119ea5760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b6000611a2a878786818110611a0157611a016137ef565b9050602002016020810190611a16919061346f565b60018501546001600160a01b031687612bc0565b90508015611a4f576001830154611a4d906001600160a01b0316826104b0612b15565b505b5050508080611a5d9061381b565b9150506118ee565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d88383604051611a97929190613927565b60405180910390a15b505050565b600260005403611ac75760405162461bcd60e51b815260040161085490613834565b6002600055611ad533610d4f565b15611af55733604051632fc6bfb160e21b8152600401610854919061363e565b606d54811180611b065750606e5481105b15611b2457604051631b8454a360e21b815260040160405180910390fd5b3433611b3581888888888888612cc0565b6001600160a01b0380871660008181526037602081815260408084206001810180549789166001600160a01b0319988916811790915581548816871782558552603a835290842080549096168517909555929091529052611b97818385611e10565b816001600160a01b0316876001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a350506001600055505050505050565b60d154610100900460ff1615808015611c06575060d154600160ff909116105b80611c205750303b158015611c20575060d15460ff166001145b611c835760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610854565b60d1805460ff191660011790558015611ca65760d1805461ff0019166101001790555b611caf86612b75565b611cb8856124bd565b611cc3600085612381565b611ccc8361256b565b611cd5826125a0565b8015611d1b5760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b505050505050565b6000600260005403611d475760405162461bcd60e51b815260040161085490613834565b6002600081905550611d8c33848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f4c92505050565b9050611d983382612faf565b600160005592915050565b6000611de285858580806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612f4c92505050565b6001600160a01b0383166000908152603760205260409020909150611e089086836123f5565b949350505050565b6001830154839083906001600160a01b03808316911614611e4457604051637bc65bd760e11b815260040160405180910390fd5b82856002016000828254611e589190613901565b92505081905550611e7e85858760020154868960030154611e799190613901565b612fd6565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d90611ed49086815260200190565b60405180910390a25050505050565b6000611ef3836002015483613011565b905080836002016000828254611f099190613914565b9091555050600183015460028401546003850154611f399286926001600160a01b0390911691611e799086613027565b82546040518281526001600160a01b0390911690600080516020613b438339815191529060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611fbb576040519150601f19603f3d011682016040523d82523d6000602084013e611fc0565b606091505b5090949350505050565b6001600160a01b0380851660009081526002602090815260408083209387168352929052908120600381015484900361200557549050611e08565b6001600160a01b03861660009081526003602081815260408084206001808452828620948701548652939092528320918201548392901561206a57805460018601549094506120549085613914565b85600201546120639190613975565b9250612072565b846001015493505b8154600090612082908690613914565b61208c9089613975565b9050670de0b6b3a76400006120a18286613901565b6120ab919061398c565b86546120b79190613901565b9b9a5050505050505050505050565b6001830154839083906001600160a01b038083169116036120fa57604051639feb934760e01b815260040160405180910390fd5b8260000361211b57604051637ab0c6ad60e11b815260040160405180910390fd5b6001600160a01b038416600090815260048601602052604090205483111561215657604051630695534560e31b815260040160405180910390fd5b6036548554604051635061f96960e11b81526001600160a01b039283169263a0c3f2d2926121899291169060040161363e565b602060405180830381865afa1580156121a6573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121ca919061386b565b801561224b575060365485546040516328bde1e160e01b81526001600160a01b03928316926328bde1e1926122049291169060040161363e565b60e060405180830381865afa158015612221573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061224591906139be565b60a00151155b801561227e57506038546001600160a01b0385166000908152600587016020526040902054429161227b91613901565b10155b1561229c5760405163f19f52bd60e01b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020546122da90869086906122ca908790613914565b868960030154611e799190613914565b84546040518481526001600160a01b03918216918616907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c906020015b60405180910390a35050505050565b600081471015612349576040516304611a4560e11b815260040160405180910390fd5b6110568383611f6e565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b61271081118061239057508082115b156123ae57604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b6001830154839083906001600160a01b0380831691160361242957604051639feb934760e01b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020546124679086908690612457908790613901565b868960030154611e799190613901565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b906123179087815260200190565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be2906020015b60405180910390a150565b6036546040805162c080c360e31b815290516000926001600160a01b03169163060406189160048083019260209291908290030181865afa158015612542573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061256691906138a6565b905090565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a906020016124ee565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c678906020016124ee565b8351821461261e57807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a585858560405161261193929190613aa2565b60405180910390a2612a0d565b600080600080600088516001600160401b0381111561263f5761263f6137d9565b604051908082528060200260200182016040528015612668578160200160208202803683370190505b509050600089516001600160401b03811115612686576126866137d9565b6040519080825280602002602001820160405280156126af578160200160208202803683370190505b50905060008a516001600160401b038111156126cd576126cd6137d9565b6040519080825280602002602001820160405280156126f6578160200160208202803683370190505b50905060005b8b51811015612978578b8181518110612717576127176137ef565b60200260200101519550600060036000886001600160a01b03166001600160a01b031681526020019081526020016000209050612753876111da565b6001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a90036127c75786838961278f8161381b565b9a50815181106127a1576127a16137ef565b60200260200101906001600160a01b031690816001600160a01b03168152505050612966565b60028101548a11156127f557604080518082019091528681526020018a905260018101869055600281018a90555b60018101541561283f5760018101548c8c84818110612816576128166137ef565b90506020020135670de0b6b3a76400006128309190613975565b61283a919061398c565b612842565b60005b9850888160000160008282546128589190613901565b918290555090508561286a8a85613914565b8151811061287a5761287a6137ef565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c81526020019081526020016000206000820151816000015560208201518160010155905050858160010160000181905550806001016000015484898461290d9190613914565b8151811061291d5761291d6137ef565b6020908102919091010152868d6129348a85613914565b81518110612944576129446137ef565b60200260200101906001600160a01b031690816001600160a01b031681525050505b806129708161381b565b9150506126fc565b5085156129c157858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a3826040516129b89190613aec565b60405180910390a25b8a5115612a0557877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c85856040516129fc93929190613aff565b60405180910390a25b505050505050505b50505050565b6001830154839083906001600160a01b03808316911614612a4757604051637bc65bd760e11b815260040160405180910390fd5b8460020154831115612a6c57604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b03851660009081526005870160205260409020544291612a9591613901565b1115612ab4576040516303db082960e11b815260040160405180910390fd5b82856002016000828254612ac89190613914565b92505081905550612ae985858760020154868960030154611e799190613914565b84546040518481526001600160a01b0390911690600080516020613b4383398151915290602001611ed4565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114612b65576040519150601f19603f3d011682016040523d82523d6000602084013e612b6a565b606091505b509095945050505050565b603680546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b6836169906124ee90839061363e565b600080612bcd858561116a565b9050612bdb85858584611fca565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b784604051612c2291815260200190565b60405180910390a36001600160a01b03808616600081815260026020908152604080832094891683529381528382208281559282526003905291909120612c6c9082868580613041565b60038181018590556001600160a01b0387811660008181526020938452604080822054600187015551908152918816929091600080516020613b63833981519152910160405180910390a350509392505050565b612ccb876000611f6e565b612d16576040805163338f030160e01b81526001600160a01b03891660048201526024810191909152600a6044820152693837b7b61030b236b4b760b11b6064820152608401610854565b612d21846000611f6e565b612d6a576040805163338f030160e01b81526001600160a01b038616600482015260248101919091526008604482015267747265617375727960c01b6064820152608401610854565b606c54811015612d8d57604051630a8d7fa760e21b815260040160405180910390fd5b856001600160a01b0316876001600160a01b0316141580612dc05750836001600160a01b0316866001600160a01b031614155b15612dde5760405163dc1d04ff60e01b815260040160405180910390fd5b60408051600380825260808201909252600091602082016060803683370190505090508781600081518110612e1557612e156137ef565b60200260200101906001600160a01b031690816001600160a01b0316815250508581600181518110612e4957612e496137ef565b60200260200101906001600160a01b031690816001600160a01b0316815250508381600281518110612e7d57612e7d6137ef565b60200260200101906001600160a01b031690816001600160a01b031681525050612ea6816130d3565b15612ec4576040516329d55f9360e11b815260040160405180910390fd5b6036546040516302209ca560e31b81526001600160a01b0389811660048301528881166024830152878116604483015286811660648301526084820186905290911690631104e5289060a401600060405180830381600087803b158015612f2a57600080fd5b505af1158015612f3e573d6000803e3d6000fd5b505050505050505050505050565b600080612f576124f9565b905060005b8351811015612fa757612f89848281518110612f7a57612f7a6137ef565b60200260200101518684612bc0565b612f939084613901565b925080612f9f8161381b565b915050612f5c565b505092915050565b612fb98282612326565b610b4757604051630c3e69bb60e11b815260040160405180910390fd5b8354612fec906001600160a01b0316848461319a565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b60008183106130205781611056565b5090919050565b6000818311613037576000611056565b6110568284613914565b828460030154101561305557600284018190555b6000613065856002015484613011565b905060008186600201546130799190613914565b905080156130ca576002860182905560018701548111156130ad576040516352e521bf60e11b815260040160405180910390fd5b808760010160000160008282546130c49190613914565b90915550505b50505050505050565b600081516000036130e657506000919050565b60005b600183516130f79190613914565b81101561319157600061310b826001613901565b90505b835181101561317e57838181518110613129576131296137ef565b60200260200101516001600160a01b031684838151811061314c5761314c6137ef565b60200260200101516001600160a01b03160361316c575060019392505050565b806131768161381b565b91505061310e565b50806131898161381b565b9150506130e9565b50600092915050565b60006131a46124f9565b6001600160a01b03851660009081526003602052604090206001810154600282015492935090918311156131ff5760405180604001604052806131e6886111da565b8152602090810185905281516001850155015160028301555b6001600160a01b038087166000908152600260209081526040808320938916835292905290812090613231888861116a565b9050600061324189898885611fca565b83549091508114613281578083556040518181526001600160a01b0389811691908b1690600080516020613b638339815191529060200160405180910390a35b61328e8584888a86613041565b84546001808501919091556003840187905585015484146132f557886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c87600101600001546040516132ec91815260200190565b60405180910390a35b505050505050505050565b60008083601f84011261331257600080fd5b5081356001600160401b0381111561332957600080fd5b6020830191508360208260051b850101111561334457600080fd5b9250929050565b6000806000806040858703121561336157600080fd5b84356001600160401b038082111561337857600080fd5b61338488838901613300565b9096509450602087013591508082111561339d57600080fd5b506133aa87828801613300565b95989497509550505050565b600081518084526020808501945080840160005b838110156133e6578151875295820195908201906001016133ca565b509495945050505050565b60208152600061105660208301846133b6565b6001600160a01b038116811461103a57600080fd5b60008060006040848603121561342e57600080fd5b83356001600160401b0381111561344457600080fd5b61345086828701613300565b909450925050602084013561346481613404565b809150509250925092565b60006020828403121561348157600080fd5b813561348c81613404565b9392505050565b600080604083850312156134a657600080fd5b82356134b181613404565b946020939093013593505050565b6000806000604084860312156134d457600080fd5b83356134df81613404565b925060208401356001600160401b038111156134fa57600080fd5b61350686828701613300565b9497909650939450505050565b6000806020838503121561352657600080fd5b82356001600160401b0381111561353c57600080fd5b61354885828601613300565b90969095509350505050565b6000806040838503121561356757600080fd5b50508035926020909101359150565b60006020828403121561358857600080fd5b5035919050565b600080604083850312156135a257600080fd5b82356135ad81613404565b915060208301356135bd81613404565b809150509250929050565b6000806000606084860312156135dd57600080fd5b83356135e881613404565b925060208401356135f881613404565b929592945050506040919091013590565b60008060006060848603121561361e57600080fd5b833561362981613404565b95602085013595506040909401359392505050565b6001600160a01b0391909116815260200190565b60008060008060006060868803121561366a57600080fd5b85356001600160401b038082111561368157600080fd5b61368d89838a01613300565b909750955060208801359150808211156136a657600080fd5b506136b388828901613300565b96999598509660400135949350505050565b6001600160a01b039390931683526020830191909152604082015260600190565b6000806000604084860312156136fb57600080fd5b83356001600160401b0381111561371157600080fd5b61371d86828701613300565b909790965060209590950135949350505050565b600080600080600060a0868803121561374957600080fd5b853561375481613404565b9450602086013561376481613404565b9350604086013561377481613404565b9250606086013561378481613404565b949793965091946080013592915050565b600080600080600060a086880312156137ad57600080fd5b85356137b881613404565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006001820161382d5761382d613805565b5060010190565b6020808252601f908201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604082015260600190565b60006020828403121561387d57600080fd5b8151801515811461348c57600080fd5b6001600160a01b03929092168252602082015260400190565b6000602082840312156138b857600080fd5b5051919050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b606082015260800190565b8082018082111561105957611059613805565b8181038181111561105957611059613805565b60208082528181018390526000908460408401835b8681101561396a57823561394f81613404565b6001600160a01b03168252918301919083019060010161393c565b509695505050505050565b808202811582820484141761105957611059613805565b6000826139a957634e487b7160e01b600052601260045260246000fd5b500490565b80516139b981613404565b919050565b600060e082840312156139d057600080fd5b60405160e081016001600160401b0381118282101715613a0057634e487b7160e01b600052604160045260246000fd5b604052613a0c836139ae565b8152613a1a602084016139ae565b6020820152613a2b604084016139ae565b6040820152613a3c606084016139ae565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b600081518084526020808501945080840160005b838110156133e65781516001600160a01b031687529582019590820190600101613a7d565b604081526000613ab56040830186613a69565b82810360208401528381526001600160fb1b03841115613ad457600080fd5b8360051b808660208401370160200195945050505050565b6020815260006110566020830184613a69565b606081526000613b126060830186613a69565b8281036020840152613b2481866133b6565b90508281036040840152613b3881856133b6565b969550505050505056fe0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f75aa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ada264697066735822122084a2646a7e3b284e947649e3c4cea51c75829bcabae922a4d19175bd5ef9292564736f6c63430008110033", + "numDeployments": 3, + "solcInputHash": "0e13282b1de32a862f3ea9c3dc0543e9", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"ErrAdminOfAnyActivePoolForbidden\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"},{\"internalType\":\"string\",\"name\":\"extraInfo\",\"type\":\"string\"}],\"name\":\"ErrCannotInitTransferRON\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrCannotTransferRON\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrDuplicated\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"}],\"name\":\"ErrInactivePool\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"currentBalance\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"sendAmount\",\"type\":\"uint256\"}],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientDelegatingAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientStakingAmount\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidArrays\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidCommissionRate\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInvalidPoolShare\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrOnlyPoolAdminAllowed\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrPoolAdminForbidden\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrStakingAmountLeft\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrThreeInteractionAddrsNotEqual\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUndelegateTooEarly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUndelegateZeroAmount\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnstakeTooEarly\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrUnstakeZeroAmount\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroValue\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minRate\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"maxRate\",\"type\":\"uint256\"}],\"name\":\"CommissionRateRangeUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"minSecs\",\"type\":\"uint256\"}],\"name\":\"CooldownSecsToUndelegateUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"delegator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Delegated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"threshold\",\"type\":\"uint256\"}],\"name\":\"MinValidatorStakingAmountUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"}],\"name\":\"PoolApproved\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"shares\",\"type\":\"uint256\"}],\"name\":\"PoolSharesUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"validator\",\"type\":\"address[]\"}],\"name\":\"PoolsDeprecated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"}],\"name\":\"PoolsUpdateConflicted\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"rewards\",\"type\":\"uint256[]\"}],\"name\":\"PoolsUpdateFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"period\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"address[]\",\"name\":\"poolAddrs\",\"type\":\"address[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"aRps\",\"type\":\"uint256[]\"},{\"indexed\":false,\"internalType\":\"uint256[]\",\"name\":\"shares\",\"type\":\"uint256[]\"}],\"name\":\"PoolsUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"user\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"RewardClaimed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Staked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingAmountDeductFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"validator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"admin\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"StakingAmountTransferFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"delegator\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Undelegated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"consensuAddr\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"amount\",\"type\":\"uint256\"}],\"name\":\"Unstaked\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"address\",\"name\":\"poolAddr\",\"type\":\"address\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"user\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"debited\",\"type\":\"uint256\"}],\"name\":\"UserRewardUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"secs\",\"type\":\"uint256\"}],\"name\":\"WaitingSecsToRevokeUpdated\",\"type\":\"event\"},{\"stateMutability\":\"payable\",\"type\":\"fallback\"},{\"inputs\":[],\"name\":\"DEFAULT_ADDITION_GAS\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"PERIOD_DURATION\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"applyValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrs\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_amounts\",\"type\":\"uint256[]\"}],\"name\":\"bulkUndelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrList\",\"type\":\"address[]\"}],\"name\":\"claimRewards\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"cooldownSecsToUndelegate\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"delegate\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrList\",\"type\":\"address[]\"},{\"internalType\":\"address\",\"name\":\"_consensusAddrDst\",\"type\":\"address\"}],\"name\":\"delegateRewards\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"execDeductStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"_actualDeductingAmount\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_pools\",\"type\":\"address[]\"},{\"internalType\":\"uint256\",\"name\":\"_newPeriod\",\"type\":\"uint256\"}],\"name\":\"execDeprecatePools\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_consensusAddrs\",\"type\":\"address[]\"},{\"internalType\":\"uint256[]\",\"name\":\"_rewards\",\"type\":\"uint256[]\"},{\"internalType\":\"uint256\",\"name\":\"_period\",\"type\":\"uint256\"}],\"name\":\"execRecordRewards\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"getCommissionRateRange\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_pools\",\"type\":\"address[]\"}],\"name\":\"getManySelfStakings\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_selfStakings\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_poolAddrs\",\"type\":\"address[]\"},{\"internalType\":\"address[]\",\"name\":\"_userList\",\"type\":\"address[]\"}],\"name\":\"getManyStakingAmounts\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_stakingAmounts\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address[]\",\"name\":\"_poolList\",\"type\":\"address[]\"}],\"name\":\"getManyStakingTotals\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_stakingAmounts\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAdminAddr\",\"type\":\"address\"}],\"name\":\"getPoolAddressOf\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"}],\"name\":\"getPoolDetail\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"_admin\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_stakingAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_stakingTotal\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"}],\"name\":\"getReward\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"},{\"internalType\":\"address[]\",\"name\":\"_poolAddrList\",\"type\":\"address[]\"}],\"name\":\"getRewards\",\"outputs\":[{\"internalType\":\"uint256[]\",\"name\":\"_rewards\",\"type\":\"uint256[]\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_user\",\"type\":\"address\"}],\"name\":\"getStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAddr\",\"type\":\"address\"}],\"name\":\"getStakingTotal\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__minValidatorStakingAmount\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__maxCommissionRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__cooldownSecsToUndelegate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__waitingSecsToRevoke\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_poolAdminAddr\",\"type\":\"address\"}],\"name\":\"isAdminOfActivePool\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"\",\"type\":\"bool\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"minValidatorStakingAmount\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddrSrc\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddrDst\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"redelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"requestEmergencyExit\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"requestRenounce\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_effectiveDaysOnwards\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"requestUpdateCommissionRate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_minRate\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_maxRate\",\"type\":\"uint256\"}],\"name\":\"setCommissionRateRange\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_cooldownSecs\",\"type\":\"uint256\"}],\"name\":\"setCooldownSecsToUndelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_threshold\",\"type\":\"uint256\"}],\"name\":\"setMinValidatorStakingAmount\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_secs\",\"type\":\"uint256\"}],\"name\":\"setWaitingSecsToRevoke\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"}],\"name\":\"stake\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_candidateAdmin\",\"type\":\"address\"},{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"address payable\",\"name\":\"_treasuryAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_commissionRate\",\"type\":\"uint256\"}],\"name\":\"tmp_re_applyValidatorCandidate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"undelegate\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_consensusAddr\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"unstake\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"waitingSecsToRevoke\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"stateMutability\":\"payable\",\"type\":\"receive\"}],\"devdoc\":{\"errors\":{\"ErrAdminOfAnyActivePoolForbidden(address)\":[{\"details\":\"Error of admin of any active pool cannot delegate.\"}],\"ErrCannotInitTransferRON(address,string)\":[{\"details\":\"Error of cannot transfer RON to specified target.\"}],\"ErrCannotTransferRON()\":[{\"details\":\"Error of cannot transfer RON.\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrDuplicated(bytes4)\":[{\"details\":\"Error thrown when a duplicated element is detected in an array.\",\"params\":{\"msgSig\":\"The function signature that invoke the error.\"}}],\"ErrInactivePool(address)\":[{\"details\":\"Error of querying inactive pool.\"}],\"ErrInsufficientBalance(bytes4,uint256,uint256)\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInsufficientDelegatingAmount()\":[{\"details\":\"Error of undelegating insufficient amount.\"}],\"ErrInsufficientStakingAmount()\":[{\"details\":\"Error of insufficient staking amount for unstaking.\"}],\"ErrInvalidArrays()\":[{\"details\":\"Error of length of input arrays are not of the same.\"}],\"ErrInvalidCommissionRate()\":[{\"details\":\"Error of setting commission rate exceeds max allowed.\"}],\"ErrInvalidPoolShare()\":[{\"details\":\"Error of invalid pool share.\"}],\"ErrOnlyPoolAdminAllowed()\":[{\"details\":\"Error of no one is allowed to call but the pool's admin.\"}],\"ErrPoolAdminForbidden()\":[{\"details\":\"Error of pool admin is not allowed to call.\"}],\"ErrRecipientRevert(bytes4)\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrStakingAmountLeft()\":[{\"details\":\"Error of invalid staking amount left after deducted.\"}],\"ErrThreeInteractionAddrsNotEqual()\":[{\"details\":\"Error of three interaction addresses must be of the same in applying for validator candidate.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUndelegateTooEarly()\":[{\"details\":\"Error of undelegating too early.\"}],\"ErrUndelegateZeroAmount()\":[{\"details\":\"Error of undelegating zero amount.\"}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrUnstakeTooEarly()\":[{\"details\":\"Error of unstaking too early.\"}],\"ErrUnstakeZeroAmount()\":[{\"details\":\"Error of unstaking zero amount.\"}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}],\"ErrZeroValue()\":[{\"details\":\"Error of receiving zero message value.\"}]},\"kind\":\"dev\",\"methods\":{\"applyValidatorCandidate(address,address,address,uint256)\":{\"details\":\"Proposes a candidate to become a validator. Requirements: - The method caller is able to receive RON. - The treasury is able to receive RON. - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`. Emits the event `PoolApproved`.\",\"params\":{\"_candidateAdmin\":\"the candidate admin will be stored in the validator contract, used for calling function that affects to its candidate, e.g. scheduling maintenance.\"}},\"bulkUndelegate(address[],uint256[])\":{\"details\":\"Bulk unstakes from a list of candidates. Requirements: - The method caller is not the pool admin. Emits the events `Undelegated`.\"},\"claimRewards(address[])\":{\"details\":\"Claims the reward of method caller. Emits the `RewardClaimed` event.\"},\"cooldownSecsToUndelegate()\":{\"details\":\"Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\"},\"delegate(address)\":{\"details\":\"Stakes for a validator candidate `_consensusAddr`. Requirements: - The consensus address is a validator candidate. - The method caller is not the pool admin. Emits the `Delegated` event.\"},\"delegateRewards(address[],address)\":{\"details\":\"Claims the rewards and delegates them to the consensus address. Requirements: - The method caller is not the pool admin. - The consensus address `_consensusAddrDst` is a validator candidate. Emits the `RewardClaimed` event and the `Delegated` event.\"},\"execDeductStakingAmount(address,uint256)\":{\"details\":\"Deducts from staking amount of the validator `_consensusAddr` for `_amount`. Requirements: - The method caller must be validator contract. Emits the event `Unstaked`.\"},\"execDeprecatePools(address[],uint256)\":{\"details\":\"Deprecates the pool. - Deduct self-staking amount of the pool admin to zero. - Transfer the deducted amount to the pool admin. - Deactivate the pool admin address in the mapping of active pool admins Requirements: - The method caller is validator contract. Emits the event `PoolsDeprecated` and `Unstaked` events. Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\"},\"execRecordRewards(address[],uint256[],uint256)\":{\"details\":\"Records the amount of rewards `_rewards` for the pools `_consensusAddrs`. Requirements: - The method caller must be validator contract. Emits the event `PoolsUpdated` once the contract recorded the rewards successfully. Emits the event `PoolsUpdateFailed` once the input array lengths are not equal. Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period. Note: This method should be called once at the period ending.\"},\"getCommissionRateRange()\":{\"details\":\"Returns the commission rate range that the candidate can set.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"getManySelfStakings(address[])\":{\"details\":\"Returns the self-staking amounts of the pools.\"},\"getManyStakingAmounts(address[],address[])\":{\"details\":\"Returns the staking amounts of the users.\"},\"getManyStakingTotals(address[])\":{\"details\":\"Returns the total staking amounts of all users for the pools `_poolAddrs`.\"},\"getPoolAddressOf(address)\":{\"details\":\"Returns the consensus address corresponding to the pool admin.\"},\"getPoolDetail(address)\":{\"details\":\"Returns the staking pool detail.\"},\"getReward(address,address)\":{\"details\":\"Returns the reward amount that user claimable.\"},\"getRewards(address,address[])\":{\"details\":\"Returns the claimable reward of the user `_user`.\"},\"getStakingAmount(address,address)\":{\"details\":\"Returns the staking amount of an user.\"},\"getStakingTotal(address)\":{\"details\":\"Returns the total staking amount of all users for a pool.\"},\"initialize(address,uint256,uint256,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"isAdminOfActivePool(address)\":{\"details\":\"Returns whether the `_poolAdminAddr` is currently active.\"},\"minValidatorStakingAmount()\":{\"details\":\"Returns the minimum threshold for being a validator candidate.\"},\"redelegate(address,address,uint256)\":{\"details\":\"Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`. Requirements: - The method caller is not the pool admin. - The consensus address `_consensusAddrDst` is a validator candidate. Emits the `Undelegated` event and the `Delegated` event.\"},\"requestEmergencyExit(address)\":{\"details\":\"Renounces being a validator candidate and takes back the delegating/staking amount. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin.\"},\"requestRenounce(address)\":{\"details\":\"Renounces being a validator candidate and takes back the delegating/staking amount. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin.\"},\"requestUpdateCommissionRate(address,uint256,uint256)\":{\"details\":\"Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}. - The `_rate` must be in range of [0_00; 100_00]. Emits the event `CommissionRateUpdated`.\"},\"setCommissionRateRange(uint256,uint256)\":{\"details\":\"Sets the commission rate range that a candidate can set. Requirements: - The method caller is admin. Emits the `CommissionRateRangeUpdated` event.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setCooldownSecsToUndelegate(uint256)\":{\"details\":\"Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated. Requirements: - The method caller is admin. Emits the event `CooldownSecsToUndelegateUpdated`.\"},\"setMinValidatorStakingAmount(uint256)\":{\"details\":\"Sets the minimum threshold for being a validator candidate. Requirements: - The method caller is admin. Emits the `MinValidatorStakingAmountUpdated` event.\"},\"setWaitingSecsToRevoke(uint256)\":{\"details\":\"Sets the number of seconds that a candidate must wait to be revoked. Requirements: - The method caller is admin. Emits the event `WaitingSecsToRevokeUpdated`.\"},\"stake(address)\":{\"details\":\"Self-delegates to the validator candidate `_consensusAddr`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. - The `msg.value` is larger than 0. Emits the event `Staked`.\"},\"tmp_re_applyValidatorCandidate(address,address,address,uint256)\":{\"details\":\"This method only work on testnet, to hotfix the applied validator candidate that is failed. TODO: Should remove this method before deploying it on mainnet.\"},\"undelegate(address,uint256)\":{\"details\":\"Unstakes from a validator candidate `_consensusAddr` for `_amount`. Requirements: - The method caller is not the pool admin. Emits the `Undelegated` event.\"},\"unstake(address,uint256)\":{\"details\":\"Unstakes from the validator candidate `_consensusAddr` for `_amount`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. Emits the event `Unstaked`.\"},\"waitingSecsToRevoke()\":{\"details\":\"Returns the number of seconds that a candidate must wait for the renounce request gets affected.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/staking/Staking.sol\":\"Staking\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/security/ReentrancyGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Contract module that helps prevent reentrant calls to a function.\\n *\\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\\n * available, which can be applied to functions to make sure there are no nested\\n * (reentrant) calls to them.\\n *\\n * Note that because there is a single `nonReentrant` guard, functions marked as\\n * `nonReentrant` may not call one another. This can be worked around by making\\n * those functions `private`, and then adding `external` `nonReentrant` entry\\n * points to them.\\n *\\n * TIP: If you would like to learn more about reentrancy and alternative ways\\n * to protect against it, check out our blog post\\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\\n */\\nabstract contract ReentrancyGuard {\\n // Booleans are more expensive than uint256 or any type that takes up a full\\n // word because each write operation emits an extra SLOAD to first read the\\n // slot's contents, replace the bits taken up by the boolean, and then write\\n // back. This is the compiler's defense against contract upgrades and\\n // pointer aliasing, and it cannot be disabled.\\n\\n // The values being non-zero value makes deployment a bit more expensive,\\n // but in exchange the refund on every call to nonReentrant will be lower in\\n // amount. Since refunds are capped to a percentage of the total\\n // transaction's gas, it is best to keep them low in cases like this one, to\\n // increase the likelihood of the full refund coming into effect.\\n uint256 private constant _NOT_ENTERED = 1;\\n uint256 private constant _ENTERED = 2;\\n\\n uint256 private _status;\\n\\n constructor() {\\n _status = _NOT_ENTERED;\\n }\\n\\n /**\\n * @dev Prevents a contract from calling itself, directly or indirectly.\\n * Calling a `nonReentrant` function from another `nonReentrant`\\n * function is not supported. It is possible to prevent this from happening\\n * by making the `nonReentrant` function external, and making it call a\\n * `private` function that does the actual work.\\n */\\n modifier nonReentrant() {\\n // On the first call to nonReentrant, _notEntered will be true\\n require(_status != _ENTERED, \\\"ReentrancyGuard: reentrant call\\\");\\n\\n // Any calls to nonReentrant after this point will fail\\n _status = _ENTERED;\\n\\n _;\\n\\n // By storing the original value once again, a refund is triggered (see\\n // https://eips.ethereum.org/EIPS/eip-2200)\\n _status = _NOT_ENTERED;\\n }\\n}\\n\",\"keccak256\":\"0x0e9621f60b2faabe65549f7ed0f24e8853a45c1b7990d47e8160e523683f3935\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert(bytes4 msgSig);\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable recipient, uint256 amount) internal {\\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\\n }\\n\\n /**\\n * @dev Send `amount` RON to the address `recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\\n return _unsafeSendRON(recipient, amount);\\n }\\n\\n /**\\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRONLimitGas(\\n address payable recipient,\\n uint256 amount,\\n uint256 gas\\n ) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount, gas: gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xdece837caa8da00fe031b8139ada009330b8bef149af12b535913c021ab94d0e\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/extensions/consumers/GlobalConfigConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract GlobalConfigConsumer {\\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\\n /// @dev The length of a period in second.\\n uint256 public constant PERIOD_DURATION = 1 days;\\n}\\n\",\"keccak256\":\"0x96d6b1ea4c8e126a8c2468683e7513d195f8e05456d85dd8f259ab049347b527\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/interfaces/consumers/PeriodWrapperConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\ninterface PeriodWrapperConsumer {\\n struct PeriodWrapper {\\n // Inner value.\\n uint256 inner;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n}\\n\",\"keccak256\":\"0xb6777e3c364306eb8d5355583c1aca44de9d351cb40ddf1cea832206d4aad272\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IBaseStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IBaseStaking {\\n struct PoolDetail {\\n // Address of the pool i.e. consensus address of the validator\\n address addr;\\n // Pool admin address\\n address admin;\\n // Self-staking amount\\n uint256 stakingAmount;\\n // Total number of RON staking for the pool\\n uint256 stakingTotal;\\n // Mapping from delegator => delegating amount\\n mapping(address => uint256) delegatingAmount;\\n // Mapping from delegator => the last timestamp that delegator staked\\n mapping(address => uint256) lastDelegatingTimestamp;\\n }\\n\\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\\n event WaitingSecsToRevokeUpdated(uint256 secs);\\n\\n /// @dev Error of cannot transfer RON.\\n error ErrCannotTransferRON();\\n /// @dev Error of receiving zero message value.\\n error ErrZeroValue();\\n /// @dev Error of pool admin is not allowed to call.\\n error ErrPoolAdminForbidden();\\n /// @dev Error of no one is allowed to call but the pool's admin.\\n error ErrOnlyPoolAdminAllowed();\\n /// @dev Error of admin of any active pool cannot delegate.\\n error ErrAdminOfAnyActivePoolForbidden(address admin);\\n /// @dev Error of querying inactive pool.\\n error ErrInactivePool(address poolAddr);\\n /// @dev Error of length of input arrays are not of the same.\\n error ErrInvalidArrays();\\n\\n /**\\n * @dev Returns whether the `_poolAdminAddr` is currently active.\\n */\\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns the consensus address corresponding to the pool admin.\\n */\\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\\n\\n /**\\n * @dev Returns the staking pool detail.\\n */\\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\\n\\n /**\\n * @dev Returns the self-staking amounts of the pools.\\n */\\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n */\\n function cooldownSecsToUndelegate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\\n */\\n function waitingSecsToRevoke() external view returns (uint256);\\n\\n /**\\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `CooldownSecsToUndelegateUpdated`.\\n *\\n */\\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\\n\\n /**\\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `WaitingSecsToRevokeUpdated`.\\n *\\n */\\n function setWaitingSecsToRevoke(uint256 _secs) external;\\n}\\n\",\"keccak256\":\"0x90517268a0e31147d97772c9ae518caa5eb8c03efe3b369e3c6d5166422f5962\",\"license\":\"MIT\"},\"contracts/interfaces/staking/ICandidateStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface ICandidateStaking is IRewardPool {\\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\\n event MinValidatorStakingAmountUpdated(uint256 threshold);\\n /// @dev Emitted when the commission rate range is updated.\\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\\n\\n /// @dev Emitted when the pool admin staked for themself.\\n event Staked(address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\\n event Unstaked(address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Emitted when the validator pool is approved.\\n event PoolApproved(address indexed validator, address indexed admin);\\n /// @dev Emitted when the validator pool is deprecated.\\n event PoolsDeprecated(address[] validator);\\n /// @dev Emitted when the staking amount transfer failed.\\n event StakingAmountTransferFailed(\\n address indexed validator,\\n address indexed admin,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\\n event StakingAmountDeductFailed(\\n address indexed validator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Error of cannot transfer RON to specified target.\\n error ErrCannotInitTransferRON(address addr, string extraInfo);\\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\\n error ErrThreeInteractionAddrsNotEqual();\\n /// @dev Error of unstaking zero amount.\\n error ErrUnstakeZeroAmount();\\n /// @dev Error of invalid staking amount left after deducted.\\n error ErrStakingAmountLeft();\\n /// @dev Error of insufficient staking amount for unstaking.\\n error ErrInsufficientStakingAmount();\\n /// @dev Error of unstaking too early.\\n error ErrUnstakeTooEarly();\\n /// @dev Error of setting commission rate exceeds max allowed.\\n error ErrInvalidCommissionRate();\\n\\n /**\\n * @dev Returns the minimum threshold for being a validator candidate.\\n */\\n function minValidatorStakingAmount() external view returns (uint256);\\n\\n /**\\n * @dev Returns the commission rate range that the candidate can set.\\n */\\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\\n\\n /**\\n * @dev Sets the minimum threshold for being a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinValidatorStakingAmountUpdated` event.\\n *\\n */\\n function setMinValidatorStakingAmount(uint256) external;\\n\\n /**\\n * @dev Sets the commission rate range that a candidate can set.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `CommissionRateRangeUpdated` event.\\n *\\n */\\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\\n\\n /**\\n * @dev Proposes a candidate to become a validator.\\n *\\n * Requirements:\\n * - The method caller is able to receive RON.\\n * - The treasury is able to receive RON.\\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\\n *\\n * Emits the event `PoolApproved`.\\n *\\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\\n * to its candidate, e.g. scheduling maintenance.\\n *\\n */\\n function applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external payable;\\n\\n /**\\n * @dev Deprecates the pool.\\n * - Deduct self-staking amount of the pool admin to zero.\\n * - Transfer the deducted amount to the pool admin.\\n * - Deactivate the pool admin address in the mapping of active pool admins\\n *\\n * Requirements:\\n * - The method caller is validator contract.\\n *\\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\\n *\\n */\\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\\n\\n /**\\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `msg.value` is larger than 0.\\n *\\n * Emits the event `Staked`.\\n *\\n */\\n function stake(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function unstake(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdated`.\\n *\\n */\\n function requestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestRenounce(address _consensusAddr) external;\\n\\n /**\\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is the pool admin.\\n *\\n */\\n function requestEmergencyExit(address _consensusAddr) external;\\n}\\n\",\"keccak256\":\"0x9bc6ba6d13f00d9928c0add35ee6406906e16ed86207d373460930c0a75e5938\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IDelegatorStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IRewardPool.sol\\\";\\n\\ninterface IDelegatorStaking is IRewardPool {\\n /// @dev Emitted when the delegator staked for a validator candidate.\\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n /// @dev Emitted when the delegator unstaked from a validator candidate.\\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\\n\\n /// @dev Error of undelegating zero amount.\\n error ErrUndelegateZeroAmount();\\n /// @dev Error of undelegating insufficient amount.\\n error ErrInsufficientDelegatingAmount();\\n /// @dev Error of undelegating too early.\\n error ErrUndelegateTooEarly();\\n\\n /**\\n * @dev Stakes for a validator candidate `_consensusAddr`.\\n *\\n * Requirements:\\n * - The consensus address is a validator candidate.\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Delegated` event.\\n *\\n */\\n function delegate(address _consensusAddr) external payable;\\n\\n /**\\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the `Undelegated` event.\\n *\\n */\\n function undelegate(address _consensusAddr, uint256 _amount) external;\\n\\n /**\\n * @dev Bulk unstakes from a list of candidates.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n *\\n * Emits the events `Undelegated`.\\n *\\n */\\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\\n\\n /**\\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `Undelegated` event and the `Delegated` event.\\n *\\n */\\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\\n\\n /**\\n * @dev Returns the claimable reward of the user `_user`.\\n */\\n function getRewards(\\n address _user,\\n address[] calldata _poolAddrList\\n ) external view returns (uint256[] memory _rewards);\\n\\n /**\\n * @dev Claims the reward of method caller.\\n *\\n * Emits the `RewardClaimed` event.\\n *\\n */\\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\\n\\n /**\\n * @dev Claims the rewards and delegates them to the consensus address.\\n *\\n * Requirements:\\n * - The method caller is not the pool admin.\\n * - The consensus address `_consensusAddrDst` is a validator candidate.\\n *\\n * Emits the `RewardClaimed` event and the `Delegated` event.\\n *\\n */\\n function delegateRewards(\\n address[] calldata _consensusAddrList,\\n address _consensusAddrDst\\n ) external returns (uint256 _amount);\\n}\\n\",\"keccak256\":\"0x6dd71bf0c17a65da0dee49b98e4b038c1dd0e74f5473d03570421ceebd5b7084\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IRewardPool.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/consumers/PeriodWrapperConsumer.sol\\\";\\n\\ninterface IRewardPool is PeriodWrapperConsumer {\\n struct UserRewardFields {\\n // Recorded reward amount.\\n uint256 debited;\\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\\n uint256 aRps;\\n // Lowest staking amount in the period.\\n uint256 lowestAmount;\\n // Last period number that the info updated.\\n uint256 lastPeriod;\\n }\\n\\n struct PoolFields {\\n // Accumulated of the amount rewards per share (one unit staking).\\n uint256 aRps;\\n // The staking total to share reward of the current period.\\n PeriodWrapper shares;\\n }\\n\\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\\n /// @dev Emitted when the user claimed their reward\\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\\n\\n /// @dev Emitted when the pool shares are updated\\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\\n /// @dev Emitted when the pools are updated\\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\\n /// @dev Emitted when the contract fails when updating the pools\\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\\n /// @dev Emitted when the contract fails when updating the pools that already set\\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\\n\\n /// @dev Error of invalid pool share.\\n error ErrInvalidPoolShare();\\n\\n /**\\n * @dev Returns the reward amount that user claimable.\\n */\\n function getReward(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amount of an user.\\n */\\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\\n\\n /**\\n * @dev Returns the staking amounts of the users.\\n */\\n function getManyStakingAmounts(\\n address[] calldata _poolAddrs,\\n address[] calldata _userList\\n ) external view returns (uint256[] memory);\\n\\n /**\\n * @dev Returns the total staking amount of all users for a pool.\\n */\\n function getStakingTotal(address _poolAddr) external view returns (uint256);\\n\\n /**\\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\\n */\\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\\n}\\n\",\"keccak256\":\"0x52349fecb897b3b8288d8732923551382822c0c5fb8db9c6b094d080a16a2129\",\"license\":\"MIT\"},\"contracts/interfaces/staking/IStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IBaseStaking.sol\\\";\\nimport \\\"./ICandidateStaking.sol\\\";\\nimport \\\"./IDelegatorStaking.sol\\\";\\n\\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\\n /**\\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\\n *\\n * Note: This method should be called once at the period ending.\\n *\\n */\\n function execRecordRewards(\\n address[] calldata _consensusAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) external payable;\\n\\n /**\\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n *\\n * Emits the event `Unstaked`.\\n *\\n */\\n function execDeductStakingAmount(\\n address _consensusAddr,\\n uint256 _amount\\n ) external returns (uint256 _actualDeductingAmount);\\n}\\n\",\"keccak256\":\"0xd302d4a78203e277fb95a89de7ae32a3102129d3fbd64fc75f92d18be0443408\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address ______deprecatedbridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnward() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0x97dae7e2ed43c21c48200581501bfa065c7836299306ba2e7f39896c3a22ef2d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the fast finality reward is distributed.\\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\\n event FastFinalityRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x22f546add63b1b6e62929bdd4052fa032af55ebf50981dc22d208fe53ad1b0a3\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0xac0b772f2fca9dafd7cc6742f91b442f9f545bf9472185b8d817fe045b680193\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfoV2.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0x3fdfa86da33b889e5153075ffc028d6b0c607480a96b532fbbbc48ac7bbf27c9\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(\\n address _addr\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(\\n address _addr,\\n uint256 _blockNum\\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x2b1846b05ca1d636299fb929c1bd7b392b236f5e3f7aa3e7eea2c6d57b8836fb\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfoV2 {\\n /**\\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\\n */\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators() external view returns (address[] memory _validatorList);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducer() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x6823181ac93ea3320e6ebfb456624afda59ac2acb480de5c774783983c8f4749\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n DeprecatedBridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa712f0d1a323ee39f23eb3ee3278b4ec25fe2e536b1ccc629578c66f277c088d\",\"license\":\"UNLICENSED\"},\"contracts/libraries/Math.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary Math {\\n /**\\n * @dev Returns the largest of two numbers.\\n */\\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a >= b ? a : b;\\n }\\n\\n /**\\n * @dev Returns the smallest of two numbers.\\n */\\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a < b ? a : b;\\n }\\n\\n /**\\n * @dev Returns whether the number `c` is in range of [a; b].\\n */\\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\\n return a <= c && c <= b;\\n }\\n\\n /**\\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\\n */\\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\\n return x1 <= y2 && y1 <= x2;\\n }\\n\\n /**\\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\\n */\\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\\n return min(a + b, upperbound);\\n }\\n\\n /**\\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\\n */\\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\\n return a > b ? a - b : 0;\\n }\\n\\n /**\\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\\n */\\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\\n return zeroable != 0 ? a + zeroable : 0;\\n }\\n}\\n\",\"keccak256\":\"0xd73170f448c644a47024c7dbcf4afc3cc7ad27f61737c6ea4c3b543ec5cdb7e9\",\"license\":\"UNLICENSED\"},\"contracts/ronin/staking/BaseStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/security/ReentrancyGuard.sol\\\";\\nimport \\\"../../extensions/RONTransferHelper.sol\\\";\\nimport \\\"../../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../../interfaces/staking/IBaseStaking.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../../utils/DeprecatedSlots.sol\\\";\\nimport \\\"./RewardCalculation.sol\\\";\\n\\nabstract contract BaseStaking is\\n RONTransferHelper,\\n ReentrancyGuard,\\n RewardCalculation,\\n HasContracts,\\n IBaseStaking,\\n HasValidatorDeprecated\\n{\\n /// @dev Mapping from pool address => staking pool detail\\n mapping(address => PoolDetail) internal _stakingPool;\\n\\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\\n uint256 internal _cooldownSecsToUndelegate;\\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\\n uint256 internal _waitingSecsToRevoke;\\n\\n /// @dev Mapping from admin address of an active pool => consensus address.\\n mapping(address => address) internal _adminOfActivePoolMapping;\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[49] private ______gap;\\n\\n modifier noEmptyValue() {\\n _requireValue();\\n _;\\n }\\n\\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\\n _anyExceptPoolAdmin(_pool, _delegator);\\n _;\\n }\\n\\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\\n _requirePoolAdmin(_pool, _requester);\\n _;\\n }\\n\\n modifier poolIsActive(address _poolAddr) {\\n _poolIsActive(_poolAddr);\\n _;\\n }\\n\\n function _requireValue() private view {\\n if (msg.value == 0) revert ErrZeroValue();\\n }\\n\\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\\n }\\n\\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\\n }\\n\\n function _poolIsActive(address _poolAddr) private view {\\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\\n revert ErrInactivePool(_poolAddr);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\\n return _adminOfActivePoolMapping[_poolAdminAddr];\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getPoolDetail(\\n address _poolAddr\\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\\n PoolDetail storage _pool = _stakingPool[_poolAddr];\\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\\n _selfStakings = new uint256[](_pools.length);\\n for (uint _i = 0; _i < _pools.length; ) {\\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\\n return _stakingPool[_poolAddr].stakingTotal;\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getManyStakingTotals(\\n address[] calldata _poolList\\n ) public view override returns (uint256[] memory _stakingAmounts) {\\n _stakingAmounts = new uint256[](_poolList.length);\\n for (uint _i = 0; _i < _poolList.length; ) {\\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\\n return _stakingPool[_poolAddr].delegatingAmount[_user];\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getManyStakingAmounts(\\n address[] calldata _poolAddrs,\\n address[] calldata _userList\\n ) external view override returns (uint256[] memory _stakingAmounts) {\\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\\n _stakingAmounts = new uint256[](_poolAddrs.length);\\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function cooldownSecsToUndelegate() external view returns (uint256) {\\n return _cooldownSecsToUndelegate;\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function waitingSecsToRevoke() external view returns (uint256) {\\n return _waitingSecsToRevoke;\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\\n _setCooldownSecsToUndelegate(_cooldownSecs);\\n }\\n\\n /**\\n * @inheritdoc IBaseStaking\\n */\\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\\n _setWaitingSecsToRevoke(_secs);\\n }\\n\\n /**\\n * @dev Sets the minium number of seconds to undelegate.\\n *\\n * Emits the event `CooldownSecsToUndelegateUpdated`.\\n *\\n */\\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\\n _cooldownSecsToUndelegate = _cooldownSecs;\\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\\n }\\n\\n /**\\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\\n *\\n * Emits the event `WaitingSecsToRevokeUpdated`.\\n *\\n */\\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\\n _waitingSecsToRevoke = _secs;\\n emit WaitingSecsToRevokeUpdated(_secs);\\n }\\n\\n /**\\n * @dev Changes the delegate amount.\\n */\\n function _changeDelegatingAmount(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _newDelegatingAmount,\\n uint256 _newStakingTotal\\n ) internal {\\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\\n _pool.stakingTotal = _newStakingTotal;\\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\\n }\\n}\\n\",\"keccak256\":\"0xa1a3e6edfc9d8da5c851de0647c58bc86b0ec2e4a1c041f1b2a73d91b3d69b8d\",\"license\":\"MIT\"},\"contracts/ronin/staking/CandidateStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../extensions/consumers/GlobalConfigConsumer.sol\\\";\\nimport \\\"../../extensions/consumers/PercentageConsumer.sol\\\";\\nimport \\\"../../libraries/AddressArrayUtils.sol\\\";\\nimport \\\"../../interfaces/staking/ICandidateStaking.sol\\\";\\nimport \\\"./BaseStaking.sol\\\";\\n\\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\\n /// @dev The minimum threshold for being a validator candidate.\\n uint256 internal _minValidatorStakingAmount;\\n\\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\\n uint256 internal _maxCommissionRate;\\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\\n uint256 internal _minCommissionRate;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[48] ______gap;\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function minValidatorStakingAmount() public view override returns (uint256) {\\n return _minValidatorStakingAmount;\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function getCommissionRateRange() external view override returns (uint256, uint256) {\\n return (_minCommissionRate, _maxCommissionRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\\n _setMinValidatorStakingAmount(_threshold);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\\n _setCommissionRateRange(_minRate, _maxRate);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external payable override nonReentrant {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\\n\\n uint256 _amount = msg.value;\\n address payable _poolAdmin = payable(msg.sender);\\n _applyValidatorCandidate({\\n _poolAdmin: _poolAdmin,\\n _candidateAdmin: _candidateAdmin,\\n _consensusAddr: _consensusAddr,\\n _treasuryAddr: _treasuryAddr,\\n _commissionRate: _commissionRate,\\n _amount: _amount\\n });\\n\\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\\n _pool.admin = _poolAdmin;\\n _pool.addr = _consensusAddr;\\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\\n\\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\\n emit PoolApproved(_consensusAddr, _poolAdmin);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveDaysOnwards,\\n uint256 _commissionRate\\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\\n _consensusAddr,\\n _effectiveDaysOnwards,\\n _commissionRate\\n );\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function execDeprecatePools(\\n address[] calldata _pools,\\n uint256 _newPeriod\\n ) external override onlyContract(ContractType.VALIDATOR) {\\n if (_pools.length == 0) {\\n return;\\n }\\n\\n for (uint _i = 0; _i < _pools.length; ) {\\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\\n // Deactivate the pool admin in the active mapping.\\n delete _adminOfActivePoolMapping[_pool.admin];\\n\\n // Deduct and transfer the self staking amount to the pool admin.\\n uint256 _deductingAmount = _pool.stakingAmount;\\n if (_deductingAmount > 0) {\\n _deductStakingAmount(_pool, _deductingAmount);\\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\\n }\\n }\\n\\n // Settle the unclaimed reward and transfer to the pool admin.\\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\\n if (_lastRewardAmount > 0) {\\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\\n }\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n emit PoolsDeprecated(_pools);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function unstake(\\n address _consensusAddr,\\n uint256 _amount\\n ) external override nonReentrant poolIsActive(_consensusAddr) {\\n if (_amount == 0) revert ErrUnstakeZeroAmount();\\n address _requester = msg.sender;\\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\\n uint256 _remainAmount = _pool.stakingAmount - _amount;\\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\\n\\n _unstake(_pool, _requester, _amount);\\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestRenounce(\\n address _consensusAddr\\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\\n _consensusAddr,\\n _waitingSecsToRevoke\\n );\\n }\\n\\n /**\\n * @inheritdoc ICandidateStaking\\n */\\n function requestEmergencyExit(\\n address _consensusAddr\\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-applyValidatorCandidate`\\n */\\n function _applyValidatorCandidate(\\n address payable _poolAdmin,\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate,\\n uint256 _amount\\n ) internal {\\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\\n revert ErrCannotInitTransferRON(_poolAdmin, \\\"pool admin\\\");\\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\\n revert ErrCannotInitTransferRON(_treasuryAddr, \\\"treasury\\\");\\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\\n\\n {\\n address[] memory _diffAddrs = new address[](2);\\n _diffAddrs[0] = _poolAdmin;\\n _diffAddrs[1] = _consensusAddr;\\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\\n _candidateAdmin,\\n _consensusAddr,\\n _treasuryAddr,\\n _commissionRate\\n );\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-stake`\\n */\\n function _stake(\\n PoolDetail storage _pool,\\n address _requester,\\n uint256 _amount\\n ) internal onlyPoolAdmin(_pool, _requester) {\\n _pool.stakingAmount += _amount;\\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\\n emit Staked(_pool.addr, _amount);\\n }\\n\\n /**\\n * @dev See `ICandidateStaking-unstake`\\n */\\n function _unstake(\\n PoolDetail storage _pool,\\n address _requester,\\n uint256 _amount\\n ) internal onlyPoolAdmin(_pool, _requester) {\\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\\n revert ErrUnstakeTooEarly();\\n }\\n\\n _pool.stakingAmount -= _amount;\\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\\n emit Unstaked(_pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\\n *\\n * Emits the event `Unstaked`.\\n *\\n * @return The actual deducted amount\\n */\\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\\n\\n /**\\n * @dev Sets the minimum threshold for being a validator candidate.\\n *\\n * Emits the `MinValidatorStakingAmountUpdated` event.\\n *\\n */\\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\\n _minValidatorStakingAmount = _threshold;\\n emit MinValidatorStakingAmountUpdated(_threshold);\\n }\\n\\n /**\\n * @dev Sets the max commission rate that a candidate can set.\\n *\\n * Emits the `MaxCommissionRateUpdated` event.\\n *\\n */\\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\\n _maxCommissionRate = _maxRate;\\n _minCommissionRate = _minRate;\\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\\n }\\n}\\n\",\"keccak256\":\"0x4859f479e8659e7c1005ae9dad4e5efc80869e8a87ee0794e90de7bffdde7a2b\",\"license\":\"MIT\"},\"contracts/ronin/staking/DelegatorStaking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/staking/IDelegatorStaking.sol\\\";\\nimport \\\"./BaseStaking.sol\\\";\\n\\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\\n address payable _delegator = payable(msg.sender);\\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\\n\\n address payable _delegator = payable(msg.sender);\\n uint256 _total;\\n\\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\\n _total += _amounts[_i];\\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n\\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function redelegate(\\n address _consensusAddrSrc,\\n address _consensusAddrDst,\\n uint256 _amount\\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\\n address _delegator = msg.sender;\\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function claimRewards(\\n address[] calldata _consensusAddrList\\n ) external override nonReentrant returns (uint256 _amount) {\\n _amount = _claimRewards(msg.sender, _consensusAddrList);\\n _transferRON(payable(msg.sender), _amount);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function delegateRewards(\\n address[] calldata _consensusAddrList,\\n address _consensusAddrDst\\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\\n }\\n\\n /**\\n * @inheritdoc IDelegatorStaking\\n */\\n function getRewards(\\n address _user,\\n address[] calldata _poolAddrList\\n ) external view returns (uint256[] memory _rewards) {\\n address _consensusAddr;\\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n _rewards = new uint256[](_poolAddrList.length);\\n\\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\\n _consensusAddr = _poolAddrList[_i];\\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Delegates from a validator address.\\n *\\n * Requirements:\\n * - The delegator is not the pool admin.\\n *\\n * Emits the `Delegated` event.\\n *\\n * Note: This function does not verify the `msg.value` with the amount.\\n *\\n */\\n function _delegate(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _amount\\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\\n _changeDelegatingAmount(\\n _pool,\\n _delegator,\\n _pool.delegatingAmount[_delegator] + _amount,\\n _pool.stakingTotal + _amount\\n );\\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\\n emit Delegated(_delegator, _pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Undelegates from a validator address.\\n *\\n * Requirements:\\n * - The delegator is not the pool admin.\\n * - The amount is larger than 0.\\n * - The delegating amount is larger than or equal to the undelegating amount.\\n *\\n * Emits the `Undelegated` event.\\n *\\n * Note: Consider transferring back the amount of RON after calling this function.\\n *\\n */\\n function _undelegate(\\n PoolDetail storage _pool,\\n address _delegator,\\n uint256 _amount\\n ) private anyExceptPoolAdmin(_pool, _delegator) {\\n if (_amount == 0) revert ErrUndelegateZeroAmount();\\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\\n\\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\\n if (\\n _validatorContract.isValidatorCandidate(_pool.addr) &&\\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\\n ) revert ErrUndelegateTooEarly();\\n\\n _changeDelegatingAmount(\\n _pool,\\n _delegator,\\n _pool.delegatingAmount[_delegator] - _amount,\\n _pool.stakingTotal - _amount\\n );\\n emit Undelegated(_delegator, _pool.addr, _amount);\\n }\\n\\n /**\\n * @dev Claims rewards from the pools `_poolAddrList`.\\n * Note: This function does not transfer reward to user.\\n */\\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\\n uint256 _period = _currentPeriod();\\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\\n\\n unchecked {\\n ++_i;\\n }\\n }\\n }\\n\\n /**\\n * @dev Claims the rewards and delegates them to the consensus address.\\n */\\n function _delegateRewards(\\n address _user,\\n address[] calldata _poolAddrList,\\n address _poolAddrDst\\n ) internal returns (uint256 _amount) {\\n _amount = _claimRewards(_user, _poolAddrList);\\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\\n }\\n}\\n\",\"keccak256\":\"0x26d154ed736d57c1ecc6be99ac33274640039975374584bd4a12b8f53b68cb5e\",\"license\":\"MIT\"},\"contracts/ronin/staking/RewardCalculation.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../interfaces/staking/IRewardPool.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\n\\n/**\\n * @title RewardCalculation contract\\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\\n */\\nabstract contract RewardCalculation is IRewardPool {\\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\\n /// @dev Mapping from the pool address => user address => the reward info of the user\\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\\n /// @dev Mapping from the pool address => reward pool fields\\n mapping(address => PoolFields) private _stakingPool;\\n\\n /**\\n * @dev This empty reserved space is put in place to allow future versions to add new\\n * variables without shifting down storage in the inheritance chain.\\n */\\n uint256[50] private ______gap;\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\\n }\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\\n\\n /**\\n * @inheritdoc IRewardPool\\n */\\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\\n\\n /**\\n * @dev Returns the reward amount that user claimable.\\n */\\n function _getReward(\\n address _poolAddr,\\n address _user,\\n uint256 _latestPeriod,\\n uint256 _latestStakingAmount\\n ) internal view returns (uint256) {\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n\\n if (_reward.lastPeriod == _latestPeriod) {\\n return _reward.debited;\\n }\\n\\n uint256 _aRps;\\n uint256 _lastPeriodReward;\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\\n\\n if (_wrappedArps.lastPeriod > 0) {\\n // Calculates the last period reward if the aRps at the period is set\\n _aRps = _wrappedArps.inner;\\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\\n } else {\\n // Fallbacks to the previous aRps in case the aRps is not set\\n _aRps = _reward.aRps;\\n }\\n\\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\\n }\\n\\n /**\\n * @dev Syncs the user reward.\\n *\\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\\n *\\n * Note: The method should be called whenever the user's staking amount changes.\\n *\\n */\\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\\n uint256 _period = _currentPeriod();\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n uint256 _lastShares = _pool.shares.inner;\\n\\n // Updates the pool shares if it is outdated\\n if (_pool.shares.lastPeriod < _period) {\\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\\n }\\n\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\\n\\n if (_reward.debited != _debited) {\\n _reward.debited = _debited;\\n emit UserRewardUpdated(_poolAddr, _user, _debited);\\n }\\n\\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\\n _reward.aRps = _pool.aRps;\\n _reward.lastPeriod = _period;\\n\\n if (_pool.shares.inner != _lastShares) {\\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\\n }\\n }\\n\\n /**\\n * @dev Syncs the minimum staking amount of an user in the current period.\\n */\\n function _syncMinStakingAmount(\\n PoolFields storage _pool,\\n UserRewardFields storage _reward,\\n uint256 _latestPeriod,\\n uint256 _newStakingAmount,\\n uint256 _currentStakingAmount\\n ) internal {\\n if (_reward.lastPeriod < _latestPeriod) {\\n _reward.lowestAmount = _currentStakingAmount;\\n }\\n\\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\\n if (_diffAmount > 0) {\\n _reward.lowestAmount = _lowestAmount;\\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\\n _pool.shares.inner -= _diffAmount;\\n }\\n }\\n\\n /**\\n * @dev Claims the settled reward for a specific user.\\n *\\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\\n *\\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\\n *\\n * Note: This method should be called before transferring rewards for the user.\\n *\\n */\\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\\n emit RewardClaimed(_poolAddr, _user, _amount);\\n\\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\\n _reward.debited = 0;\\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\\n _reward.lastPeriod = _lastPeriod;\\n _reward.aRps = _stakingPool[_poolAddr].aRps;\\n emit UserRewardUpdated(_poolAddr, _user, 0);\\n }\\n\\n /**\\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\\n *\\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\\n *\\n * Note: This method should be called once at the period ending.\\n *\\n */\\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\\n if (_poolAddrs.length != _rewards.length) {\\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\\n return;\\n }\\n\\n uint256 _rps;\\n uint256 _count;\\n address _poolAddr;\\n uint256 _stakingTotal;\\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\\n address[] memory _conflicted = new address[](_poolAddrs.length);\\n\\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\\n _poolAddr = _poolAddrs[_i];\\n PoolFields storage _pool = _stakingPool[_poolAddr];\\n _stakingTotal = getStakingTotal(_poolAddr);\\n\\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\\n unchecked {\\n _conflicted[_count++] = _poolAddr;\\n }\\n continue;\\n }\\n\\n // Updates the pool shares if it is outdated\\n if (_pool.shares.lastPeriod < _period) {\\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\\n }\\n\\n // The rps is 0 if no one stakes for the pool\\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\\n _aRps[_i - _count] = _pool.aRps += _rps;\\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\\n _pool.shares.inner = _stakingTotal;\\n _shares[_i - _count] = _pool.shares.inner;\\n _poolAddrs[_i - _count] = _poolAddr;\\n }\\n\\n if (_count > 0) {\\n assembly {\\n mstore(_conflicted, _count)\\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\\n }\\n emit PoolsUpdateConflicted(_period, _conflicted);\\n }\\n\\n if (_poolAddrs.length > 0) {\\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\\n }\\n }\\n\\n /**\\n * @dev Returns the current period.\\n */\\n function _currentPeriod() internal view virtual returns (uint256);\\n}\\n\",\"keccak256\":\"0x98f330685911b18730cf85223ecf30f4da2ec19dda5608b5d82c6b5e4f222fa1\",\"license\":\"MIT\"},\"contracts/ronin/staking/Staking.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../../libraries/Math.sol\\\";\\nimport \\\"../../interfaces/staking/IStaking.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\nimport \\\"./CandidateStaking.sol\\\";\\nimport \\\"./DelegatorStaking.sol\\\";\\n\\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\\n constructor() {\\n _disableInitializers();\\n }\\n\\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\\n\\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 __minValidatorStakingAmount,\\n uint256 __maxCommissionRate,\\n uint256 __cooldownSecsToUndelegate,\\n uint256 __waitingSecsToRevoke\\n ) external initializer {\\n _setContract(ContractType.VALIDATOR, __validatorContract);\\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\\n _setCommissionRateRange(0, __maxCommissionRate);\\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\\n }\\n\\n function initializeV2() external reinitializer(2) {\\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\\n delete ______deprecatedValidator;\\n }\\n\\n /**\\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\\n * TODO: Should remove this method before deploying it on mainnet.\\n */\\n function tmp_re_applyValidatorCandidate(\\n address _candidateAdmin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n uint256 _commissionRate\\n ) external {\\n require(block.chainid == 2021, \\\"E1\\\");\\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \\\"E2\\\");\\n\\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\\n _candidateAdmin,\\n _consensusAddr,\\n _treasuryAddr,\\n _commissionRate\\n );\\n }\\n\\n /**\\n * @inheritdoc IStaking\\n */\\n function execRecordRewards(\\n address[] calldata _consensusAddrs,\\n uint256[] calldata _rewards,\\n uint256 _period\\n ) external payable override onlyContract(ContractType.VALIDATOR) {\\n _recordRewards(_consensusAddrs, _rewards, _period);\\n }\\n\\n /**\\n * @inheritdoc IStaking\\n */\\n function execDeductStakingAmount(\\n address _consensusAddr,\\n uint256 _amount\\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\\n address payable _validatorContractAddr = payable(msg.sender);\\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\\n emit StakingAmountDeductFailed(\\n _consensusAddr,\\n _validatorContractAddr,\\n _actualDeductingAmount,\\n address(this).balance\\n );\\n }\\n }\\n\\n /**\\n * @inheritdoc RewardCalculation\\n */\\n function _currentPeriod() internal view virtual override returns (uint256) {\\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\\n }\\n\\n /**\\n * @inheritdoc CandidateStaking\\n */\\n function _deductStakingAmount(\\n PoolDetail storage _pool,\\n uint256 _amount\\n ) internal override returns (uint256 _actualDeductingAmount) {\\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\\n\\n _pool.stakingAmount -= _actualDeductingAmount;\\n _changeDelegatingAmount(\\n _pool,\\n _pool.admin,\\n _pool.stakingAmount,\\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\\n );\\n emit Unstaked(_pool.addr, _actualDeductingAmount);\\n }\\n}\\n\",\"keccak256\":\"0x096cf6e78eba085c42b96318b9e882d469583c8e205e631855cec3b83000180a\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/DeprecatedSlots.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\n/**\\n * @title Deprecated Contracts\\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\\n * They provide functionality related to various aspects of a smart contract but have been marked\\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\\n */\\ncontract HasSlashIndicatorDeprecated {\\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\\n address internal ______deprecatedSlashIndicator;\\n}\\n\\ncontract HasStakingVestingDeprecated {\\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\\n address internal ______deprecatedStakingVesting;\\n}\\n\\ncontract HasBridgeDeprecated {\\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\\n address internal ______deprecatedBridge;\\n}\\n\\ncontract HasValidatorDeprecated {\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address internal ______deprecatedValidator;\\n}\\n\\ncontract HasStakingDeprecated {\\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\\n address internal ______deprecatedStakingContract;\\n}\\n\\ncontract HasMaintenanceDeprecated {\\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\\n address internal ______deprecatedMaintenance;\\n}\\n\\ncontract HasTrustedOrgDeprecated {\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address internal ______deprecatedTrustedOrg;\\n}\\n\\ncontract HasGovernanceAdminDeprecated {\\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\\n address internal ______deprecatedGovernanceAdmin;\\n}\\n\\ncontract HasBridgeTrackingDeprecated {\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address internal ______deprecatedBridgeTracking;\\n}\\n\",\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x60806040523480156200001157600080fd5b5060016000556200002162000027565b620000e9565b60d154610100900460ff1615620000945760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60d15460ff9081161015620000e75760d1805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b6139b880620000f96000396000f3fe60806040526004361061023f5760003560e01c80636bd8f8041161012e578063aa15a6fd116100ab578063d01b8eed1161006f578063d01b8eed146106e6578063de981f1b14610757578063e22d1c9d14610777578063f92ad21914610797578063f9f031df146107b757610251565b8063aa15a6fd1461062d578063acd79c461461064d578063af24542914610660578063c2a672e014610675578063c50870031461069557610251565b8063909791dd116100f2578063909791dd1461059857806391f8723f146105ad578063924f081e146105cd5780639488e4e9146105ed578063969ffc141461060d57610251565b80636bd8f804146104df57806376664b65146104ff578063865e6fd31461051f578063888b9ae91461053f578063895ab7421461055f57610251565b806342e0c408116101bc5780635c19a95c116101805780635c19a95c146104605780635cd8a76b146104735780636558954f14610488578063679a6e431461049f5780636b091695146104bf57610251565b806342e0c4081461038d57806342ef3c34146103d85780634530d202146103f85780634d99dd1614610420578063574734471461044057610251565b80631658c86e116102035780631658c86e1461030757806326476204146103275780632715805e1461033a5780632baae1251461035a5780633d8e846e1461036d57610251565b8063038278841461025c5780630682e8fa14610285578063095f64751461029a578063097e4a9d146102c75780630dccaf46146102e757610251565b3661025157600861024f816107d7565b005b600861024f816107d7565b34801561026857600080fd5b506102726104b081565b6040519081526020015b60405180910390f35b34801561029157600080fd5b50603854610272565b3480156102a657600080fd5b506102ba6102b5366004613102565b61082f565b60405161027c91906131a8565b3480156102d357600080fd5b506102726102e23660046131d0565b610967565b3480156102f357600080fd5b5061024f610302366004613226565b6109ed565b34801561031357600080fd5b5061024f610322366004613277565b610af0565b61024f610335366004613277565b610b60565b34801561034657600080fd5b5061027261035536600461329b565b610b99565b61024f610368366004613226565b610c2a565b34801561037957600080fd5b506102ba6103883660046132c7565b610d78565b34801561039957600080fd5b506103c86103a8366004613277565b6001600160a01b039081166000908152603a602052604090205416151590565b604051901515815260200161027c565b3480156103e457600080fd5b506102ba6103f336600461331b565b610ea6565b34801561040457600080fd5b50606e54606d546040805192835260208301919091520161027c565b34801561042c57600080fd5b5061024f61043b36600461329b565b610f72565b34801561044c57600080fd5b5061024f61045b36600461335c565b610fee565b61024f61046e366004613277565b611000565b34801561047f57600080fd5b5061024f61106e565b34801561049457600080fd5b506102726201518081565b3480156104ab57600080fd5b5061024f6104ba36600461337e565b61112d565b3480156104cb57600080fd5b506102726104da366004613397565b61113e565b3480156104eb57600080fd5b5061024f6104fa3660046133d0565b611160565b34801561050b57600080fd5b5061027261051a366004613397565b6111e5565b34801561052b57600080fd5b5061024f61053a366004613420565b611214565b34801561054b57600080fd5b5061024f61055a36600461337e565b61122f565b34801561056b57600080fd5b5061027261057a366004613277565b6001600160a01b031660009081526037602052604090206003015490565b3480156105a457600080fd5b50606c54610272565b3480156105b957600080fd5b506102ba6105c836600461331b565b611240565b3480156105d957600080fd5b5061024f6105e836600461343c565b6112e0565b3480156105f957600080fd5b5061024f610608366004613102565b6113ba565b34801561061957600080fd5b5061024f61062836600461337e565b6114e9565b34801561063957600080fd5b5061024f610648366004613277565b6114fa565b61024f61065b366004613471565b61156a565b34801561066c57600080fd5b50603954610272565b34801561068157600080fd5b5061024f61069036600461329b565b6115be565b3480156106a157600080fd5b506106ce6106b0366004613277565b6001600160a01b039081166000908152603a60205260409020541690565b6040516001600160a01b03909116815260200161027c565b3480156106f257600080fd5b50610732610701366004613277565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604080516001600160a01b03909416845260208401929092529082015260600161027c565b34801561076357600080fd5b506106ce6107723660046134e4565b611678565b34801561078357600080fd5b5061024f6107923660046134ff565b6116f3565b3480156107a357600080fd5b5061024f6107b236600461354a565b6118b7565b3480156107c357600080fd5b506102726107d236600461331b565b6119ae565b6107e081611678565b6001600160a01b0316336001600160a01b03161461082c576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610823939291906135b8565b60405180910390fd5b50565b6060838214610851576040516376081a7b60e11b815260040160405180910390fd5b836001600160401b03811115610869576108696135ef565b604051908082528060200260200182016040528015610892578160200160208202803683370190505b50905060005b815181101561095e57603760008787848181106108b7576108b7613605565b90506020020160208101906108cc9190613277565b6001600160a01b03166001600160a01b03168152602001908152602001600020600401600085858481811061090357610903613605565b90506020020160208101906109189190613277565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061094b5761094b613605565b6020908102919091010152600101610898565b50949350505050565b600060026000540361098b5760405162461bcd60e51b81526004016108239061361b565b60026000558161099a81611a2e565b336000908152603a60205260409020546001600160a01b0316156109d357604051632fc6bfb160e21b8152336004820152602401610823565b6109df33868686611acc565b600160005595945050505050565b466107e514610a235760405162461bcd60e51b8152602060048201526002602482015261453160f01b6044820152606401610823565b7357832a94810e18c84a5a5e2c4dd67d012ade574f3314610a6b5760405162461bcd60e51b8152602060048201526002602482015261229960f11b6044820152606401610823565b610a756008611678565b60405163f883afaf60e01b81526001600160a01b0386811660048301528581166024830152848116604483015260648201849052919091169063f883afaf906084015b600060405180830381600087803b158015610ad257600080fd5b505af1158015610ae6573d6000803e3d6000fd5b5050505050505050565b80610afa81611a2e565b6001600160a01b038216600090815260376020526040902033610b1d8282611b39565b610b276008611678565b60395460405163dd716ad360e01b81526001600160a01b038781166004830152602482019290925291169063dd716ad390604401610ab8565b610b68611b69565b80610b7281611a2e565b6001600160a01b0382166000908152603760205260409020610b95903334611b8c565b5050565b60006008610ba6816107d7565b6001600160a01b0384166000908152603760205260409020610bc89084611c37565b915033610bd58184611cd4565b610c2257604080518481524760208201526001600160a01b0380841692908816917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b505092915050565b600260005403610c4c5760405162461bcd60e51b81526004016108239061361b565b60026000908155338152603a60205260409020546001600160a01b031615610c8957604051632fc6bfb160e21b8152336004820152602401610823565b606d54811180610c9a5750606e5481105b15610cb857604051631b8454a360e21b815260040160405180910390fd5b3433610cc8818787878787611d30565b6001600160a01b0380861660008181526037602081815260408084206001810180549789166001600160a01b0319988916811790915581548816871782558552603a835290842080549096168517909555929091529052610d2a818385611b8c565b816001600160a01b0316866001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a3505060016000555050505050565b6060600080610d876008611678565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610dc4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de89190613652565b9050836001600160401b03811115610e0257610e026135ef565b604051908082528060200260200182016040528015610e2b578160200160208202803683370190505b50925060005b84811015610e9c57858582818110610e4b57610e4b613605565b9050602002016020810190610e609190613277565b9250610e77838884610e72878c6111e5565b611f64565b848281518110610e8957610e89613605565b6020908102919091010152600101610e31565b5050509392505050565b6060816001600160401b03811115610ec057610ec06135ef565b604051908082528060200260200182016040528015610ee9578160200160208202803683370190505b50905060005b82811015610f6b5760376000858584818110610f0d57610f0d613605565b9050602002016020810190610f229190613277565b6001600160a01b03166001600160a01b0316815260200190815260200160002060020154828281518110610f5857610f58613605565b6020908102919091010152600101610eef565b5092915050565b600260005403610f945760405162461bcd60e51b81526004016108239061361b565b600260009081556001600160a01b03831681526037602052604090203390610fbd908284612060565b610fc78183612298565b610fe457604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b610ff66122e0565b610b95828261233a565b611008611b69565b8061101281611a2e565b336000908152603a60205260409020546001600160a01b03161561104b57604051632fc6bfb160e21b8152336004820152602401610823565b6001600160a01b0382166000908152603760205260409020610b959033346123ae565b60d154600290610100900460ff16158015611090575060d15460ff8083169116105b6110ac5760405162461bcd60e51b81526004016108239061366b565b60d1805461ffff191660ff8316176101001790556036546110d8906008906001600160a01b031661245d565b603680546001600160a01b031916905560d1805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6111356122e0565b61082c81612501565b6000611157838361114d612536565b610e7287876111e5565b90505b92915050565b6002600054036111825760405162461bcd60e51b81526004016108239061361b565b60026000558161119181611a2e565b6001600160a01b038416600090815260376020526040902033906111b6908285612060565b6001600160a01b03841660009081526037602052604090206111d99082856123ae565b50506001600055505050565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b61121c6122e0565b611225816125a8565b610b95828261245d565b6112376122e0565b61082c816125de565b6060816001600160401b0381111561125a5761125a6135ef565b604051908082528060200260200182016040528015611283578160200160208202803683370190505b50905060005b82811015610f6b576112bb8484838181106112a6576112a6613605565b905060200201602081019061057a9190613277565b8282815181106112cd576112cd613605565b6020908102919091010152600101611289565b826112ea81611a2e565b6001600160a01b03841660009081526037602052604090203361130d8282611b39565b606d5484118061131e5750606e5484105b1561133c57604051631b8454a360e21b815260040160405180910390fd5b6113466008611678565b60405163e5125a1d60e01b81526001600160a01b0388811660048301526024820188905260448201879052919091169063e5125a1d906064015b600060405180830381600087803b15801561139a57600080fd5b505af11580156113ae573d6000803e3d6000fd5b50505050505050505050565b6002600054036113dc5760405162461bcd60e51b81526004016108239061361b565b60026000558215806113ee5750828114155b1561140c576040516376081a7b60e11b815260040160405180910390fd5b336000805b858110156114b45784848281811061142b5761142b613605565b905060200201358261143d91906136cf565b91506114ac6037600089898581811061145857611458613605565b905060200201602081019061146d9190613277565b6001600160a01b03166001600160a01b03168152602001908152602001600020848787858181106114a0576114a0613605565b90506020020135612060565b600101611411565b506114bf8282612298565b6114dc57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b6114f16122e0565b61082c81612613565b8061150481611a2e565b6001600160a01b0382166000908152603760205260409020336115278282611b39565b6115316008611678565b60395460405163a7c2f11960e01b81526001600160a01b038781166004830152602482019290925291169063a7c2f11990604401610ab8565b6008611575816107d7565b6115b6868680806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250889250879150869050612648565b505050505050565b6002600054036115e05760405162461bcd60e51b81526004016108239061361b565b6002600055816115ef81611a2e565b81600003611610576040516331d9f7d760e01b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061163b9086906136e2565b9050606c548110156116605760405163ef0a995760e01b815260040160405180910390fd5b61166b828487612a76565b6114bf83866104b0612b62565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156116af576116af61358e565b60ff1681526020810191909152604001600020546001600160a01b03169050806116ee578160405163409140df60e11b815260040161082391906136f5565b919050565b60086116fe816107d7565b82156118b15760005b838110156118765760006037600087878581811061172757611727613605565b905060200201602081019061173c9190613277565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a909352912080546001600160a01b031916905560028101549091508015611803576117938282611c37565b5060018201546117af906001600160a01b0316826104b0612b62565b6118035760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b600061184388888681811061181a5761181a613605565b905060200201602081019061182f9190613277565b60018501546001600160a01b031688612bc2565b90508015611868576001830154611866906001600160a01b0316826104b0612b62565b505b836001019350505050611707565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d884846040516118a8929190613703565b60405180910390a15b50505050565b60d154610100900460ff16158080156118d7575060d154600160ff909116105b806118f15750303b1580156118f1575060d15460ff166001145b61190d5760405162461bcd60e51b81526004016108239061366b565b60d1805460ff1916600117905580156119305760d1805461ff0019166101001790555b61193b60088761245d565b61194485612501565b61194f60008561233a565b611958836125de565b61196182612613565b80156115b65760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a1505050505050565b60006002600054036119d25760405162461bcd60e51b81526004016108239061361b565b6002600081905550611a1733848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612cd492505050565b9050611a233382612d25565b600160005592915050565b611a386008611678565b604051635061f96960e11b81526001600160a01b038381166004830152919091169063a0c3f2d290602401602060405180830381865afa158015611a80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611aa49190613751565b61082c57604051630fd0c64560e11b81526001600160a01b0382166004820152602401610823565b6000611b0b85858580806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612cd492505050565b6001600160a01b0383166000908152603760205260409020909150611b319086836123ae565b949350505050565b60018201546001600160a01b03828116911614610b9557604051637bc65bd760e11b815260040160405180910390fd5b34600003611b8a57604051636dfcbde560e11b815260040160405180910390fd5b565b8282611b988282611b39565b82856002016000828254611bac91906136cf565b92505081905550611bd285858760020154868960030154611bcd91906136cf565b612d5a565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d90611c289086815260200190565b60405180910390a25050505050565b6000611c47836002015483612d95565b905080836002016000828254611c5d91906136e2565b9091555050600183015460028401546003850154611c8d9286926001600160a01b0390911691611bcd9086612dab565b82546040518281526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f759060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611d21576040519150601f19603f3d011682016040523d82523d6000602084013e611d26565b606091505b5090949350505050565b611d3e8660006104b0612b62565b611d89576040805163338f030160e01b81526001600160a01b03881660048201526024810191909152600a6044820152693837b7b61030b236b4b760b11b6064820152608401610823565b611d978360006104b0612b62565b611de0576040805163338f030160e01b81526001600160a01b038516600482015260248101919091526008604482015267747265617375727960c01b6064820152608401610823565b606c54811015611e0357604051630a8d7fa760e21b815260040160405180910390fd5b846001600160a01b0316866001600160a01b0316141580611e365750826001600160a01b0316856001600160a01b031614155b15611e545760405163dc1d04ff60e01b815260040160405180910390fd5b6040805160028082526060820183526000926020830190803683370190505090508681600081518110611e8957611e89613605565b60200260200101906001600160a01b031690816001600160a01b0316815250508481600181518110611ebd57611ebd613605565b60200260200101906001600160a01b031690816001600160a01b031681525050611ee681612dc5565b15611f1257604051630d697db160e11b81526001600160e01b0319600035166004820152602401610823565b50611f1d6008611678565b60405163f883afaf60e01b81526001600160a01b0387811660048301528681166024830152858116604483015260648201859052919091169063f883afaf90608401611380565b6001600160a01b03808516600090815260026020908152604080832093871683529290529081206003810154849003611f9f57549050611b31565b6001600160a01b0386166000908152600360208181526040808420600180845282862094870154865293909252832091820154839290156120045780546001860154909450611fee90856136e2565b8560020154611ffd9190613773565b925061200c565b846001015493505b815460009061201c9086906136e2565b6120269089613773565b9050670de0b6b3a764000061203b82866136cf565b612045919061378a565b865461205191906136cf565b9b9a5050505050505050505050565b828261206c8282612e64565b8260000361208d57604051637ab0c6ad60e11b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020548311156120c857604051630695534560e31b815260040160405180910390fd5b60006120d46008611678565b8654604051635061f96960e11b81526001600160a01b03918216600482015291925082169063a0c3f2d290602401602060405180830381865afa15801561211f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121439190613751565b80156121bd575085546040516328bde1e160e01b81526001600160a01b039182166004820152908216906328bde1e19060240160e060405180830381865afa158015612193573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121b791906137b7565b60a00151155b80156121f057506038546001600160a01b038616600090815260058801602052604090205442916121ed916136cf565b10155b1561220e5760405163f19f52bd60e01b815260040160405180910390fd5b6001600160a01b038516600090815260048701602052604090205461224c908790879061223c9088906136e2565b878a60030154611bcd91906136e2565b85546040518581526001600160a01b03918216918716907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c9060200160405180910390a3505050505050565b6000814710156122d6576040516302631c4f60e61b81526001600160e01b031960003516600482015247602482015260448101839052606401610823565b6111578383611cd4565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611b8a576000356001600160e01b0319166001604051620f948f60ea1b8152600401610823929190613862565b61271081118061234957508082115b1561236757604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b82826123ba8282612e64565b6001600160a01b03841660009081526004860160205260409020546123f890869086906123e89087906136cf565b868960030154611bcd91906136cf565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b9061244e9087815260200190565b60405180910390a35050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156124935761249361358e565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156124d4576124d461358e565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be290602001611122565b60006125426008611678565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561257f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125a39190613652565b905090565b806001600160a01b03163b60000361082c57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610823565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a90602001611122565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c67890602001611122565b8351821461269157807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a5858585604051612684939291906138c9565b60405180910390a26118b1565b600080600080600088516001600160401b038111156126b2576126b26135ef565b6040519080825280602002602001820160405280156126db578160200160208202803683370190505b509050600089516001600160401b038111156126f9576126f96135ef565b604051908082528060200260200182016040528015612722578160200160208202803683370190505b50905060008a516001600160401b03811115612740576127406135ef565b604051908082528060200260200182016040528015612769578160200160208202803683370190505b50905060005b8b518110156129dc578b818151811061278a5761278a613605565b6020908102919091018101516001600160a01b038116600090815260038084526040808320603790955290912001549097506001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a900361282b57868389806001019a508151811061280557612805613605565b60200260200101906001600160a01b031690816001600160a01b031681525050506129ca565b60028101548a111561285957604080518082019091528681526020018a905260018101869055600281018a90555b6001810154156128a35760018101548c8c8481811061287a5761287a613605565b90506020020135670de0b6b3a76400006128949190613773565b61289e919061378a565b6128a6565b60005b9850888160000160008282546128bc91906136cf565b91829055509050856128ce8a856136e2565b815181106128de576128de613605565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c81526020019081526020016000206000820151816000015560208201518160010155905050858160010160000181905550806001016000015484898461297191906136e2565b8151811061298157612981613605565b6020908102919091010152868d6129988a856136e2565b815181106129a8576129a8613605565b60200260200101906001600160a01b031690816001600160a01b031681525050505b806129d481613913565b91505061276f565b508515612a2557858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a382604051612a1c919061392c565b60405180910390a25b8a5115612a6957877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c8585604051612a609392919061393f565b60405180910390a25b5050505050505050505050565b8282612a828282611b39565b8460020154831115612aa757604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b03851660009081526005870160205260409020544291612ad0916136cf565b1115612aef576040516303db082960e11b815260040160405180910390fd5b82856002016000828254612b0391906136e2565b92505081905550612b2485858760020154868960030154611bcd91906136e2565b84546040518481526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f7590602001611c28565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114612bb2576040519150601f19603f3d011682016040523d82523d6000602084013e612bb7565b606091505b509095945050505050565b600080612bcf85856111e5565b9050612bdd85858584611f64565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b784604051612c2491815260200190565b60405180910390a36001600160a01b03808616600081815260026020908152604080832094891683529381528382208281559282526003905291909120612c6e9082868580612e94565b60038181018590556001600160a01b03878116600081815260209384526040808220546001870155519081529188169290917faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad910160405180910390a350509392505050565b600080612cdf612536565b905060005b8351811015610c2257612d11848281518110612d0257612d02613605565b60200260200101518684612bc2565b612d1b90846136cf565b9250600101612ce4565b612d2f8282612298565b610b95576040516303b97b7760e41b81526001600160e01b0319600035166004820152602401610823565b8354612d70906001600160a01b03168484612f26565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b6000818310612da45781611157565b5090919050565b6000818311612dbb576000611157565b61115782846136e2565b60008151600003612dd857506000919050565b60005b6001835103811015612e5b57600181015b8351811015612e5257838181518110612e0757612e07613605565b60200260200101516001600160a01b0316848381518110612e2a57612e2a613605565b60200260200101516001600160a01b031603612e4a575060019392505050565b600101612dec565b50600101612ddb565b50600092915050565b60018201546001600160a01b03808316911603610b9557604051639feb934760e01b815260040160405180910390fd5b8284600301541015612ea857600284018190555b6000612eb8856002015484612d95565b90506000818660020154612ecc91906136e2565b90508015612f1d57600286018290556001870154811115612f00576040516352e521bf60e11b815260040160405180910390fd5b80876001016000016000828254612f1791906136e2565b90915550505b50505050505050565b6000612f30612536565b6001600160a01b0385166000908152600360205260409020600181015460028201549293509091831115612fa4576040518060400160405280612f8b886001600160a01b031660009081526037602052604090206003015490565b8152602090810185905281516001850155015160028301555b6001600160a01b038087166000908152600260209081526040808320938916835292905290812090612fd688886111e5565b90506000612fe689898885611f64565b83549091508114613038578083556040518181526001600160a01b0389811691908b16907faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad9060200160405180910390a35b6130458584888a86612e94565b84546001808501919091556003840187905585015484146130ac57886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c87600101600001546040516130a391815260200190565b60405180910390a35b505050505050505050565b60008083601f8401126130c957600080fd5b5081356001600160401b038111156130e057600080fd5b6020830191508360208260051b85010111156130fb57600080fd5b9250929050565b6000806000806040858703121561311857600080fd5b84356001600160401b038082111561312f57600080fd5b61313b888389016130b7565b9096509450602087013591508082111561315457600080fd5b50613161878288016130b7565b95989497509550505050565b600081518084526020808501945080840160005b8381101561319d57815187529582019590820190600101613181565b509495945050505050565b602081526000611157602083018461316d565b6001600160a01b038116811461082c57600080fd5b6000806000604084860312156131e557600080fd5b83356001600160401b038111156131fb57600080fd5b613207868287016130b7565b909450925050602084013561321b816131bb565b809150509250925092565b6000806000806080858703121561323c57600080fd5b8435613247816131bb565b93506020850135613257816131bb565b92506040850135613267816131bb565b9396929550929360600135925050565b60006020828403121561328957600080fd5b8135613294816131bb565b9392505050565b600080604083850312156132ae57600080fd5b82356132b9816131bb565b946020939093013593505050565b6000806000604084860312156132dc57600080fd5b83356132e7816131bb565b925060208401356001600160401b0381111561330257600080fd5b61330e868287016130b7565b9497909650939450505050565b6000806020838503121561332e57600080fd5b82356001600160401b0381111561334457600080fd5b613350858286016130b7565b90969095509350505050565b6000806040838503121561336f57600080fd5b50508035926020909101359150565b60006020828403121561339057600080fd5b5035919050565b600080604083850312156133aa57600080fd5b82356133b5816131bb565b915060208301356133c5816131bb565b809150509250929050565b6000806000606084860312156133e557600080fd5b83356133f0816131bb565b92506020840135613400816131bb565b929592945050506040919091013590565b8035601081106116ee57600080fd5b6000806040838503121561343357600080fd5b6133b583613411565b60008060006060848603121561345157600080fd5b833561345c816131bb565b95602085013595506040909401359392505050565b60008060008060006060868803121561348957600080fd5b85356001600160401b03808211156134a057600080fd5b6134ac89838a016130b7565b909750955060208801359150808211156134c557600080fd5b506134d2888289016130b7565b96999598509660400135949350505050565b6000602082840312156134f657600080fd5b61115782613411565b60008060006040848603121561351457600080fd5b83356001600160401b0381111561352a57600080fd5b613536868287016130b7565b909790965060209590950135949350505050565b600080600080600060a0868803121561356257600080fd5b853561356d816131bb565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052602160045260246000fd5b601081106135b4576135b461358e565b9052565b6001600160e01b031984168152606081016135d660208301856135a4565b6001600160a01b03929092166040919091015292915050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6020808252601f908201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604082015260600190565b60006020828403121561366457600080fd5b5051919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052601160045260246000fd5b8082018082111561115a5761115a6136b9565b8181038181111561115a5761115a6136b9565b6020810161115a82846135a4565b60208082528181018390526000908460408401835b8681101561374657823561372b816131bb565b6001600160a01b031682529183019190830190600101613718565b509695505050505050565b60006020828403121561376357600080fd5b8151801515811461329457600080fd5b808202811582820484141761115a5761115a6136b9565b6000826137a757634e487b7160e01b600052601260045260246000fd5b500490565b80516116ee816131bb565b600060e082840312156137c957600080fd5b60405160e081018181106001600160401b03821117156137f957634e487b7160e01b600052604160045260246000fd5b604052613805836137ac565b8152613813602084016137ac565b6020820152613824604084016137ac565b6040820152613835606084016137ac565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b6001600160e01b03198316815260408101600b83106138835761388361358e565b8260208301529392505050565b600081518084526020808501945080840160005b8381101561319d5781516001600160a01b0316875295820195908201906001016138a4565b6040815260006138dc6040830186613890565b82810360208401528381526001600160fb1b038411156138fb57600080fd5b8360051b808660208401370160200195945050505050565b600060018201613925576139256136b9565b5060010190565b6020815260006111576020830184613890565b6060815260006139526060830186613890565b8281036020840152613964818661316d565b90508281036040840152613978818561316d565b969550505050505056fea26469706673582212207f5f44f90636203e47ed66d68d89757d8550e32bf28d21dd0cbada492905742f64736f6c63430008110033", + "deployedBytecode": "0x60806040526004361061023f5760003560e01c80636bd8f8041161012e578063aa15a6fd116100ab578063d01b8eed1161006f578063d01b8eed146106e6578063de981f1b14610757578063e22d1c9d14610777578063f92ad21914610797578063f9f031df146107b757610251565b8063aa15a6fd1461062d578063acd79c461461064d578063af24542914610660578063c2a672e014610675578063c50870031461069557610251565b8063909791dd116100f2578063909791dd1461059857806391f8723f146105ad578063924f081e146105cd5780639488e4e9146105ed578063969ffc141461060d57610251565b80636bd8f804146104df57806376664b65146104ff578063865e6fd31461051f578063888b9ae91461053f578063895ab7421461055f57610251565b806342e0c408116101bc5780635c19a95c116101805780635c19a95c146104605780635cd8a76b146104735780636558954f14610488578063679a6e431461049f5780636b091695146104bf57610251565b806342e0c4081461038d57806342ef3c34146103d85780634530d202146103f85780634d99dd1614610420578063574734471461044057610251565b80631658c86e116102035780631658c86e1461030757806326476204146103275780632715805e1461033a5780632baae1251461035a5780633d8e846e1461036d57610251565b8063038278841461025c5780630682e8fa14610285578063095f64751461029a578063097e4a9d146102c75780630dccaf46146102e757610251565b3661025157600861024f816107d7565b005b600861024f816107d7565b34801561026857600080fd5b506102726104b081565b6040519081526020015b60405180910390f35b34801561029157600080fd5b50603854610272565b3480156102a657600080fd5b506102ba6102b5366004613102565b61082f565b60405161027c91906131a8565b3480156102d357600080fd5b506102726102e23660046131d0565b610967565b3480156102f357600080fd5b5061024f610302366004613226565b6109ed565b34801561031357600080fd5b5061024f610322366004613277565b610af0565b61024f610335366004613277565b610b60565b34801561034657600080fd5b5061027261035536600461329b565b610b99565b61024f610368366004613226565b610c2a565b34801561037957600080fd5b506102ba6103883660046132c7565b610d78565b34801561039957600080fd5b506103c86103a8366004613277565b6001600160a01b039081166000908152603a602052604090205416151590565b604051901515815260200161027c565b3480156103e457600080fd5b506102ba6103f336600461331b565b610ea6565b34801561040457600080fd5b50606e54606d546040805192835260208301919091520161027c565b34801561042c57600080fd5b5061024f61043b36600461329b565b610f72565b34801561044c57600080fd5b5061024f61045b36600461335c565b610fee565b61024f61046e366004613277565b611000565b34801561047f57600080fd5b5061024f61106e565b34801561049457600080fd5b506102726201518081565b3480156104ab57600080fd5b5061024f6104ba36600461337e565b61112d565b3480156104cb57600080fd5b506102726104da366004613397565b61113e565b3480156104eb57600080fd5b5061024f6104fa3660046133d0565b611160565b34801561050b57600080fd5b5061027261051a366004613397565b6111e5565b34801561052b57600080fd5b5061024f61053a366004613420565b611214565b34801561054b57600080fd5b5061024f61055a36600461337e565b61122f565b34801561056b57600080fd5b5061027261057a366004613277565b6001600160a01b031660009081526037602052604090206003015490565b3480156105a457600080fd5b50606c54610272565b3480156105b957600080fd5b506102ba6105c836600461331b565b611240565b3480156105d957600080fd5b5061024f6105e836600461343c565b6112e0565b3480156105f957600080fd5b5061024f610608366004613102565b6113ba565b34801561061957600080fd5b5061024f61062836600461337e565b6114e9565b34801561063957600080fd5b5061024f610648366004613277565b6114fa565b61024f61065b366004613471565b61156a565b34801561066c57600080fd5b50603954610272565b34801561068157600080fd5b5061024f61069036600461329b565b6115be565b3480156106a157600080fd5b506106ce6106b0366004613277565b6001600160a01b039081166000908152603a60205260409020541690565b6040516001600160a01b03909116815260200161027c565b3480156106f257600080fd5b50610732610701366004613277565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604080516001600160a01b03909416845260208401929092529082015260600161027c565b34801561076357600080fd5b506106ce6107723660046134e4565b611678565b34801561078357600080fd5b5061024f6107923660046134ff565b6116f3565b3480156107a357600080fd5b5061024f6107b236600461354a565b6118b7565b3480156107c357600080fd5b506102726107d236600461331b565b6119ae565b6107e081611678565b6001600160a01b0316336001600160a01b03161461082c576000356001600160e01b03191681336040516320e0f98d60e21b8152600401610823939291906135b8565b60405180910390fd5b50565b6060838214610851576040516376081a7b60e11b815260040160405180910390fd5b836001600160401b03811115610869576108696135ef565b604051908082528060200260200182016040528015610892578160200160208202803683370190505b50905060005b815181101561095e57603760008787848181106108b7576108b7613605565b90506020020160208101906108cc9190613277565b6001600160a01b03166001600160a01b03168152602001908152602001600020600401600085858481811061090357610903613605565b90506020020160208101906109189190613277565b6001600160a01b03166001600160a01b031681526020019081526020016000205482828151811061094b5761094b613605565b6020908102919091010152600101610898565b50949350505050565b600060026000540361098b5760405162461bcd60e51b81526004016108239061361b565b60026000558161099a81611a2e565b336000908152603a60205260409020546001600160a01b0316156109d357604051632fc6bfb160e21b8152336004820152602401610823565b6109df33868686611acc565b600160005595945050505050565b466107e514610a235760405162461bcd60e51b8152602060048201526002602482015261453160f01b6044820152606401610823565b7357832a94810e18c84a5a5e2c4dd67d012ade574f3314610a6b5760405162461bcd60e51b8152602060048201526002602482015261229960f11b6044820152606401610823565b610a756008611678565b60405163f883afaf60e01b81526001600160a01b0386811660048301528581166024830152848116604483015260648201849052919091169063f883afaf906084015b600060405180830381600087803b158015610ad257600080fd5b505af1158015610ae6573d6000803e3d6000fd5b5050505050505050565b80610afa81611a2e565b6001600160a01b038216600090815260376020526040902033610b1d8282611b39565b610b276008611678565b60395460405163dd716ad360e01b81526001600160a01b038781166004830152602482019290925291169063dd716ad390604401610ab8565b610b68611b69565b80610b7281611a2e565b6001600160a01b0382166000908152603760205260409020610b95903334611b8c565b5050565b60006008610ba6816107d7565b6001600160a01b0384166000908152603760205260409020610bc89084611c37565b915033610bd58184611cd4565b610c2257604080518481524760208201526001600160a01b0380841692908816917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b505092915050565b600260005403610c4c5760405162461bcd60e51b81526004016108239061361b565b60026000908155338152603a60205260409020546001600160a01b031615610c8957604051632fc6bfb160e21b8152336004820152602401610823565b606d54811180610c9a5750606e5481105b15610cb857604051631b8454a360e21b815260040160405180910390fd5b3433610cc8818787878787611d30565b6001600160a01b0380861660008181526037602081815260408084206001810180549789166001600160a01b0319988916811790915581548816871782558552603a835290842080549096168517909555929091529052610d2a818385611b8c565b816001600160a01b0316866001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a3505060016000555050505050565b6060600080610d876008611678565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610dc4573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610de89190613652565b9050836001600160401b03811115610e0257610e026135ef565b604051908082528060200260200182016040528015610e2b578160200160208202803683370190505b50925060005b84811015610e9c57858582818110610e4b57610e4b613605565b9050602002016020810190610e609190613277565b9250610e77838884610e72878c6111e5565b611f64565b848281518110610e8957610e89613605565b6020908102919091010152600101610e31565b5050509392505050565b6060816001600160401b03811115610ec057610ec06135ef565b604051908082528060200260200182016040528015610ee9578160200160208202803683370190505b50905060005b82811015610f6b5760376000858584818110610f0d57610f0d613605565b9050602002016020810190610f229190613277565b6001600160a01b03166001600160a01b0316815260200190815260200160002060020154828281518110610f5857610f58613605565b6020908102919091010152600101610eef565b5092915050565b600260005403610f945760405162461bcd60e51b81526004016108239061361b565b600260009081556001600160a01b03831681526037602052604090203390610fbd908284612060565b610fc78183612298565b610fe457604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b610ff66122e0565b610b95828261233a565b611008611b69565b8061101281611a2e565b336000908152603a60205260409020546001600160a01b03161561104b57604051632fc6bfb160e21b8152336004820152602401610823565b6001600160a01b0382166000908152603760205260409020610b959033346123ae565b60d154600290610100900460ff16158015611090575060d15460ff8083169116105b6110ac5760405162461bcd60e51b81526004016108239061366b565b60d1805461ffff191660ff8316176101001790556036546110d8906008906001600160a01b031661245d565b603680546001600160a01b031916905560d1805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6111356122e0565b61082c81612501565b6000611157838361114d612536565b610e7287876111e5565b90505b92915050565b6002600054036111825760405162461bcd60e51b81526004016108239061361b565b60026000558161119181611a2e565b6001600160a01b038416600090815260376020526040902033906111b6908285612060565b6001600160a01b03841660009081526037602052604090206111d99082856123ae565b50506001600055505050565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b61121c6122e0565b611225816125a8565b610b95828261245d565b6112376122e0565b61082c816125de565b6060816001600160401b0381111561125a5761125a6135ef565b604051908082528060200260200182016040528015611283578160200160208202803683370190505b50905060005b82811015610f6b576112bb8484838181106112a6576112a6613605565b905060200201602081019061057a9190613277565b8282815181106112cd576112cd613605565b6020908102919091010152600101611289565b826112ea81611a2e565b6001600160a01b03841660009081526037602052604090203361130d8282611b39565b606d5484118061131e5750606e5484105b1561133c57604051631b8454a360e21b815260040160405180910390fd5b6113466008611678565b60405163e5125a1d60e01b81526001600160a01b0388811660048301526024820188905260448201879052919091169063e5125a1d906064015b600060405180830381600087803b15801561139a57600080fd5b505af11580156113ae573d6000803e3d6000fd5b50505050505050505050565b6002600054036113dc5760405162461bcd60e51b81526004016108239061361b565b60026000558215806113ee5750828114155b1561140c576040516376081a7b60e11b815260040160405180910390fd5b336000805b858110156114b45784848281811061142b5761142b613605565b905060200201358261143d91906136cf565b91506114ac6037600089898581811061145857611458613605565b905060200201602081019061146d9190613277565b6001600160a01b03166001600160a01b03168152602001908152602001600020848787858181106114a0576114a0613605565b90506020020135612060565b600101611411565b506114bf8282612298565b6114dc57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b6114f16122e0565b61082c81612613565b8061150481611a2e565b6001600160a01b0382166000908152603760205260409020336115278282611b39565b6115316008611678565b60395460405163a7c2f11960e01b81526001600160a01b038781166004830152602482019290925291169063a7c2f11990604401610ab8565b6008611575816107d7565b6115b6868680806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250889250879150869050612648565b505050505050565b6002600054036115e05760405162461bcd60e51b81526004016108239061361b565b6002600055816115ef81611a2e565b81600003611610576040516331d9f7d760e01b815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061163b9086906136e2565b9050606c548110156116605760405163ef0a995760e01b815260040160405180910390fd5b61166b828487612a76565b6114bf83866104b0612b62565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156116af576116af61358e565b60ff1681526020810191909152604001600020546001600160a01b03169050806116ee578160405163409140df60e11b815260040161082391906136f5565b919050565b60086116fe816107d7565b82156118b15760005b838110156118765760006037600087878581811061172757611727613605565b905060200201602081019061173c9190613277565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a909352912080546001600160a01b031916905560028101549091508015611803576117938282611c37565b5060018201546117af906001600160a01b0316826104b0612b62565b6118035760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b600061184388888681811061181a5761181a613605565b905060200201602081019061182f9190613277565b60018501546001600160a01b031688612bc2565b90508015611868576001830154611866906001600160a01b0316826104b0612b62565b505b836001019350505050611707565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d884846040516118a8929190613703565b60405180910390a15b50505050565b60d154610100900460ff16158080156118d7575060d154600160ff909116105b806118f15750303b1580156118f1575060d15460ff166001145b61190d5760405162461bcd60e51b81526004016108239061366b565b60d1805460ff1916600117905580156119305760d1805461ff0019166101001790555b61193b60088761245d565b61194485612501565b61194f60008561233a565b611958836125de565b61196182612613565b80156115b65760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a1505050505050565b60006002600054036119d25760405162461bcd60e51b81526004016108239061361b565b6002600081905550611a1733848480806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612cd492505050565b9050611a233382612d25565b600160005592915050565b611a386008611678565b604051635061f96960e11b81526001600160a01b038381166004830152919091169063a0c3f2d290602401602060405180830381865afa158015611a80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611aa49190613751565b61082c57604051630fd0c64560e11b81526001600160a01b0382166004820152602401610823565b6000611b0b85858580806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250612cd492505050565b6001600160a01b0383166000908152603760205260409020909150611b319086836123ae565b949350505050565b60018201546001600160a01b03828116911614610b9557604051637bc65bd760e11b815260040160405180910390fd5b34600003611b8a57604051636dfcbde560e11b815260040160405180910390fd5b565b8282611b988282611b39565b82856002016000828254611bac91906136cf565b92505081905550611bd285858760020154868960030154611bcd91906136cf565b612d5a565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d90611c289086815260200190565b60405180910390a25050505050565b6000611c47836002015483612d95565b905080836002016000828254611c5d91906136e2565b9091555050600183015460028401546003850154611c8d9286926001600160a01b0390911691611bcd9086612dab565b82546040518281526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f759060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611d21576040519150601f19603f3d011682016040523d82523d6000602084013e611d26565b606091505b5090949350505050565b611d3e8660006104b0612b62565b611d89576040805163338f030160e01b81526001600160a01b03881660048201526024810191909152600a6044820152693837b7b61030b236b4b760b11b6064820152608401610823565b611d978360006104b0612b62565b611de0576040805163338f030160e01b81526001600160a01b038516600482015260248101919091526008604482015267747265617375727960c01b6064820152608401610823565b606c54811015611e0357604051630a8d7fa760e21b815260040160405180910390fd5b846001600160a01b0316866001600160a01b0316141580611e365750826001600160a01b0316856001600160a01b031614155b15611e545760405163dc1d04ff60e01b815260040160405180910390fd5b6040805160028082526060820183526000926020830190803683370190505090508681600081518110611e8957611e89613605565b60200260200101906001600160a01b031690816001600160a01b0316815250508481600181518110611ebd57611ebd613605565b60200260200101906001600160a01b031690816001600160a01b031681525050611ee681612dc5565b15611f1257604051630d697db160e11b81526001600160e01b0319600035166004820152602401610823565b50611f1d6008611678565b60405163f883afaf60e01b81526001600160a01b0387811660048301528681166024830152858116604483015260648201859052919091169063f883afaf90608401611380565b6001600160a01b03808516600090815260026020908152604080832093871683529290529081206003810154849003611f9f57549050611b31565b6001600160a01b0386166000908152600360208181526040808420600180845282862094870154865293909252832091820154839290156120045780546001860154909450611fee90856136e2565b8560020154611ffd9190613773565b925061200c565b846001015493505b815460009061201c9086906136e2565b6120269089613773565b9050670de0b6b3a764000061203b82866136cf565b612045919061378a565b865461205191906136cf565b9b9a5050505050505050505050565b828261206c8282612e64565b8260000361208d57604051637ab0c6ad60e11b815260040160405180910390fd5b6001600160a01b03841660009081526004860160205260409020548311156120c857604051630695534560e31b815260040160405180910390fd5b60006120d46008611678565b8654604051635061f96960e11b81526001600160a01b03918216600482015291925082169063a0c3f2d290602401602060405180830381865afa15801561211f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121439190613751565b80156121bd575085546040516328bde1e160e01b81526001600160a01b039182166004820152908216906328bde1e19060240160e060405180830381865afa158015612193573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121b791906137b7565b60a00151155b80156121f057506038546001600160a01b038616600090815260058801602052604090205442916121ed916136cf565b10155b1561220e5760405163f19f52bd60e01b815260040160405180910390fd5b6001600160a01b038516600090815260048701602052604090205461224c908790879061223c9088906136e2565b878a60030154611bcd91906136e2565b85546040518581526001600160a01b03918216918716907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c9060200160405180910390a3505050505050565b6000814710156122d6576040516302631c4f60e61b81526001600160e01b031960003516600482015247602482015260448101839052606401610823565b6111578383611cd4565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611b8a576000356001600160e01b0319166001604051620f948f60ea1b8152600401610823929190613862565b61271081118061234957508082115b1561236757604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b82826123ba8282612e64565b6001600160a01b03841660009081526004860160205260409020546123f890869086906123e89087906136cf565b868960030154611bcd91906136cf565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b9061244e9087815260200190565b60405180910390a35050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156124935761249361358e565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156124d4576124d461358e565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be290602001611122565b60006125426008611678565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561257f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125a39190613652565b905090565b806001600160a01b03163b60000361082c57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610823565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a90602001611122565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c67890602001611122565b8351821461269157807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a5858585604051612684939291906138c9565b60405180910390a26118b1565b600080600080600088516001600160401b038111156126b2576126b26135ef565b6040519080825280602002602001820160405280156126db578160200160208202803683370190505b509050600089516001600160401b038111156126f9576126f96135ef565b604051908082528060200260200182016040528015612722578160200160208202803683370190505b50905060008a516001600160401b03811115612740576127406135ef565b604051908082528060200260200182016040528015612769578160200160208202803683370190505b50905060005b8b518110156129dc578b818151811061278a5761278a613605565b6020908102919091018101516001600160a01b038116600090815260038084526040808320603790955290912001549097506001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a900361282b57868389806001019a508151811061280557612805613605565b60200260200101906001600160a01b031690816001600160a01b031681525050506129ca565b60028101548a111561285957604080518082019091528681526020018a905260018101869055600281018a90555b6001810154156128a35760018101548c8c8481811061287a5761287a613605565b90506020020135670de0b6b3a76400006128949190613773565b61289e919061378a565b6128a6565b60005b9850888160000160008282546128bc91906136cf565b91829055509050856128ce8a856136e2565b815181106128de576128de613605565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c81526020019081526020016000206000820151816000015560208201518160010155905050858160010160000181905550806001016000015484898461297191906136e2565b8151811061298157612981613605565b6020908102919091010152868d6129988a856136e2565b815181106129a8576129a8613605565b60200260200101906001600160a01b031690816001600160a01b031681525050505b806129d481613913565b91505061276f565b508515612a2557858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a382604051612a1c919061392c565b60405180910390a25b8a5115612a6957877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c8585604051612a609392919061393f565b60405180910390a25b5050505050505050505050565b8282612a828282611b39565b8460020154831115612aa757604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b03851660009081526005870160205260409020544291612ad0916136cf565b1115612aef576040516303db082960e11b815260040160405180910390fd5b82856002016000828254612b0391906136e2565b92505081905550612b2485858760020154868960030154611bcd91906136e2565b84546040518481526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f7590602001611c28565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114612bb2576040519150601f19603f3d011682016040523d82523d6000602084013e612bb7565b606091505b509095945050505050565b600080612bcf85856111e5565b9050612bdd85858584611f64565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b784604051612c2491815260200190565b60405180910390a36001600160a01b03808616600081815260026020908152604080832094891683529381528382208281559282526003905291909120612c6e9082868580612e94565b60038181018590556001600160a01b03878116600081815260209384526040808220546001870155519081529188169290917faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad910160405180910390a350509392505050565b600080612cdf612536565b905060005b8351811015610c2257612d11848281518110612d0257612d02613605565b60200260200101518684612bc2565b612d1b90846136cf565b9250600101612ce4565b612d2f8282612298565b610b95576040516303b97b7760e41b81526001600160e01b0319600035166004820152602401610823565b8354612d70906001600160a01b03168484612f26565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b6000818310612da45781611157565b5090919050565b6000818311612dbb576000611157565b61115782846136e2565b60008151600003612dd857506000919050565b60005b6001835103811015612e5b57600181015b8351811015612e5257838181518110612e0757612e07613605565b60200260200101516001600160a01b0316848381518110612e2a57612e2a613605565b60200260200101516001600160a01b031603612e4a575060019392505050565b600101612dec565b50600101612ddb565b50600092915050565b60018201546001600160a01b03808316911603610b9557604051639feb934760e01b815260040160405180910390fd5b8284600301541015612ea857600284018190555b6000612eb8856002015484612d95565b90506000818660020154612ecc91906136e2565b90508015612f1d57600286018290556001870154811115612f00576040516352e521bf60e11b815260040160405180910390fd5b80876001016000016000828254612f1791906136e2565b90915550505b50505050505050565b6000612f30612536565b6001600160a01b0385166000908152600360205260409020600181015460028201549293509091831115612fa4576040518060400160405280612f8b886001600160a01b031660009081526037602052604090206003015490565b8152602090810185905281516001850155015160028301555b6001600160a01b038087166000908152600260209081526040808320938916835292905290812090612fd688886111e5565b90506000612fe689898885611f64565b83549091508114613038578083556040518181526001600160a01b0389811691908b16907faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad9060200160405180910390a35b6130458584888a86612e94565b84546001808501919091556003840187905585015484146130ac57886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c87600101600001546040516130a391815260200190565b60405180910390a35b505050505050505050565b60008083601f8401126130c957600080fd5b5081356001600160401b038111156130e057600080fd5b6020830191508360208260051b85010111156130fb57600080fd5b9250929050565b6000806000806040858703121561311857600080fd5b84356001600160401b038082111561312f57600080fd5b61313b888389016130b7565b9096509450602087013591508082111561315457600080fd5b50613161878288016130b7565b95989497509550505050565b600081518084526020808501945080840160005b8381101561319d57815187529582019590820190600101613181565b509495945050505050565b602081526000611157602083018461316d565b6001600160a01b038116811461082c57600080fd5b6000806000604084860312156131e557600080fd5b83356001600160401b038111156131fb57600080fd5b613207868287016130b7565b909450925050602084013561321b816131bb565b809150509250925092565b6000806000806080858703121561323c57600080fd5b8435613247816131bb565b93506020850135613257816131bb565b92506040850135613267816131bb565b9396929550929360600135925050565b60006020828403121561328957600080fd5b8135613294816131bb565b9392505050565b600080604083850312156132ae57600080fd5b82356132b9816131bb565b946020939093013593505050565b6000806000604084860312156132dc57600080fd5b83356132e7816131bb565b925060208401356001600160401b0381111561330257600080fd5b61330e868287016130b7565b9497909650939450505050565b6000806020838503121561332e57600080fd5b82356001600160401b0381111561334457600080fd5b613350858286016130b7565b90969095509350505050565b6000806040838503121561336f57600080fd5b50508035926020909101359150565b60006020828403121561339057600080fd5b5035919050565b600080604083850312156133aa57600080fd5b82356133b5816131bb565b915060208301356133c5816131bb565b809150509250929050565b6000806000606084860312156133e557600080fd5b83356133f0816131bb565b92506020840135613400816131bb565b929592945050506040919091013590565b8035601081106116ee57600080fd5b6000806040838503121561343357600080fd5b6133b583613411565b60008060006060848603121561345157600080fd5b833561345c816131bb565b95602085013595506040909401359392505050565b60008060008060006060868803121561348957600080fd5b85356001600160401b03808211156134a057600080fd5b6134ac89838a016130b7565b909750955060208801359150808211156134c557600080fd5b506134d2888289016130b7565b96999598509660400135949350505050565b6000602082840312156134f657600080fd5b61115782613411565b60008060006040848603121561351457600080fd5b83356001600160401b0381111561352a57600080fd5b613536868287016130b7565b909790965060209590950135949350505050565b600080600080600060a0868803121561356257600080fd5b853561356d816131bb565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052602160045260246000fd5b601081106135b4576135b461358e565b9052565b6001600160e01b031984168152606081016135d660208301856135a4565b6001600160a01b03929092166040919091015292915050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6020808252601f908201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604082015260600190565b60006020828403121561366457600080fd5b5051919050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052601160045260246000fd5b8082018082111561115a5761115a6136b9565b8181038181111561115a5761115a6136b9565b6020810161115a82846135a4565b60208082528181018390526000908460408401835b8681101561374657823561372b816131bb565b6001600160a01b031682529183019190830190600101613718565b509695505050505050565b60006020828403121561376357600080fd5b8151801515811461329457600080fd5b808202811582820484141761115a5761115a6136b9565b6000826137a757634e487b7160e01b600052601260045260246000fd5b500490565b80516116ee816131bb565b600060e082840312156137c957600080fd5b60405160e081018181106001600160401b03821117156137f957634e487b7160e01b600052604160045260246000fd5b604052613805836137ac565b8152613813602084016137ac565b6020820152613824604084016137ac565b6040820152613835606084016137ac565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b6001600160e01b03198316815260408101600b83106138835761388361358e565b8260208301529392505050565b600081518084526020808501945080840160005b8381101561319d5781516001600160a01b0316875295820195908201906001016138a4565b6040815260006138dc6040830186613890565b82810360208401528381526001600160fb1b038411156138fb57600080fd5b8360051b808660208401370160200195945050505050565b600060018201613925576139256136b9565b5060010190565b6020815260006111576020830184613890565b6060815260006139526060830186613890565b8281036020840152613964818661316d565b90508281036040840152613978818561316d565b969550505050505056fea26469706673582212207f5f44f90636203e47ed66d68d89757d8550e32bf28d21dd0cbada492905742f64736f6c63430008110033", "devdoc": { "errors": { "ErrAdminOfAnyActivePoolForbidden(address)": [ @@ -1323,11 +1447,6 @@ "details": "Error of admin of any active pool cannot delegate." } ], - "ErrCallerMustBeValidatorContract()": [ - { - "details": "Error of method caller must be validator contract." - } - ], "ErrCannotInitTransferRON(address,string)": [ { "details": "Error of cannot transfer RON to specified target." @@ -1338,12 +1457,25 @@ "details": "Error of cannot transfer RON." } ], + "ErrContractTypeNotFound(uint8)": [ + { + "details": "Error of invalid role." + } + ], + "ErrDuplicated(bytes4)": [ + { + "details": "Error thrown when a duplicated element is detected in an array.", + "params": { + "msgSig": "The function signature that invoke the error." + } + } + ], "ErrInactivePool(address)": [ { "details": "Error of querying inactive pool." } ], - "ErrInsufficientBalance()": [ + "ErrInsufficientBalance(bytes4,uint256,uint256)": [ { "details": "Error of sender has insufficient balance." } @@ -1383,7 +1515,7 @@ "details": "Error of pool admin is not allowed to call." } ], - "ErrRecipientRevert()": [ + "ErrRecipientRevert(bytes4)": [ { "details": "Error of recipient not accepting RON when transfer RON." } @@ -1398,9 +1530,13 @@ "details": "Error of three interaction addresses must be of the same in applying for validator candidate." } ], - "ErrThreeOperationAddrsNotDistinct()": [ + "ErrUnauthorized(bytes4,uint8)": [ { - "details": "Error of three operation addresses must be distinct in applying for validator candidate." + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } } ], "ErrUndelegateTooEarly()": [ @@ -1413,6 +1549,16 @@ "details": "Error of undelegating zero amount." } ], + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } + } + ], "ErrUnstakeTooEarly()": [ { "details": "Error of unstaking too early." @@ -1423,7 +1569,7 @@ "details": "Error of unstaking zero amount." } ], - "ErrZeroCodeContract()": [ + "ErrZeroCodeContract(address)": [ { "details": "Error of set to non-contract." } @@ -1436,7 +1582,7 @@ }, "kind": "dev", "methods": { - "applyValidatorCandidate(address,address,address,address,uint256)": { + "applyValidatorCandidate(address,address,address,uint256)": { "details": "Proposes a candidate to become a validator. Requirements: - The method caller is able to receive RON. - The treasury is able to receive RON. - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`. Emits the event `PoolApproved`.", "params": { "_candidateAdmin": "the candidate admin will be stored in the validator contract, used for calling function that affects to its candidate, e.g. scheduling maintenance." @@ -1469,6 +1615,15 @@ "getCommissionRateRange()": { "details": "Returns the commission rate range that the candidate can set." }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, "getManySelfStakings(address[])": { "details": "Returns the self-staking amounts of the pools." }, @@ -1520,30 +1675,34 @@ "setCommissionRateRange(uint256,uint256)": { "details": "Sets the commission rate range that a candidate can set. Requirements: - The method caller is admin. Emits the `CommissionRateRangeUpdated` event." }, + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } + }, "setCooldownSecsToUndelegate(uint256)": { "details": "Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated. Requirements: - The method caller is admin. Emits the event `CooldownSecsToUndelegateUpdated`." }, "setMinValidatorStakingAmount(uint256)": { "details": "Sets the minimum threshold for being a validator candidate. Requirements: - The method caller is admin. Emits the `MinValidatorStakingAmountUpdated` event." }, - "setValidatorContract(address)": { - "details": "Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`." - }, "setWaitingSecsToRevoke(uint256)": { "details": "Sets the number of seconds that a candidate must wait to be revoked. Requirements: - The method caller is admin. Emits the event `WaitingSecsToRevokeUpdated`." }, "stake(address)": { "details": "Self-delegates to the validator candidate `_consensusAddr`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. - The `msg.value` is larger than 0. Emits the event `Staked`." }, + "tmp_re_applyValidatorCandidate(address,address,address,uint256)": { + "details": "This method only work on testnet, to hotfix the applied validator candidate that is failed. TODO: Should remove this method before deploying it on mainnet." + }, "undelegate(address,uint256)": { "details": "Unstakes from a validator candidate `_consensusAddr` for `_amount`. Requirements: - The method caller is not the pool admin. Emits the `Undelegated` event." }, "unstake(address,uint256)": { "details": "Unstakes from the validator candidate `_consensusAddr` for `_amount`. Requirements: - The consensus address is a validator candidate. - The method caller is the pool admin. Emits the event `Unstaked`." }, - "validatorContract()": { - "details": "Returns the validator contract." - }, "waitingSecsToRevoke()": { "details": "Returns the number of seconds that a candidate must wait for the renounce request gets affected." } @@ -1566,31 +1725,31 @@ "type": "t_uint256" }, { - "astId": 29207, + "astId": 35885, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_accumulatedRps", "offset": 0, "slot": "1", - "type": "t_mapping(t_address,t_mapping(t_uint256,t_struct(PeriodWrapper)10552_storage))" + "type": "t_mapping(t_address,t_mapping(t_uint256,t_struct(PeriodWrapper)13011_storage))" }, { - "astId": 29215, + "astId": 35893, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_userReward", "offset": 0, "slot": "2", - "type": "t_mapping(t_address,t_mapping(t_address,t_struct(UserRewardFields)11332_storage))" + "type": "t_mapping(t_address,t_mapping(t_address,t_struct(UserRewardFields)13874_storage))" }, { - "astId": 29221, + "astId": 35899, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_stakingPool", "offset": 0, "slot": "3", - "type": "t_mapping(t_address,t_struct(PoolFields)11338_storage)" + "type": "t_mapping(t_address,t_struct(PoolFields)13880_storage)" }, { - "astId": 29226, + "astId": 35904, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "______gap", "offset": 0, @@ -1598,23 +1757,23 @@ "type": "t_array(t_uint256)50_storage" }, { - "astId": 7051, + "astId": 41900, "contract": "contracts/ronin/staking/Staking.sol:Staking", - "label": "_validatorContract", + "label": "______deprecatedValidator", "offset": 0, "slot": "54", - "type": "t_contract(IRoninValidatorSet)11973" + "type": "t_address" }, { - "astId": 27475, + "astId": 34068, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_stakingPool", "offset": 0, "slot": "55", - "type": "t_mapping(t_address,t_struct(PoolDetail)10939_storage)" + "type": "t_mapping(t_address,t_struct(PoolDetail)13486_storage)" }, { - "astId": 27478, + "astId": 34071, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_cooldownSecsToUndelegate", "offset": 0, @@ -1622,7 +1781,7 @@ "type": "t_uint256" }, { - "astId": 27481, + "astId": 34074, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_waitingSecsToRevoke", "offset": 0, @@ -1630,7 +1789,7 @@ "type": "t_uint256" }, { - "astId": 27486, + "astId": 34079, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_adminOfActivePoolMapping", "offset": 0, @@ -1638,7 +1797,7 @@ "type": "t_mapping(t_address,t_address)" }, { - "astId": 27491, + "astId": 34084, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "______gap", "offset": 0, @@ -1646,7 +1805,7 @@ "type": "t_array(t_uint256)49_storage" }, { - "astId": 27927, + "astId": 34573, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_minValidatorStakingAmount", "offset": 0, @@ -1654,7 +1813,7 @@ "type": "t_uint256" }, { - "astId": 27930, + "astId": 34576, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_maxCommissionRate", "offset": 0, @@ -1662,7 +1821,7 @@ "type": "t_uint256" }, { - "astId": 27933, + "astId": 34579, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "_minCommissionRate", "offset": 0, @@ -1670,7 +1829,7 @@ "type": "t_uint256" }, { - "astId": 27938, + "astId": 34584, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "______gap", "offset": 0, @@ -1678,7 +1837,7 @@ "type": "t_array(t_uint256)48_storage" }, { - "astId": 28680, + "astId": 35340, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "______gap", "offset": 0, @@ -1731,11 +1890,6 @@ "label": "bool", "numberOfBytes": "1" }, - "t_contract(IRoninValidatorSet)11973": { - "encoding": "inplace", - "label": "contract IRoninValidatorSet", - "numberOfBytes": "20" - }, "t_mapping(t_address,t_address)": { "encoding": "mapping", "key": "t_address", @@ -1743,40 +1897,40 @@ "numberOfBytes": "32", "value": "t_address" }, - "t_mapping(t_address,t_mapping(t_address,t_struct(UserRewardFields)11332_storage))": { + "t_mapping(t_address,t_mapping(t_address,t_struct(UserRewardFields)13874_storage))": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => mapping(address => struct IRewardPool.UserRewardFields))", "numberOfBytes": "32", - "value": "t_mapping(t_address,t_struct(UserRewardFields)11332_storage)" + "value": "t_mapping(t_address,t_struct(UserRewardFields)13874_storage)" }, - "t_mapping(t_address,t_mapping(t_uint256,t_struct(PeriodWrapper)10552_storage))": { + "t_mapping(t_address,t_mapping(t_uint256,t_struct(PeriodWrapper)13011_storage))": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => mapping(uint256 => struct PeriodWrapperConsumer.PeriodWrapper))", "numberOfBytes": "32", - "value": "t_mapping(t_uint256,t_struct(PeriodWrapper)10552_storage)" + "value": "t_mapping(t_uint256,t_struct(PeriodWrapper)13011_storage)" }, - "t_mapping(t_address,t_struct(PoolDetail)10939_storage)": { + "t_mapping(t_address,t_struct(PoolDetail)13486_storage)": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => struct IBaseStaking.PoolDetail)", "numberOfBytes": "32", - "value": "t_struct(PoolDetail)10939_storage" + "value": "t_struct(PoolDetail)13486_storage" }, - "t_mapping(t_address,t_struct(PoolFields)11338_storage)": { + "t_mapping(t_address,t_struct(PoolFields)13880_storage)": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => struct IRewardPool.PoolFields)", "numberOfBytes": "32", - "value": "t_struct(PoolFields)11338_storage" + "value": "t_struct(PoolFields)13880_storage" }, - "t_mapping(t_address,t_struct(UserRewardFields)11332_storage)": { + "t_mapping(t_address,t_struct(UserRewardFields)13874_storage)": { "encoding": "mapping", "key": "t_address", "label": "mapping(address => struct IRewardPool.UserRewardFields)", "numberOfBytes": "32", - "value": "t_struct(UserRewardFields)11332_storage" + "value": "t_struct(UserRewardFields)13874_storage" }, "t_mapping(t_address,t_uint256)": { "encoding": "mapping", @@ -1785,19 +1939,19 @@ "numberOfBytes": "32", "value": "t_uint256" }, - "t_mapping(t_uint256,t_struct(PeriodWrapper)10552_storage)": { + "t_mapping(t_uint256,t_struct(PeriodWrapper)13011_storage)": { "encoding": "mapping", "key": "t_uint256", "label": "mapping(uint256 => struct PeriodWrapperConsumer.PeriodWrapper)", "numberOfBytes": "32", - "value": "t_struct(PeriodWrapper)10552_storage" + "value": "t_struct(PeriodWrapper)13011_storage" }, - "t_struct(PeriodWrapper)10552_storage": { + "t_struct(PeriodWrapper)13011_storage": { "encoding": "inplace", "label": "struct PeriodWrapperConsumer.PeriodWrapper", "members": [ { - "astId": 10549, + "astId": 13008, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "inner", "offset": 0, @@ -1805,7 +1959,7 @@ "type": "t_uint256" }, { - "astId": 10551, + "astId": 13010, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "lastPeriod", "offset": 0, @@ -1815,12 +1969,12 @@ ], "numberOfBytes": "64" }, - "t_struct(PoolDetail)10939_storage": { + "t_struct(PoolDetail)13486_storage": { "encoding": "inplace", "label": "struct IBaseStaking.PoolDetail", "members": [ { - "astId": 10924, + "astId": 13471, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "addr", "offset": 0, @@ -1828,7 +1982,7 @@ "type": "t_address" }, { - "astId": 10926, + "astId": 13473, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "admin", "offset": 0, @@ -1836,7 +1990,7 @@ "type": "t_address" }, { - "astId": 10928, + "astId": 13475, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "stakingAmount", "offset": 0, @@ -1844,7 +1998,7 @@ "type": "t_uint256" }, { - "astId": 10930, + "astId": 13477, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "stakingTotal", "offset": 0, @@ -1852,7 +2006,7 @@ "type": "t_uint256" }, { - "astId": 10934, + "astId": 13481, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "delegatingAmount", "offset": 0, @@ -1860,7 +2014,7 @@ "type": "t_mapping(t_address,t_uint256)" }, { - "astId": 10938, + "astId": 13485, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "lastDelegatingTimestamp", "offset": 0, @@ -1870,12 +2024,12 @@ ], "numberOfBytes": "192" }, - "t_struct(PoolFields)11338_storage": { + "t_struct(PoolFields)13880_storage": { "encoding": "inplace", "label": "struct IRewardPool.PoolFields", "members": [ { - "astId": 11334, + "astId": 13876, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "aRps", "offset": 0, @@ -1883,22 +2037,22 @@ "type": "t_uint256" }, { - "astId": 11337, + "astId": 13879, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "shares", "offset": 0, "slot": "1", - "type": "t_struct(PeriodWrapper)10552_storage" + "type": "t_struct(PeriodWrapper)13011_storage" } ], "numberOfBytes": "96" }, - "t_struct(UserRewardFields)11332_storage": { + "t_struct(UserRewardFields)13874_storage": { "encoding": "inplace", "label": "struct IRewardPool.UserRewardFields", "members": [ { - "astId": 11325, + "astId": 13867, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "debited", "offset": 0, @@ -1906,7 +2060,7 @@ "type": "t_uint256" }, { - "astId": 11327, + "astId": 13869, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "aRps", "offset": 0, @@ -1914,7 +2068,7 @@ "type": "t_uint256" }, { - "astId": 11329, + "astId": 13871, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "lowestAmount", "offset": 0, @@ -1922,7 +2076,7 @@ "type": "t_uint256" }, { - "astId": 11331, + "astId": 13873, "contract": "contracts/ronin/staking/Staking.sol:Staking", "label": "lastPeriod", "offset": 0, diff --git a/deployments/ronin-mainnet/StakingVestingLogic.json b/deployments/ronin-mainnet/StakingVestingLogic.json index e8db04e08..1eb443fd0 100644 --- a/deployments/ronin-mainnet/StakingVestingLogic.json +++ b/deployments/ronin-mainnet/StakingVestingLogic.json @@ -1,5 +1,5 @@ { - "address": "0xf07121671F929d89eA6CaEE8e3D26BD7eD63CFeb", + "address": "0x7CcBb3CD1b19BC1f1d5B7048400D41B1b796AbAd", "abi": [ { "inputs": [], @@ -8,21 +8,108 @@ }, { "inputs": [], - "name": "ErrCallerMustBeValidatorContract", + "name": "ErrBonusAlreadySent", "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "ErrContractTypeNotFound", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "uint256", + "name": "currentBalance", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "sendAmount", + "type": "uint256" + } + ], "name": "ErrInsufficientBalance", "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], + "name": "ErrInvalidArguments", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + } + ], "name": "ErrRecipientRevert", "type": "error" }, { - "inputs": [], + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum RoleAccess", + "name": "expectedRole", + "type": "uint8" + } + ], + "name": "ErrUnauthorized", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "bytes4", + "name": "msgSig", + "type": "bytes4" + }, + { + "internalType": "enum ContractType", + "name": "expectedContractType", + "type": "uint8" + }, + { + "internalType": "address", + "name": "actual", + "type": "address" + } + ], + "name": "ErrUnexpectedInternalCall", + "type": "error" + }, + { + "inputs": [ + { + "internalType": "address", + "name": "addr", + "type": "address" + } + ], "name": "ErrZeroCodeContract", "type": "error" }, @@ -124,13 +211,19 @@ "anonymous": false, "inputs": [ { - "indexed": false, - "internalType": "uint8", - "name": "version", + "indexed": true, + "internalType": "enum ContractType", + "name": "contractType", "type": "uint8" + }, + { + "indexed": true, + "internalType": "address", + "name": "addr", + "type": "address" } ], - "name": "Initialized", + "name": "ContractUpdated", "type": "event" }, { @@ -138,12 +231,25 @@ "inputs": [ { "indexed": false, - "internalType": "address", + "internalType": "uint256", "name": "", - "type": "address" + "type": "uint256" } ], - "name": "ValidatorContractUpdated", + "name": "FastFinalityRewardPercentageUpdated", + "type": "event" + }, + { + "anonymous": false, + "inputs": [ + { + "indexed": false, + "internalType": "uint8", + "name": "version", + "type": "uint8" + } + ], + "name": "Initialized", "type": "event" }, { @@ -184,6 +290,38 @@ "stateMutability": "view", "type": "function" }, + { + "inputs": [], + "name": "fastFinalityRewardPercentage", + "outputs": [ + { + "internalType": "uint256", + "name": "", + "type": "uint256" + } + ], + "stateMutability": "view", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + } + ], + "name": "getContract", + "outputs": [ + { + "internalType": "address", + "name": "contract_", + "type": "address" + } + ], + "stateMutability": "view", + "type": "function" + }, { "inputs": [ { @@ -207,6 +345,26 @@ "stateMutability": "payable", "type": "function" }, + { + "inputs": [], + "name": "initializeV2", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, + { + "inputs": [ + { + "internalType": "uint256", + "name": "fastFinalityRewardPercent", + "type": "uint256" + } + ], + "name": "initializeV3", + "outputs": [], + "stateMutability": "nonpayable", + "type": "function" + }, { "inputs": [], "name": "lastBlockSendingBonus", @@ -231,12 +389,12 @@ "inputs": [ { "internalType": "bool", - "name": "_forBlockProducer", + "name": "forBlockProducer", "type": "bool" }, { "internalType": "bool", - "name": "_forBridgeOperator", + "name": "forBridgeOperator", "type": "bool" } ], @@ -244,17 +402,22 @@ "outputs": [ { "internalType": "bool", - "name": "_success", + "name": "success", "type": "bool" }, { "internalType": "uint256", - "name": "_blockProducerBonus", + "name": "blockProducerBonus", + "type": "uint256" + }, + { + "internalType": "uint256", + "name": "bridgeOperatorBonus", "type": "uint256" }, { "internalType": "uint256", - "name": "_bridgeOperatorBonus", + "name": "fastFinalityRewardPercent", "type": "uint256" } ], @@ -289,84 +452,118 @@ }, { "inputs": [ + { + "internalType": "enum ContractType", + "name": "contractType", + "type": "uint8" + }, { "internalType": "address", - "name": "_addr", + "name": "addr", "type": "address" } ], - "name": "setValidatorContract", + "name": "setContract", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { - "inputs": [], - "name": "validatorContract", - "outputs": [ + "inputs": [ { - "internalType": "address", - "name": "", - "type": "address" + "internalType": "uint256", + "name": "percent", + "type": "uint256" } ], - "stateMutability": "view", + "name": "setFastFinalityRewardPercentage", + "outputs": [], + "stateMutability": "nonpayable", "type": "function" } ], - "transactionHash": "0x70f246f2c0919cc0d392fc83cfa3e19300eb13fd51693e31ce057a36a2ca3bbe", + "transactionHash": "0x8eef1f708f13daf2bd48ed062f977cb9c32e6f7385019523f2291ed9afb5e568", "receipt": { "to": null, - "from": "0x0F68eDBE14C8f68481771016d7E2871d6a35DE11", - "contractAddress": "0xf07121671F929d89eA6CaEE8e3D26BD7eD63CFeb", - "transactionIndex": 5, - "gasUsed": "546074", - "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080000000040000800000000000000000000000000000010400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "blockHash": "0xb9428c35fd5ae41ed016062b9feaf739da7fc07e3805012f6335dea0bba03952", - "transactionHash": "0x70f246f2c0919cc0d392fc83cfa3e19300eb13fd51693e31ce057a36a2ca3bbe", + "from": "0x4d58Ea7231c394d5804e8B06B1365915f906E27F", + "contractAddress": "0x7CcBb3CD1b19BC1f1d5B7048400D41B1b796AbAd", + "transactionIndex": 1, + "gasUsed": "757115", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000100000000000000000004000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "blockHash": "0x103957d424393e8436b2d6e8aaecb4f7de09eaf3fca54c1217a6ab7931c7aae3", + "transactionHash": "0x8eef1f708f13daf2bd48ed062f977cb9c32e6f7385019523f2291ed9afb5e568", "logs": [ { - "transactionIndex": 5, - "blockNumber": 22608285, - "transactionHash": "0x70f246f2c0919cc0d392fc83cfa3e19300eb13fd51693e31ce057a36a2ca3bbe", - "address": "0xf07121671F929d89eA6CaEE8e3D26BD7eD63CFeb", + "transactionIndex": 1, + "blockNumber": 28538533, + "transactionHash": "0x8eef1f708f13daf2bd48ed062f977cb9c32e6f7385019523f2291ed9afb5e568", + "address": "0x7CcBb3CD1b19BC1f1d5B7048400D41B1b796AbAd", "topics": [ "0x7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498" ], "data": "0x00000000000000000000000000000000000000000000000000000000000000ff", - "logIndex": 5, - "blockHash": "0xb9428c35fd5ae41ed016062b9feaf739da7fc07e3805012f6335dea0bba03952" + "logIndex": 1, + "blockHash": "0x103957d424393e8436b2d6e8aaecb4f7de09eaf3fca54c1217a6ab7931c7aae3" } ], - "blockNumber": 22608285, - "cumulativeGasUsed": "655114", + "blockNumber": 28538533, + "cumulativeGasUsed": "816543", "status": 1, "byzantium": true }, "args": [], - "numDeployments": 1, - "solcInputHash": "a50a3f056fa24c0b5a230a9cb29a1cb4", - "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrCallerMustBeValidatorContract\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"BlockProducerBonusPerBlockUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"blockNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"blockProducerAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeOperatorAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"BonusTransferFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"blockNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"blockProducerAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeOperatorAmount\",\"type\":\"uint256\"}],\"name\":\"BonusTransferred\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorBonusPerBlockUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"name\":\"ValidatorContractUpdated\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"blockProducerBlockBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"bridgeOperatorBlockBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__blockProducerBonusPerBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__bridgeOperatorBonusPerBlock\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"lastBlockSendingBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"receiveRON\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bool\",\"name\":\"_forBlockProducer\",\"type\":\"bool\"},{\"internalType\":\"bool\",\"name\":\"_forBridgeOperator\",\"type\":\"bool\"}],\"name\":\"requestBonus\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"_success\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"_blockProducerBonus\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"_bridgeOperatorBonus\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"setBlockProducerBonusPerBlock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"setBridgeOperatorBonusPerBlock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"_addr\",\"type\":\"address\"}],\"name\":\"setValidatorContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"validatorContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrCallerMustBeValidatorContract()\":[{\"details\":\"Error of method caller must be validator contract.\"}],\"ErrInsufficientBalance()\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrRecipientRevert()\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrZeroCodeContract()\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"blockProducerBlockBonus(uint256)\":{\"details\":\"Returns the bonus amount for the block producer at `_block`.\"},\"bridgeOperatorBlockBonus(uint256)\":{\"details\":\"Returns the bonus amount for the bridge validator at `_block`.\"},\"initialize(address,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"receiveRON()\":{\"details\":\"Receives RON from any address.\"},\"requestBonus(bool,bool)\":{\"details\":\"Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined. Requirements: - The method caller must be validator contract. - The method must be called only once per block. Emits the event `BonusTransferred` or `BonusTransferFailed`. Notes: - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method will not be reverted, and the underlying nodes does not hang.\",\"params\":{\"_forBlockProducer\":\"Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\",\"_forBridgeOperator\":\"Indicates whether requesting the bonus for the bridge operator.\"},\"returns\":{\"_blockProducerBonus\":\"The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\",\"_bridgeOperatorBonus\":\"The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\",\"_success\":\"Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\"}},\"setBlockProducerBonusPerBlock(uint256)\":{\"details\":\"Sets the bonus amount per block for block producer. Emits the event `BlockProducerBonusPerBlockUpdated`. Requirements: - The method caller is admin.\"},\"setBridgeOperatorBonusPerBlock(uint256)\":{\"details\":\"Sets the bonus amount per block for bridge operator. Emits the event `BridgeOperatorBonusPerBlockUpdated`. Requirements: - The method caller is admin.\"},\"setValidatorContract(address)\":{\"details\":\"Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`.\"},\"validatorContract()\":{\"details\":\"Returns the validator contract.\"}},\"stateVariables\":{\"_blockProducerBonusPerBlock\":{\"details\":\"The block bonus for the block producer whenever a new block is mined.\"},\"_bridgeOperatorBonusPerBlock\":{\"details\":\"The block bonus for the bridge operator whenever a new block is mined.\"},\"lastBlockSendingBonus\":{\"details\":\"The last block number that the staking vesting sent.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/StakingVesting.sol\":\"StakingVesting\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":10},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert();\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance();\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable _recipient, uint256 _amount) internal {\\n if (!_sendRON(_recipient, _amount)) revert ErrRecipientRevert();\\n }\\n\\n /**\\n * @dev Send `_amount` RON to the address `_recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n if (address(this).balance < _amount) revert ErrInsufficientBalance();\\n return _unsafeSendRON(_recipient, _amount);\\n }\\n\\n /**\\n * @dev Unsafe send `_amount` RON to the address `_recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable _recipient, uint256 _amount) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRON(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRON(\\n address payable _recipient,\\n uint256 _amount,\\n uint256 _gas\\n ) internal returns (bool _success) {\\n (_success, ) = _recipient.call{ value: _amount, gas: _gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xbf47d40b2431cf190fa737b803e4cb6fb55aee3f8804470da57a9e340f7914f8\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n require(msg.sender == _getAdmin(), \\\"HasProxyAdmin: unauthorized sender\\\");\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n}\\n\",\"keccak256\":\"0x0c2fcf25290180e8cd733691b113464cdde671dc019e6c343e9eb3e16c6ca24a\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasValidatorContract.sol\\\";\\nimport \\\"../../interfaces/validator/IRoninValidatorSet.sol\\\";\\n\\ncontract HasValidatorContract is IHasValidatorContract, HasProxyAdmin {\\n IRoninValidatorSet internal _validatorContract;\\n\\n modifier onlyValidatorContract() {\\n if (validatorContract() != msg.sender) revert ErrCallerMustBeValidatorContract();\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function validatorContract() public view override returns (address) {\\n return address(_validatorContract);\\n }\\n\\n /**\\n * @inheritdoc IHasValidatorContract\\n */\\n function setValidatorContract(address _addr) external virtual override onlyAdmin {\\n if (_addr.code.length == 0) revert ErrZeroCodeContract();\\n _setValidatorContract(_addr);\\n }\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function _setValidatorContract(address _addr) internal {\\n _validatorContract = IRoninValidatorSet(_addr);\\n emit ValidatorContractUpdated(_addr);\\n }\\n}\\n\",\"keccak256\":\"0xf0a7c4c2165ede118c6ba219ee1a20d293d94049b18aa6fc86a2c48661eb654d\",\"license\":\"MIT\"},\"contracts/interfaces/IStakingVesting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IStakingVesting {\\n /// @dev Emitted when the block bonus for block producer is transferred.\\n event BonusTransferred(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount\\n );\\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\\n event BonusTransferFailed(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the block bonus for block producer is updated\\n event BlockProducerBonusPerBlockUpdated(uint256);\\n /// @dev Emitted when the block bonus for bridge operator is updated\\n event BridgeOperatorBonusPerBlockUpdated(uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the block producer at `_block`.\\n */\\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the bridge validator at `_block`.\\n */\\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Receives RON from any address.\\n */\\n function receiveRON() external payable;\\n\\n /**\\n * @dev Returns the last block number that the staking vesting is sent.\\n */\\n function lastBlockSendingBonus() external view returns (uint256);\\n\\n /**\\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n * - The method must be called only once per block.\\n *\\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\\n *\\n * Notes:\\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\\n * will not be reverted, and the underlying nodes does not hang.\\n *\\n * @param _forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\\n * @param _forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\\n *\\n * @return _success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\\n * @return _blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\\n * @return _bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\\n *\\n */\\n function requestBonus(bool _forBlockProducer, bool _forBridgeOperator)\\n external\\n returns (\\n bool _success,\\n uint256 _blockProducerBonus,\\n uint256 _bridgeOperatorBonus\\n );\\n\\n /**\\n * @dev Sets the bonus amount per block for block producer.\\n *\\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\\n\\n /**\\n * @dev Sets the bonus amount per block for bridge operator.\\n *\\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\\n}\\n\",\"keccak256\":\"0x6705fdccf03c4acd34ceb1034c2ab556c901781d6d5597e63f257eafe75cf1ae\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IHasContract {\\n /// @dev Error of set to non-contract.\\n error ErrZeroCodeContract();\\n}\\n\",\"keccak256\":\"0x8a17785d841137fcae5b5d542f1714de0492c85b54ca074f0b9c1c490ad3f342\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasValidatorContract.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IHasContract.sol\\\";\\n\\ninterface IHasValidatorContract is IHasContract {\\n /// @dev Emitted when the validator contract is updated.\\n event ValidatorContractUpdated(address);\\n\\n /// @dev Error of method caller must be validator contract.\\n error ErrCallerMustBeValidatorContract();\\n\\n /**\\n * @dev Returns the validator contract.\\n */\\n function validatorContract() external view returns (address);\\n\\n /**\\n * @dev Sets the validator contract.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n * - The new address is a contract.\\n *\\n * Emits the event `ValidatorContractUpdated`.\\n *\\n */\\n function setValidatorContract(address) external;\\n}\\n\",\"keccak256\":\"0x35a715f123b0c5dc296d13583f946bef4e485201e122b5170988a7535f114559\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICandidateManager.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ICandidateManager {\\n struct ValidatorCandidate {\\n // Admin of the candidate\\n address admin;\\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\\n address consensusAddr;\\n // Address that receives mining reward of the validator\\n address payable treasuryAddr;\\n // Address of the bridge operator corresponding to the candidate\\n address bridgeOperatorAddr;\\n // The percentage of reward that validators can be received, the rest goes to the delegators.\\n // Values in range [0; 100_00] stands for 0-100%\\n uint256 commissionRate;\\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\\n uint256 revokingTimestamp;\\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\\n uint256 topupDeadline;\\n }\\n\\n struct CommissionSchedule {\\n // The timestamp that the commission schedule gets affected (no schedule=0).\\n uint256 effectiveTimestamp;\\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\\n uint256 commissionRate;\\n }\\n\\n /// @dev Emitted when the maximum number of validator candidates is updated.\\n event MaxValidatorCandidateUpdated(uint256 threshold);\\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\\n /// @dev Emitted when the validator candidate is granted.\\n event CandidateGranted(\\n address indexed consensusAddr,\\n address indexed treasuryAddr,\\n address indexed admin,\\n address bridgeOperator\\n );\\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\\n /// @dev Emitted when the topup deadline of a candidate is updated.\\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\\n /// @dev Emitted when the validator candidate is revoked.\\n event CandidatesRevoked(address[] consensusAddrs);\\n\\n /// @dev Emitted when a schedule for updating commission rate is set.\\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\\n /// @dev Emitted when the commission rate of a validator is updated.\\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\\n\\n /// @dev Error of exceeding maximum number of candidates.\\n error ErrExceedsMaxNumberOfCandidate();\\n /// @dev Error of querying for already existent candidate.\\n error ErrExistentCandidate();\\n /// @dev Error of querying for non-existent candidate.\\n error ErrNonExistentCandidate();\\n /// @dev Error of candidate admin already exists.\\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\\n /// @dev Error of treasury already exists.\\n error ErrExistentTreasury(address _treasuryAddr);\\n /// @dev Error of bridge operator already exists.\\n error ErrExistentBridgeOperator(address _bridgeOperatorAddr);\\n /// @dev Error of invalid commission rate.\\n error ErrInvalidCommissionRate();\\n /// @dev Error of invalid effective days onwards.\\n error ErrInvalidEffectiveDaysOnwards();\\n /// @dev Error of invalid min effective days onwards.\\n error ErrInvalidMinEffectiveDaysOnwards();\\n /// @dev Error of already requested revoking candidate before.\\n error ErrAlreadyRequestedRevokingCandidate();\\n /// @dev Error of commission change schedule exists.\\n error ErrAlreadyRequestedUpdatingCommissionRate();\\n /// @dev Error of trusted org cannot renounce.\\n error ErrTrustedOrgCannotRenounce();\\n\\n /**\\n * @dev Returns the maximum number of validator candidate.\\n */\\n function maxValidatorCandidate() external view returns (uint256);\\n\\n /**\\n * @dev Returns the minimum number of days to the effective date of commission rate change.\\n */\\n function minEffectiveDaysOnwards() external view returns (uint256);\\n\\n /**\\n * @dev Sets the maximum number of validator candidate.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MaxValidatorCandidateUpdated` event.\\n *\\n */\\n function setMaxValidatorCandidate(uint256) external;\\n\\n /**\\n * @dev Sets the minimum number of days to the effective date of commision rate change.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\\n *\\n */\\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\\n\\n /**\\n * @dev Grants a validator candidate.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateGranted`.\\n *\\n */\\n function execApplyValidatorCandidate(\\n address _admin,\\n address _consensusAddr,\\n address payable _treasuryAddr,\\n address _bridgeOperatorAddr,\\n uint256 _commissionRate\\n ) external;\\n\\n /**\\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n * Emits the event `CandidateRevokingTimestampUpdated`.\\n *\\n */\\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\\n\\n /**\\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\\n *\\n * Requirements:\\n * - The method caller is the staking contract.\\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\\n * - The `_rate` must be in range of [0_00; 100_00].\\n *\\n * Emits the event `CommissionRateUpdateScheduled`.\\n *\\n */\\n function execRequestUpdateCommissionRate(\\n address _consensusAddr,\\n uint256 _effectiveTimestamp,\\n uint256 _rate\\n ) external;\\n\\n /**\\n * @dev Returns whether the address is a validator (candidate).\\n */\\n function isValidatorCandidate(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the validator candidate.\\n */\\n function getValidatorCandidates() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns all candidate info.\\n */\\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\\n\\n /**\\n * @dev Returns the info of a candidate.\\n */\\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\\n\\n /**\\n * @dev Returns whether the address is the candidate admin.\\n */\\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\\n\\n /**\\n * @dev Returns the schedule of changing commission rate of a candidate address.\\n */\\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\\n}\\n\",\"keccak256\":\"0xc382bd50ca507308ec23826308bc9ff0a22cfb9b3fcd09c7ac7a63c37729d33e\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ICoinbaseExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ISlashingExecution.sol\\\";\\n\\ninterface ICoinbaseExecution is ISlashingExecution {\\n enum BlockRewardDeprecatedType {\\n UNKNOWN,\\n UNAVAILABILITY,\\n AFTER_BAILOUT\\n }\\n\\n /// @dev Emitted when the validator set is updated\\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\\n /// @dev Emitted when the bridge operator set is updated.\\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\\n\\n /// @dev Emitted when the reward of the block producer is deprecated.\\n event BlockRewardDeprecated(\\n address indexed coinbaseAddr,\\n uint256 rewardAmount,\\n BlockRewardDeprecatedType deprecatedType\\n );\\n /// @dev Emitted when the block reward is submitted.\\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\\n\\n /// @dev Emitted when the block producer reward is distributed.\\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\\n /// @dev Emitted when the contract fails when distributing the block producer reward.\\n event MiningRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the bridge operator reward is distributed.\\n event BridgeOperatorRewardDistributed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipientAddr,\\n uint256 amount\\n );\\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\\n event BridgeOperatorRewardDistributionFailed(\\n address indexed consensusAddr,\\n address indexed bridgeOperator,\\n address indexed recipient,\\n uint256 amount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\\n event StakingRewardDistributionFailed(\\n uint256 totalAmount,\\n address[] consensusAddrs,\\n uint256[] amounts,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the epoch is wrapped up.\\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\\n /// @dev Emitted when the bridge tracking contract's response is incorrect\\n event BridgeTrackingIncorrectlyResponded();\\n\\n /// @dev Error of method caller must be coinbase\\n error ErrCallerMustBeCoinbase();\\n /// @dev Error of only allowed at the end of epoch\\n error ErrAtEndOfEpochOnly();\\n /// @dev Error of query for already wrapped up epoch\\n error ErrAlreadyWrappedEpoch();\\n\\n /**\\n * @dev Submits reward of the current block.\\n *\\n * Requirements:\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\\n * Emits the event `BlockRewardSubmitted` for the valid call.\\n *\\n */\\n function submitBlockReward() external payable;\\n\\n /**\\n * @dev Wraps up the current epoch.\\n *\\n * Requirements:\\n * - The method must be called when the current epoch is ending.\\n * - The epoch is not wrapped yet.\\n * - The method caller is coinbase.\\n *\\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\\n * Emits the event `WrappedUpEpoch`.\\n *\\n */\\n function wrapUpEpoch() external payable;\\n}\\n\",\"keccak256\":\"0x42ed0bff5f8233dc6de28bd3283f98a0c16df6abc26655fc777bdc07a83ff3f5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IEmergencyExit.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IEmergencyExit {\\n /// @dev Emitted when the fund is locked from an emergency exit request\\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\\n event EmergencyExitLockedFundReleased(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount\\n );\\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\\n event EmergencyExitLockedFundReleasingFailed(\\n address indexed consensusAddr,\\n address indexed recipient,\\n uint256 unlockedAmount,\\n uint256 contractBalance\\n );\\n\\n /// @dev Emitted when the emergency exit locked amount is updated.\\n event EmergencyExitLockedAmountUpdated(uint256 amount);\\n /// @dev Emitted when the emergency expiry duration is updated.\\n event EmergencyExpiryDurationUpdated(uint256 amount);\\n\\n /// @dev Error of already requested emergency exit before.\\n error ErrAlreadyRequestedEmergencyExit();\\n\\n /**\\n * @dev Returns the amount of RON to lock from a consensus address.\\n */\\n function emergencyExitLockedAmount() external returns (uint256);\\n\\n /**\\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\\n */\\n function emergencyExpiryDuration() external returns (uint256);\\n\\n /**\\n * @dev Sets the amount of RON to lock from a consensus address.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedAmountUpdated`.\\n *\\n */\\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\\n\\n /**\\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExpiryDurationUpdated`.\\n *\\n */\\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\\n\\n /**\\n * @dev Unlocks fund for emergency exit request.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\\n *\\n */\\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\\n\\n /**\\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\\n *\\n * Requirements:\\n * - The method caller is staking contract.\\n *\\n */\\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\\n}\\n\",\"keccak256\":\"0x45161abd1e3db83052a06889a0e3a7a5e7ee3306478601d58ac4ed32ccaa75ad\",\"license\":\"MIT\"},\"contracts/interfaces/validator/IRoninValidatorSet.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./ICandidateManager.sol\\\";\\nimport \\\"./info-fragments/ICommonInfo.sol\\\";\\nimport \\\"./ICoinbaseExecution.sol\\\";\\nimport \\\"./ISlashingExecution.sol\\\";\\nimport \\\"./IEmergencyExit.sol\\\";\\n\\ninterface IRoninValidatorSet is\\n ICandidateManager,\\n ICommonInfo,\\n ISlashingExecution,\\n ICoinbaseExecution,\\n IEmergencyExit\\n{}\\n\",\"keccak256\":\"0x813f34747aea4dfb53bbc147abf8dbe5999ce73111c2db99bcb3efb4cf75bb3d\",\"license\":\"MIT\"},\"contracts/interfaces/validator/ISlashingExecution.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ISlashingExecution {\\n /// @dev Emitted when the validator is punished.\\n event ValidatorPunished(\\n address indexed consensusAddr,\\n uint256 indexed period,\\n uint256 jailedUntil,\\n uint256 deductedStakingAmount,\\n bool blockProducerRewardDeprecated,\\n bool bridgeOperatorRewardDeprecated\\n );\\n /// @dev Emitted when the validator get out of jail by bailout.\\n event ValidatorUnjailed(address indexed validator, uint256 period);\\n\\n /// @dev Error of cannot bailout due to high tier slash.\\n error ErrCannotBailout(address validator);\\n\\n /**\\n * @dev Finalize the slash request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorPunished`.\\n *\\n */\\n function execSlash(\\n address _validatorAddr,\\n uint256 _newJailedUntil,\\n uint256 _slashAmount,\\n bool _cannotBailout\\n ) external;\\n\\n /**\\n * @dev Finalize the bailout request from slash indicator contract.\\n *\\n * Requirements:\\n * - The method caller is slash indicator contract.\\n *\\n * Emits the event `ValidatorUnjailed`.\\n *\\n */\\n function execBailOut(address _validatorAddr, uint256 _period) external;\\n}\\n\",\"keccak256\":\"0x80362c42fdc0ee06543a2abbffee961fe51c15a7c5e18933a9c34897e50d07fe\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ICommonInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"./IJailingInfo.sol\\\";\\nimport \\\"./ITimingInfo.sol\\\";\\nimport \\\"./IValidatorInfo.sol\\\";\\n\\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfo {\\n struct EmergencyExitInfo {\\n uint256 lockedAmount;\\n // The timestamp that this locked amount will be recycled to staking vesting contract\\n uint256 recyclingAt;\\n }\\n\\n /// @dev Emitted when the deprecated reward is withdrawn.\\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\\n /// @dev Emitted when the deprecated reward withdrawal is failed\\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\\n\\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\\n error ErrUnauthorizedReceiveRON();\\n /// @dev Error thrown when queries for a non existent info.\\n error NonExistentRecyclingInfo();\\n\\n /**\\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\\n */\\n function totalDeprecatedReward() external view returns (uint256);\\n\\n /**\\n * @dev Returns the emergency exit request.\\n */\\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\\n}\\n\",\"keccak256\":\"0xc00b1bda0c6076c9aa0631dc0c01e849d8f42cc616fe4c036f73cda0a9afe9ef\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IJailingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IJailingInfo {\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkJailed(address) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeft(address _addr)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\\n */\\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\\n */\\n function getJailedTimeLeftAtBlock(address _addr, uint256 _blockNum)\\n external\\n view\\n returns (\\n bool isJailed_,\\n uint256 blockLeft_,\\n uint256 epochLeft_\\n );\\n\\n /**\\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\\n */\\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\\n */\\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\\n */\\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the latest wrapped up period.\\n */\\n function checkBridgeRewardDeprecatedAtLatestPeriod(address _consensusAddr) external view returns (bool _result);\\n\\n /**\\n * @dev Returns whether the incoming reward of the validator with `_consensusAddr` is deprecated in the `_period`.\\n */\\n function checkBridgeRewardDeprecatedAtPeriod(address _consensusAddr, uint256 _period)\\n external\\n view\\n returns (bool _result);\\n}\\n\",\"keccak256\":\"0x19b85ce95caf9deb4aff9614d1ca2d89712b89e8609dc6ab772e989164a51139\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/ITimingInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface ITimingInfo {\\n /**\\n * @dev Returns the block that validator set was updated.\\n */\\n function getLastUpdatedBlock() external view returns (uint256);\\n\\n /**\\n * @dev Returns the number of blocks in a epoch.\\n */\\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\\n\\n /**\\n * @dev Returns the epoch index from the block number.\\n */\\n function epochOf(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns whether the epoch ending is at the block number `_block`.\\n */\\n function epochEndingAt(uint256 _block) external view returns (bool);\\n\\n /**\\n * @dev Tries to get the period index from the epoch number.\\n */\\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\\n\\n /**\\n * @dev Returns whether the period ending at the current block number.\\n */\\n function isPeriodEnding() external view returns (bool);\\n\\n /**\\n * @dev Returns the period index from the current block.\\n */\\n function currentPeriod() external view returns (uint256);\\n\\n /**\\n * @dev Returns the block number that the current period starts at.\\n */\\n function currentPeriodStartAtBlock() external view returns (uint256);\\n}\\n\",\"keccak256\":\"0x77b86a68149389fed0eb0c5b8d56f278d3bd103ba64f504697d709b24c3212d5\",\"license\":\"MIT\"},\"contracts/interfaces/validator/info-fragments/IValidatorInfo.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"../../../libraries/EnumFlags.sol\\\";\\n\\ninterface IValidatorInfo {\\n /// @dev Emitted when the number of max validator is updated.\\n event MaxValidatorNumberUpdated(uint256);\\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\\n event MaxPrioritizedValidatorNumberUpdated(uint256);\\n\\n /// @dev Error of number of prioritized greater than number of max validators.\\n error ErrInvalidMaxPrioritizedValidatorNumber();\\n\\n /**\\n * @dev Returns the maximum number of validators in the epoch.\\n */\\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\\n\\n /**\\n * @dev Returns the number of reserved slots for prioritized validators.\\n */\\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\\n\\n /**\\n * @dev Returns the current validator list.\\n */\\n function getValidators()\\n external\\n view\\n returns (\\n address[] memory _validatorList,\\n address[] memory _bridgeOperators,\\n EnumFlags.ValidatorFlag[] memory _flags\\n );\\n\\n /**\\n * @dev Returns whether the address is either a bridge operator or a block producer.\\n */\\n function isValidator(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns the current block producer list.\\n */\\n function getBlockProducers() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is block producer or not.\\n */\\n function isBlockProducer(address _addr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the block producers.\\n */\\n function totalBlockProducers() external view returns (uint256);\\n\\n /**\\n * @dev Returns the current bridge operator list.\\n */\\n function getBridgeOperators() external view returns (address[] memory);\\n\\n /**\\n * @dev Returns the bridge operator list corresponding to validator address list.\\n */\\n function getBridgeOperatorsOf(address[] memory _validatorAddrs) external view returns (address[] memory);\\n\\n /**\\n * @dev Returns whether the address is bridge operator.\\n */\\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\\n\\n /**\\n * @dev Returns whether the consensus address is operating the bridge or not.\\n */\\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\\n\\n /**\\n * @dev Returns total numbers of the bridge operators.\\n */\\n function totalBridgeOperators() external view returns (uint256);\\n\\n /**\\n * @dev Updates the max validator number\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxValidatorNumberUpdated`\\n *\\n */\\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\\n\\n /**\\n * @dev Updates the number of reserved slots for prioritized validators\\n *\\n * Requirements:\\n * - The method caller is admin\\n *\\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\\n *\\n */\\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\\n}\\n\",\"keccak256\":\"0x86189a2fee2e5dccba27728db15e1bd19f647cdb97c02b52d9ab07c5d98a2a75\",\"license\":\"MIT\"},\"contracts/libraries/EnumFlags.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This library implements checking flag of an enumerated value.\\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\\n */\\nlibrary EnumFlags {\\n enum ValidatorFlag {\\n None, // bit(00)\\n BlockProducer, // bit(01)\\n BridgeOperator, // bit(10)\\n Both // bit(11)\\n }\\n\\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\\n return uint8(_value) == 0;\\n }\\n\\n /**\\n * @dev Checks if `_value` has `_flag`.\\n */\\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\\n return (uint8(_value) & uint8(_flag)) != 0;\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after adding `_flag`.\\n */\\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) | uint8(_flag));\\n }\\n\\n /**\\n * @dev Calculate new value of `_value` after remove `_flag`.\\n */\\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\\n }\\n}\\n\",\"keccak256\":\"0xa6c77f9d704c57854a30e57e16467a1b70b76be5331d9e53a3f9ec5e57542533\",\"license\":\"UNLICENSED\"},\"contracts/ronin/StakingVesting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../interfaces/IStakingVesting.sol\\\";\\nimport \\\"../extensions/collections/HasValidatorContract.sol\\\";\\nimport \\\"../extensions/RONTransferHelper.sol\\\";\\n\\ncontract StakingVesting is IStakingVesting, HasValidatorContract, RONTransferHelper, Initializable {\\n /// @dev The block bonus for the block producer whenever a new block is mined.\\n uint256 internal _blockProducerBonusPerBlock;\\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\\n uint256 internal _bridgeOperatorBonusPerBlock;\\n /// @dev The last block number that the staking vesting sent.\\n uint256 public lastBlockSendingBonus;\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 __blockProducerBonusPerBlock,\\n uint256 __bridgeOperatorBonusPerBlock\\n ) external payable initializer {\\n _setValidatorContract(__validatorContract);\\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function receiveRON() external payable {}\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function blockProducerBlockBonus(\\n uint256 /* _block */\\n ) public view override returns (uint256) {\\n return _blockProducerBonusPerBlock;\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function bridgeOperatorBlockBonus(\\n uint256 /* _block */\\n ) public view override returns (uint256) {\\n return _bridgeOperatorBonusPerBlock;\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function requestBonus(bool _forBlockProducer, bool _forBridgeOperator)\\n external\\n override\\n onlyValidatorContract\\n returns (\\n bool _success,\\n uint256 _blockProducerBonus,\\n uint256 _bridgeOperatorBonus\\n )\\n {\\n require(block.number > lastBlockSendingBonus, \\\"StakingVesting: bonus for already sent\\\");\\n lastBlockSendingBonus = block.number;\\n\\n _blockProducerBonus = _forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\\n _bridgeOperatorBonus = _forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\\n\\n uint256 _totalAmount = _blockProducerBonus + _bridgeOperatorBonus;\\n\\n if (_totalAmount > 0) {\\n address payable _validatorContractAddr = payable(validatorContract());\\n\\n _success = _unsafeSendRON(_validatorContractAddr, _totalAmount);\\n\\n if (!_success) {\\n emit BonusTransferFailed(\\n block.number,\\n _validatorContractAddr,\\n _blockProducerBonus,\\n _bridgeOperatorBonus,\\n address(this).balance\\n );\\n return (_success, 0, 0);\\n }\\n\\n emit BonusTransferred(block.number, _validatorContractAddr, _blockProducerBonus, _bridgeOperatorBonus);\\n }\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\\n _setBlockProducerBonusPerBlock(_amount);\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\\n _setBridgeOperatorBonusPerBlock(_amount);\\n }\\n\\n /**\\n * @dev Sets the bonus amount per block for block producer.\\n *\\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\\n *\\n */\\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\\n _blockProducerBonusPerBlock = _amount;\\n emit BlockProducerBonusPerBlockUpdated(_amount);\\n }\\n\\n /**\\n * @dev Sets the bonus amount per block for bridge operator.\\n *\\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\\n *\\n */\\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\\n _bridgeOperatorBonusPerBlock = _amount;\\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\\n }\\n}\\n\",\"keccak256\":\"0x4276fc004a6e0f6ab87b302aba515b8286b5512ca0e1c3a0360173e7cebeec63\",\"license\":\"MIT\"}},\"version\":1}", - "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600054600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff600160a01b909104811610156100e9576000805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61086d806100fa6000396000f3fe6080604052600436106100815760003560e01c80630634f5b9146100865780630d9160e7146100c857806359f778df146100ec57806367e9941c146100ee5780637a1ac61e1461010e5780639943908914610121578063cdf64a7614610143578063d8209d0714610163578063f13ba64414610185578063fa8674a1146101a5575b600080fd5b34801561009257600080fd5b506100a66100a1366004610702565b6101c7565b6040805193151584526020840192909252908201526060015b60405180910390f35b3480156100d457600080fd5b506100de60035481565b6040519081526020016100bf565b005b3480156100fa57600080fd5b506100ec610109366004610735565b610365565b6100ec61011c366004610765565b6103a9565b34801561012d57600080fd5b506101366104eb565b6040516100bf9190610798565b34801561014f57600080fd5b506100ec61015e3660046107ac565b6104fa565b34801561016f57600080fd5b506100de61017e366004610735565b5060015490565b34801561019157600080fd5b506100ec6101a0366004610735565b610566565b3480156101b157600080fd5b506100de6101c0366004610735565b5060025490565b60008080336101d46104eb565b6001600160a01b0316146101fb57604051630e6444a160e31b815260040160405180910390fd5b60035443116102605760405162461bcd60e51b815260206004820152602660248201527f5374616b696e6756657374696e673a20626f6e757320666f7220616c726561646044820152651e481cd95b9d60d21b60648201526084015b60405180910390fd5b4360035584610270576000610274565b6001545b915083610282576000610286565b6002545b9050600061029482846107ce565b9050801561035c5760006102a66104eb565b90506102b281836105a7565b945084610314576040805185815260208101859052478183015290516001600160a01b0383169143917f137e697384eeada9cf7614b88e4ac940aeff18d0fef7e86bce1abdc812b95e099181900360600190a3506000925082915061035e9050565b60408051858152602081018590526001600160a01b0383169143917f60200441f885b45b3b7f1fdc45a47bb0d0a0884a6a17722f8dd7232830de9bd2910160405180910390a3505b505b9250925092565b61036d610603565b6001600160a01b0316336001600160a01b03161461039d5760405162461bcd60e51b8152600401610257906107f5565b6103a681610631565b50565b600054600160a81b900460ff16158080156103d157506000546001600160a01b90910460ff16105b806103f25750303b1580156103f25750600054600160a01b900460ff166001145b6104555760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610257565b6000805460ff60a01b1916600160a01b1790558015610482576000805460ff60a81b1916600160a81b1790555b61048b8461066d565b610494836106b8565b61049d82610631565b80156104e5576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b6000546001600160a01b031690565b610502610603565b6001600160a01b0316336001600160a01b0316146105325760405162461bcd60e51b8152600401610257906107f5565b806001600160a01b03163b60000361055d57604051637bcd509160e01b815260040160405180910390fd5b6103a68161066d565b61056e610603565b6001600160a01b0316336001600160a01b03161461059e5760405162461bcd60e51b8152600401610257906107f5565b6103a6816106b8565b6000826001600160a01b03168260405160006040518083038185875af1925050503d80600081146105f4576040519150601f19603f3d011682016040523d82523d6000602084013e6105f9565b606091505b5090949350505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b60028190556040518181527f57a23b4b11f619fb9dea21a5a8115bb90103c1043eb3318d773558829d25f12c906020015b60405180910390a150565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b683616990610662908390610798565b60018190556040518181527f861f03c645467325a586235bb3155834f1dddf12413d0a802f416eb6d4035e6d90602001610662565b803580151581146106fd57600080fd5b919050565b6000806040838503121561071557600080fd5b61071e836106ed565b915061072c602084016106ed565b90509250929050565b60006020828403121561074757600080fd5b5035919050565b80356001600160a01b03811681146106fd57600080fd5b60008060006060848603121561077a57600080fd5b6107838461074e565b95602085013595506040909401359392505050565b6001600160a01b0391909116815260200190565b6000602082840312156107be57600080fd5b6107c78261074e565b9392505050565b808201808211156107ef57634e487b7160e01b600052601160045260246000fd5b92915050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b60608201526080019056fea2646970667358221220b345fe7b21a326c505620c829a22364ed6c5c78193d7823706c9e440c45c338f64736f6c63430008110033", - "deployedBytecode": "0x6080604052600436106100815760003560e01c80630634f5b9146100865780630d9160e7146100c857806359f778df146100ec57806367e9941c146100ee5780637a1ac61e1461010e5780639943908914610121578063cdf64a7614610143578063d8209d0714610163578063f13ba64414610185578063fa8674a1146101a5575b600080fd5b34801561009257600080fd5b506100a66100a1366004610702565b6101c7565b6040805193151584526020840192909252908201526060015b60405180910390f35b3480156100d457600080fd5b506100de60035481565b6040519081526020016100bf565b005b3480156100fa57600080fd5b506100ec610109366004610735565b610365565b6100ec61011c366004610765565b6103a9565b34801561012d57600080fd5b506101366104eb565b6040516100bf9190610798565b34801561014f57600080fd5b506100ec61015e3660046107ac565b6104fa565b34801561016f57600080fd5b506100de61017e366004610735565b5060015490565b34801561019157600080fd5b506100ec6101a0366004610735565b610566565b3480156101b157600080fd5b506100de6101c0366004610735565b5060025490565b60008080336101d46104eb565b6001600160a01b0316146101fb57604051630e6444a160e31b815260040160405180910390fd5b60035443116102605760405162461bcd60e51b815260206004820152602660248201527f5374616b696e6756657374696e673a20626f6e757320666f7220616c726561646044820152651e481cd95b9d60d21b60648201526084015b60405180910390fd5b4360035584610270576000610274565b6001545b915083610282576000610286565b6002545b9050600061029482846107ce565b9050801561035c5760006102a66104eb565b90506102b281836105a7565b945084610314576040805185815260208101859052478183015290516001600160a01b0383169143917f137e697384eeada9cf7614b88e4ac940aeff18d0fef7e86bce1abdc812b95e099181900360600190a3506000925082915061035e9050565b60408051858152602081018590526001600160a01b0383169143917f60200441f885b45b3b7f1fdc45a47bb0d0a0884a6a17722f8dd7232830de9bd2910160405180910390a3505b505b9250925092565b61036d610603565b6001600160a01b0316336001600160a01b03161461039d5760405162461bcd60e51b8152600401610257906107f5565b6103a681610631565b50565b600054600160a81b900460ff16158080156103d157506000546001600160a01b90910460ff16105b806103f25750303b1580156103f25750600054600160a01b900460ff166001145b6104555760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610257565b6000805460ff60a01b1916600160a01b1790558015610482576000805460ff60a81b1916600160a81b1790555b61048b8461066d565b610494836106b8565b61049d82610631565b80156104e5576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b6000546001600160a01b031690565b610502610603565b6001600160a01b0316336001600160a01b0316146105325760405162461bcd60e51b8152600401610257906107f5565b806001600160a01b03163b60000361055d57604051637bcd509160e01b815260040160405180910390fd5b6103a68161066d565b61056e610603565b6001600160a01b0316336001600160a01b03161461059e5760405162461bcd60e51b8152600401610257906107f5565b6103a6816106b8565b6000826001600160a01b03168260405160006040518083038185875af1925050503d80600081146105f4576040519150601f19603f3d011682016040523d82523d6000602084013e6105f9565b606091505b5090949350505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b60028190556040518181527f57a23b4b11f619fb9dea21a5a8115bb90103c1043eb3318d773558829d25f12c906020015b60405180910390a150565b600080546001600160a01b0319166001600160a01b0383161790556040517fef40dc07567635f84f5edbd2f8dbc16b40d9d282dd8e7e6f4ff58236b683616990610662908390610798565b60018190556040518181527f861f03c645467325a586235bb3155834f1dddf12413d0a802f416eb6d4035e6d90602001610662565b803580151581146106fd57600080fd5b919050565b6000806040838503121561071557600080fd5b61071e836106ed565b915061072c602084016106ed565b90509250929050565b60006020828403121561074757600080fd5b5035919050565b80356001600160a01b03811681146106fd57600080fd5b60008060006060848603121561077a57600080fd5b6107838461074e565b95602085013595506040909401359392505050565b6001600160a01b0391909116815260200190565b6000602082840312156107be57600080fd5b6107c78261074e565b9392505050565b808201808211156107ef57634e487b7160e01b600052601160045260246000fd5b92915050565b60208082526022908201527f48617350726f787941646d696e3a20756e617574686f72697a65642073656e6460408201526132b960f11b60608201526080019056fea2646970667358221220b345fe7b21a326c505620c829a22364ed6c5c78193d7823706c9e440c45c338f64736f6c63430008110033", + "numDeployments": 2, + "solcInputHash": "0e13282b1de32a862f3ea9c3dc0543e9", + "metadata": "{\"compiler\":{\"version\":\"0.8.17+commit.8df45f5f\"},\"language\":\"Solidity\",\"output\":{\"abi\":[{\"inputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"inputs\":[],\"name\":\"ErrBonusAlreadySent\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"ErrContractTypeNotFound\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"uint256\",\"name\":\"currentBalance\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"sendAmount\",\"type\":\"uint256\"}],\"name\":\"ErrInsufficientBalance\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrInvalidArguments\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"}],\"name\":\"ErrRecipientRevert\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum RoleAccess\",\"name\":\"expectedRole\",\"type\":\"uint8\"}],\"name\":\"ErrUnauthorized\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"bytes4\",\"name\":\"msgSig\",\"type\":\"bytes4\"},{\"internalType\":\"enum ContractType\",\"name\":\"expectedContractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"actual\",\"type\":\"address\"}],\"name\":\"ErrUnexpectedInternalCall\",\"type\":\"error\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ErrZeroCodeContract\",\"type\":\"error\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"BlockProducerBonusPerBlockUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"blockNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"blockProducerAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeOperatorAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"contractBalance\",\"type\":\"uint256\"}],\"name\":\"BonusTransferFailed\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"uint256\",\"name\":\"blockNumber\",\"type\":\"uint256\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"recipient\",\"type\":\"address\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"blockProducerAmount\",\"type\":\"uint256\"},{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"bridgeOperatorAmount\",\"type\":\"uint256\"}],\"name\":\"BonusTransferred\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"BridgeOperatorBonusPerBlockUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"indexed\":true,\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"ContractUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"FastFinalityRewardPercentageUpdated\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"internalType\":\"uint8\",\"name\":\"version\",\"type\":\"uint8\"}],\"name\":\"Initialized\",\"type\":\"event\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"blockProducerBlockBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"bridgeOperatorBlockBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"fastFinalityRewardPercentage\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"}],\"name\":\"getContract\",\"outputs\":[{\"internalType\":\"address\",\"name\":\"contract_\",\"type\":\"address\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"address\",\"name\":\"__validatorContract\",\"type\":\"address\"},{\"internalType\":\"uint256\",\"name\":\"__blockProducerBonusPerBlock\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"__bridgeOperatorBonusPerBlock\",\"type\":\"uint256\"}],\"name\":\"initialize\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"initializeV2\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"fastFinalityRewardPercent\",\"type\":\"uint256\"}],\"name\":\"initializeV3\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"lastBlockSendingBonus\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[],\"name\":\"receiveRON\",\"outputs\":[],\"stateMutability\":\"payable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"bool\",\"name\":\"forBlockProducer\",\"type\":\"bool\"},{\"internalType\":\"bool\",\"name\":\"forBridgeOperator\",\"type\":\"bool\"}],\"name\":\"requestBonus\",\"outputs\":[{\"internalType\":\"bool\",\"name\":\"success\",\"type\":\"bool\"},{\"internalType\":\"uint256\",\"name\":\"blockProducerBonus\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"bridgeOperatorBonus\",\"type\":\"uint256\"},{\"internalType\":\"uint256\",\"name\":\"fastFinalityRewardPercent\",\"type\":\"uint256\"}],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"setBlockProducerBonusPerBlock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"_amount\",\"type\":\"uint256\"}],\"name\":\"setBridgeOperatorBonusPerBlock\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"enum ContractType\",\"name\":\"contractType\",\"type\":\"uint8\"},{\"internalType\":\"address\",\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setContract\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"percent\",\"type\":\"uint256\"}],\"name\":\"setFastFinalityRewardPercentage\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}],\"devdoc\":{\"errors\":{\"ErrBonusAlreadySent()\":[{\"details\":\"Error thrown when attempting to send a bonus that has already been sent.\"}],\"ErrContractTypeNotFound(uint8)\":[{\"details\":\"Error of invalid role.\"}],\"ErrInsufficientBalance(bytes4,uint256,uint256)\":[{\"details\":\"Error of sender has insufficient balance.\"}],\"ErrInvalidArguments(bytes4)\":[{\"details\":\"Error indicating that arguments are invalid.\"}],\"ErrRecipientRevert(bytes4)\":[{\"details\":\"Error of recipient not accepting RON when transfer RON.\"}],\"ErrUnauthorized(bytes4,uint8)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"expectedRole\":\"The role required to perform the function.\",\"msgSig\":\"The function signature (bytes4) that the caller is unauthorized to perform.\"}}],\"ErrUnexpectedInternalCall(bytes4,uint8,address)\":[{\"details\":\"Error indicating that the caller is unauthorized to perform a specific function.\",\"params\":{\"actual\":\"The actual address that called to the function.\",\"expectedContractType\":\"The contract type required to perform the function.\",\"msgSig\":\"The function signature (bytes4).\"}}],\"ErrZeroCodeContract(address)\":[{\"details\":\"Error of set to non-contract.\"}]},\"kind\":\"dev\",\"methods\":{\"blockProducerBlockBonus(uint256)\":{\"details\":\"Returns the bonus amount for the block producer at `_block`.\"},\"bridgeOperatorBlockBonus(uint256)\":{\"details\":\"Returns the bonus amount for the bridge validator at `_block`.\"},\"fastFinalityRewardPercentage()\":{\"details\":\"Returns the percentage of fast finality reward.\"},\"getContract(uint8)\":{\"details\":\"Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.\",\"params\":{\"contractType\":\"The role of the contract to retrieve.\"},\"returns\":{\"contract_\":\"The address of the contract with the specified role.\"}},\"initialize(address,uint256,uint256)\":{\"details\":\"Initializes the contract storage.\"},\"receiveRON()\":{\"details\":\"Receives RON from any address.\"},\"requestBonus(bool,bool)\":{\"details\":\"Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined. Requirements: - The method caller must be validator contract. - The method must be called only once per block. Emits the event `BonusTransferred` or `BonusTransferFailed`. Notes: - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method will not be reverted, and the underlying nodes does not hang.\",\"params\":{\"forBlockProducer\":\"Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\",\"forBridgeOperator\":\"Indicates whether requesting the bonus for the bridge operator.\"},\"returns\":{\"blockProducerBonus\":\"The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\",\"bridgeOperatorBonus\":\"The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\",\"fastFinalityRewardPercent\":\"The percent of fast finality reward, returns 0 when the transfer is failed.\",\"success\":\"Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\"}},\"setBlockProducerBonusPerBlock(uint256)\":{\"details\":\"Sets the bonus amount per block for block producer. Emits the event `BlockProducerBonusPerBlockUpdated`. Requirements: - The method caller is admin.\"},\"setBridgeOperatorBonusPerBlock(uint256)\":{\"details\":\"Sets the bonus amount per block for bridge operator. Emits the event `BridgeOperatorBonusPerBlockUpdated`. Requirements: - The method caller is admin.\"},\"setContract(uint8,address)\":{\"details\":\"Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.\",\"params\":{\"addr\":\"The address of the contract to set.\",\"contractType\":\"The role of the contract to set.\"}},\"setFastFinalityRewardPercentage(uint256)\":{\"details\":\"Sets the percent of fast finality reward. Emits the event `FastFinalityRewardPercentageUpdated`. Requirements: - The method caller is admin.\"}},\"stateVariables\":{\"_blockProducerBonusPerBlock\":{\"details\":\"The block bonus for the block producer whenever a new block is mined.\"},\"_bridgeOperatorBonusPerBlock\":{\"details\":\"The block bonus for the bridge operator whenever a new block is mined.\"},\"_fastFinalityRewardPercentage\":{\"details\":\"The percentage that extracted from reward of block producer for fast finality.\"},\"lastBlockSendingBonus\":{\"details\":\"The last block number that the staking vesting sent.\"}},\"version\":1},\"userdoc\":{\"kind\":\"user\",\"methods\":{},\"version\":1}},\"settings\":{\"compilationTarget\":{\"contracts/ronin/StakingVesting.sol\":\"StakingVesting\"},\"evmVersion\":\"london\",\"libraries\":{},\"metadata\":{\"bytecodeHash\":\"ipfs\",\"useLiteralContent\":true},\"optimizer\":{\"enabled\":true,\"runs\":200},\"remappings\":[]},\"sources\":{\"@openzeppelin/contracts/interfaces/draft-IERC1822.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\\n * proxy whose upgrades are fully controlled by the current implementation.\\n */\\ninterface IERC1822Proxiable {\\n /**\\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\\n * address.\\n *\\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\\n * function revert if invoked through a proxy.\\n */\\n function proxiableUUID() external view returns (bytes32);\\n}\\n\",\"keccak256\":\"0x1d4afe6cb24200cc4545eed814ecf5847277dfe5d613a1707aad5fceecebcfff\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../Proxy.sol\\\";\\nimport \\\"./ERC1967Upgrade.sol\\\";\\n\\n/**\\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\\n * implementation address that can be changed. This address is stored in storage in the location specified by\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\\n * implementation behind the proxy.\\n */\\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\\n /**\\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\\n *\\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\\n */\\n constructor(address _logic, bytes memory _data) payable {\\n _upgradeToAndCall(_logic, _data, false);\\n }\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _implementation() internal view virtual override returns (address impl) {\\n return ERC1967Upgrade._getImplementation();\\n }\\n}\\n\",\"keccak256\":\"0xa2b22da3032e50b55f95ec1d13336102d675f341167aa76db571ef7f8bb7975d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../beacon/IBeacon.sol\\\";\\nimport \\\"../../interfaces/draft-IERC1822.sol\\\";\\nimport \\\"../../utils/Address.sol\\\";\\nimport \\\"../../utils/StorageSlot.sol\\\";\\n\\n/**\\n * @dev This abstract contract provides getters and event emitting update functions for\\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\\n *\\n * _Available since v4.1._\\n *\\n * @custom:oz-upgrades-unsafe-allow delegatecall\\n */\\nabstract contract ERC1967Upgrade {\\n // This is the keccak-256 hash of \\\"eip1967.proxy.rollback\\\" subtracted by 1\\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\\n\\n /**\\n * @dev Storage slot with the address of the current implementation.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.implementation\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n\\n /**\\n * @dev Emitted when the implementation is upgraded.\\n */\\n event Upgraded(address indexed implementation);\\n\\n /**\\n * @dev Returns the current implementation address.\\n */\\n function _getImplementation() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 implementation slot.\\n */\\n function _setImplementation(address newImplementation) private {\\n require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n }\\n\\n /**\\n * @dev Perform implementation upgrade\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeTo(address newImplementation) internal {\\n _setImplementation(newImplementation);\\n emit Upgraded(newImplementation);\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCall(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _upgradeTo(newImplementation);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(newImplementation, data);\\n }\\n }\\n\\n /**\\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\\n *\\n * Emits an {Upgraded} event.\\n */\\n function _upgradeToAndCallUUPS(\\n address newImplementation,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n // Upgrades from old implementations will perform a rollback test. This test requires the new\\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\\n // this special case will break upgrade paths from old UUPS implementation to new ones.\\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\\n _setImplementation(newImplementation);\\n } else {\\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\\n require(slot == _IMPLEMENTATION_SLOT, \\\"ERC1967Upgrade: unsupported proxiableUUID\\\");\\n } catch {\\n revert(\\\"ERC1967Upgrade: new implementation is not UUPS\\\");\\n }\\n _upgradeToAndCall(newImplementation, data, forceCall);\\n }\\n }\\n\\n /**\\n * @dev Storage slot with the admin of the contract.\\n * This is the keccak-256 hash of \\\"eip1967.proxy.admin\\\" subtracted by 1, and is\\n * validated in the constructor.\\n */\\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n /**\\n * @dev Emitted when the admin account has changed.\\n */\\n event AdminChanged(address previousAdmin, address newAdmin);\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _getAdmin() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new address in the EIP1967 admin slot.\\n */\\n function _setAdmin(address newAdmin) private {\\n require(newAdmin != address(0), \\\"ERC1967: new admin is the zero address\\\");\\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n */\\n function _changeAdmin(address newAdmin) internal {\\n emit AdminChanged(_getAdmin(), newAdmin);\\n _setAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\\n */\\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\\n\\n /**\\n * @dev Emitted when the beacon is upgraded.\\n */\\n event BeaconUpgraded(address indexed beacon);\\n\\n /**\\n * @dev Returns the current beacon.\\n */\\n function _getBeacon() internal view returns (address) {\\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\\n }\\n\\n /**\\n * @dev Stores a new beacon in the EIP1967 beacon slot.\\n */\\n function _setBeacon(address newBeacon) private {\\n require(Address.isContract(newBeacon), \\\"ERC1967: new beacon is not a contract\\\");\\n require(\\n Address.isContract(IBeacon(newBeacon).implementation()),\\n \\\"ERC1967: beacon implementation is not a contract\\\"\\n );\\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\\n }\\n\\n /**\\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\\n *\\n * Emits a {BeaconUpgraded} event.\\n */\\n function _upgradeBeaconToAndCall(\\n address newBeacon,\\n bytes memory data,\\n bool forceCall\\n ) internal {\\n _setBeacon(newBeacon);\\n emit BeaconUpgraded(newBeacon);\\n if (data.length > 0 || forceCall) {\\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\\n }\\n }\\n}\\n\",\"keccak256\":\"0xabf3f59bc0e5423eae45e459dbe92e7052c6983628d39008590edc852a62f94a\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/Proxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\\n * be specified by overriding the virtual {_implementation} function.\\n *\\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\\n * different contract through the {_delegate} function.\\n *\\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\\n */\\nabstract contract Proxy {\\n /**\\n * @dev Delegates the current call to `implementation`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _delegate(address implementation) internal virtual {\\n assembly {\\n // Copy msg.data. We take full control of memory in this inline assembly\\n // block because it will not return to Solidity code. We overwrite the\\n // Solidity scratch pad at memory position 0.\\n calldatacopy(0, 0, calldatasize())\\n\\n // Call the implementation.\\n // out and outsize are 0 because we don't know the size yet.\\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\\n\\n // Copy the returned data.\\n returndatacopy(0, 0, returndatasize())\\n\\n switch result\\n // delegatecall returns 0 on error.\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n\\n /**\\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\\n * and {_fallback} should delegate.\\n */\\n function _implementation() internal view virtual returns (address);\\n\\n /**\\n * @dev Delegates the current call to the address returned by `_implementation()`.\\n *\\n * This function does not return to its internal call site, it will return directly to the external caller.\\n */\\n function _fallback() internal virtual {\\n _beforeFallback();\\n _delegate(_implementation());\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\\n * function in the contract matches the call data.\\n */\\n fallback() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\\n * is empty.\\n */\\n receive() external payable virtual {\\n _fallback();\\n }\\n\\n /**\\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\\n * call, or as part of the Solidity `fallback` or `receive` functions.\\n *\\n * If overridden should call `super._beforeFallback()`.\\n */\\n function _beforeFallback() internal virtual {}\\n}\\n\",\"keccak256\":\"0xc130fe33f1b2132158531a87734153293f6d07bc263ff4ac90e85da9c82c0e27\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/beacon/IBeacon.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\\n */\\ninterface IBeacon {\\n /**\\n * @dev Must return an address that can be used as a delegate call target.\\n *\\n * {BeaconProxy} will check that this address is a contract.\\n */\\n function implementation() external view returns (address);\\n}\\n\",\"keccak256\":\"0xd50a3421ac379ccb1be435fa646d66a65c986b4924f0849839f08692f39dde61\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\\n\\npragma solidity ^0.8.0;\\n\\nimport \\\"../ERC1967/ERC1967Proxy.sol\\\";\\n\\n/**\\n * @dev This contract implements a proxy that is upgradeable by an admin.\\n *\\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\\n * clashing], which can potentially be used in an attack, this contract uses the\\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\\n * things that go hand in hand:\\n *\\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\\n * that call matches one of the admin functions exposed by the proxy itself.\\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\\n * \\\"admin cannot fallback to proxy target\\\".\\n *\\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\\n * to sudden errors when trying to call a function from the proxy implementation.\\n *\\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\\n */\\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\\n /**\\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\\n */\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable ERC1967Proxy(_logic, _data) {\\n _changeAdmin(admin_);\\n }\\n\\n /**\\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\\n */\\n modifier ifAdmin() {\\n if (msg.sender == _getAdmin()) {\\n _;\\n } else {\\n _fallback();\\n }\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\\n */\\n function admin() external ifAdmin returns (address admin_) {\\n admin_ = _getAdmin();\\n }\\n\\n /**\\n * @dev Returns the current implementation.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\\n *\\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\\n */\\n function implementation() external ifAdmin returns (address implementation_) {\\n implementation_ = _implementation();\\n }\\n\\n /**\\n * @dev Changes the admin of the proxy.\\n *\\n * Emits an {AdminChanged} event.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\\n */\\n function changeAdmin(address newAdmin) external virtual ifAdmin {\\n _changeAdmin(newAdmin);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\\n */\\n function upgradeTo(address newImplementation) external ifAdmin {\\n _upgradeToAndCall(newImplementation, bytes(\\\"\\\"), false);\\n }\\n\\n /**\\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\\n * proxied contract.\\n *\\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\\n */\\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\\n _upgradeToAndCall(newImplementation, data, true);\\n }\\n\\n /**\\n * @dev Returns the current admin.\\n */\\n function _admin() internal view virtual returns (address) {\\n return _getAdmin();\\n }\\n\\n /**\\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\\n */\\n function _beforeFallback() internal virtual override {\\n require(msg.sender != _getAdmin(), \\\"TransparentUpgradeableProxy: admin cannot fallback to proxy target\\\");\\n super._beforeFallback();\\n }\\n}\\n\",\"keccak256\":\"0xa6a787e7a901af6511e19aa53e1a00352db215a011d2c7a438d0582dd5da76f9\",\"license\":\"MIT\"},\"@openzeppelin/contracts/proxy/utils/Initializable.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\\n\\npragma solidity ^0.8.2;\\n\\nimport \\\"../../utils/Address.sol\\\";\\n\\n/**\\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\\n *\\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\\n * reused. This mechanism prevents re-execution of each \\\"step\\\" but allows the creation of new initialization steps in\\n * case an upgrade adds a module that needs to be initialized.\\n *\\n * For example:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * contract MyToken is ERC20Upgradeable {\\n * function initialize() initializer public {\\n * __ERC20_init(\\\"MyToken\\\", \\\"MTK\\\");\\n * }\\n * }\\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\\n * function initializeV2() reinitializer(2) public {\\n * __ERC20Permit_init(\\\"MyToken\\\");\\n * }\\n * }\\n * ```\\n *\\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\\n *\\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\\n *\\n * [CAUTION]\\n * ====\\n * Avoid leaving a contract uninitialized.\\n *\\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\\n *\\n * [.hljs-theme-light.nopadding]\\n * ```\\n * /// @custom:oz-upgrades-unsafe-allow constructor\\n * constructor() {\\n * _disableInitializers();\\n * }\\n * ```\\n * ====\\n */\\nabstract contract Initializable {\\n /**\\n * @dev Indicates that the contract has been initialized.\\n * @custom:oz-retyped-from bool\\n */\\n uint8 private _initialized;\\n\\n /**\\n * @dev Indicates that the contract is in the process of being initialized.\\n */\\n bool private _initializing;\\n\\n /**\\n * @dev Triggered when the contract has been initialized or reinitialized.\\n */\\n event Initialized(uint8 version);\\n\\n /**\\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\\n */\\n modifier initializer() {\\n bool isTopLevelCall = !_initializing;\\n require(\\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\\n \\\"Initializable: contract is already initialized\\\"\\n );\\n _initialized = 1;\\n if (isTopLevelCall) {\\n _initializing = true;\\n }\\n _;\\n if (isTopLevelCall) {\\n _initializing = false;\\n emit Initialized(1);\\n }\\n }\\n\\n /**\\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\\n * used to initialize parent contracts.\\n *\\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\\n * initialization step. This is essential to configure modules that are added through upgrades and that require\\n * initialization.\\n *\\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\\n * a contract, executing them in the right order is up to the developer or operator.\\n */\\n modifier reinitializer(uint8 version) {\\n require(!_initializing && _initialized < version, \\\"Initializable: contract is already initialized\\\");\\n _initialized = version;\\n _initializing = true;\\n _;\\n _initializing = false;\\n emit Initialized(version);\\n }\\n\\n /**\\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\\n */\\n modifier onlyInitializing() {\\n require(_initializing, \\\"Initializable: contract is not initializing\\\");\\n _;\\n }\\n\\n /**\\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\\n * through proxies.\\n */\\n function _disableInitializers() internal virtual {\\n require(!_initializing, \\\"Initializable: contract is initializing\\\");\\n if (_initialized < type(uint8).max) {\\n _initialized = type(uint8).max;\\n emit Initialized(type(uint8).max);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x2a21b14ff90012878752f230d3ffd5c3405e5938d06c97a7d89c0a64561d0d66\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/Address.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\\n\\npragma solidity ^0.8.1;\\n\\n/**\\n * @dev Collection of functions related to the address type\\n */\\nlibrary Address {\\n /**\\n * @dev Returns true if `account` is a contract.\\n *\\n * [IMPORTANT]\\n * ====\\n * It is unsafe to assume that an address for which this function returns\\n * false is an externally-owned account (EOA) and not a contract.\\n *\\n * Among others, `isContract` will return false for the following\\n * types of addresses:\\n *\\n * - an externally-owned account\\n * - a contract in construction\\n * - an address where a contract will be created\\n * - an address where a contract lived, but was destroyed\\n * ====\\n *\\n * [IMPORTANT]\\n * ====\\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\\n *\\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\\n * constructor.\\n * ====\\n */\\n function isContract(address account) internal view returns (bool) {\\n // This method relies on extcodesize/address.code.length, which returns 0\\n // for contracts in construction, since the code is only stored at the end\\n // of the constructor execution.\\n\\n return account.code.length > 0;\\n }\\n\\n /**\\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\\n * `recipient`, forwarding all available gas and reverting on errors.\\n *\\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\\n * imposed by `transfer`, making them unable to receive funds via\\n * `transfer`. {sendValue} removes this limitation.\\n *\\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\\n *\\n * IMPORTANT: because control is transferred to `recipient`, care must be\\n * taken to not create reentrancy vulnerabilities. Consider using\\n * {ReentrancyGuard} or the\\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\\n */\\n function sendValue(address payable recipient, uint256 amount) internal {\\n require(address(this).balance >= amount, \\\"Address: insufficient balance\\\");\\n\\n (bool success, ) = recipient.call{value: amount}(\\\"\\\");\\n require(success, \\\"Address: unable to send value, recipient may have reverted\\\");\\n }\\n\\n /**\\n * @dev Performs a Solidity function call using a low level `call`. A\\n * plain `call` is an unsafe replacement for a function call: use this\\n * function instead.\\n *\\n * If `target` reverts with a revert reason, it is bubbled up by this\\n * function (like regular Solidity function calls).\\n *\\n * Returns the raw returned data. To convert to the expected return value,\\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\\n *\\n * Requirements:\\n *\\n * - `target` must be a contract.\\n * - calling `target` with `data` must not revert.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionCall(target, data, \\\"Address: low-level call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\\n * `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, 0, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but also transferring `value` wei to `target`.\\n *\\n * Requirements:\\n *\\n * - the calling contract must have an ETH balance of at least `value`.\\n * - the called Solidity function must be `payable`.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value\\n ) internal returns (bytes memory) {\\n return functionCallWithValue(target, data, value, \\\"Address: low-level call with value failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\\n * with `errorMessage` as a fallback revert reason when `target` reverts.\\n *\\n * _Available since v3.1._\\n */\\n function functionCallWithValue(\\n address target,\\n bytes memory data,\\n uint256 value,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(address(this).balance >= value, \\\"Address: insufficient balance for call\\\");\\n require(isContract(target), \\\"Address: call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.call{value: value}(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\\n return functionStaticCall(target, data, \\\"Address: low-level static call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a static call.\\n *\\n * _Available since v3.3._\\n */\\n function functionStaticCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal view returns (bytes memory) {\\n require(isContract(target), \\\"Address: static call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.staticcall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\\n return functionDelegateCall(target, data, \\\"Address: low-level delegate call failed\\\");\\n }\\n\\n /**\\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\\n * but performing a delegate call.\\n *\\n * _Available since v3.4._\\n */\\n function functionDelegateCall(\\n address target,\\n bytes memory data,\\n string memory errorMessage\\n ) internal returns (bytes memory) {\\n require(isContract(target), \\\"Address: delegate call to non-contract\\\");\\n\\n (bool success, bytes memory returndata) = target.delegatecall(data);\\n return verifyCallResult(success, returndata, errorMessage);\\n }\\n\\n /**\\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\\n * revert reason using the provided one.\\n *\\n * _Available since v4.3._\\n */\\n function verifyCallResult(\\n bool success,\\n bytes memory returndata,\\n string memory errorMessage\\n ) internal pure returns (bytes memory) {\\n if (success) {\\n return returndata;\\n } else {\\n // Look for revert reason and bubble it up if present\\n if (returndata.length > 0) {\\n // The easiest way to bubble the revert reason is using memory via assembly\\n /// @solidity memory-safe-assembly\\n assembly {\\n let returndata_size := mload(returndata)\\n revert(add(32, returndata), returndata_size)\\n }\\n } else {\\n revert(errorMessage);\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd6153ce99bcdcce22b124f755e72553295be6abcd63804cfdffceb188b8bef10\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/StorageSlot.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Library for reading and writing primitive types to specific storage slots.\\n *\\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\\n * This library helps with reading and writing to such slots without the need for inline assembly.\\n *\\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\\n *\\n * Example usage to set ERC1967 implementation slot:\\n * ```\\n * contract ERC1967 {\\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\\n *\\n * function _getImplementation() internal view returns (address) {\\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\\n * }\\n *\\n * function _setImplementation(address newImplementation) internal {\\n * require(Address.isContract(newImplementation), \\\"ERC1967: new implementation is not a contract\\\");\\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\\n * }\\n * }\\n * ```\\n *\\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\\n */\\nlibrary StorageSlot {\\n struct AddressSlot {\\n address value;\\n }\\n\\n struct BooleanSlot {\\n bool value;\\n }\\n\\n struct Bytes32Slot {\\n bytes32 value;\\n }\\n\\n struct Uint256Slot {\\n uint256 value;\\n }\\n\\n /**\\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\\n */\\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\\n */\\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\\n */\\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n\\n /**\\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\\n */\\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\\n /// @solidity memory-safe-assembly\\n assembly {\\n r.slot := slot\\n }\\n }\\n}\\n\",\"keccak256\":\"0xd5c50c54bf02740ebd122ff06832546cb5fa84486d52695a9ccfd11666e0c81d\",\"license\":\"MIT\"},\"@openzeppelin/contracts/utils/introspection/IERC165.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\\n\\npragma solidity ^0.8.0;\\n\\n/**\\n * @dev Interface of the ERC165 standard, as defined in the\\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\\n *\\n * Implementers can declare support of contract interfaces, which can then be\\n * queried by others ({ERC165Checker}).\\n *\\n * For an implementation, see {ERC165}.\\n */\\ninterface IERC165 {\\n /**\\n * @dev Returns true if this contract implements the interface defined by\\n * `interfaceId`. See the corresponding\\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\\n * to learn more about how these ids are created.\\n *\\n * This function call must use less than 30 000 gas.\\n */\\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\\n}\\n\",\"keccak256\":\"0x447a5f3ddc18419d41ff92b3773fb86471b1db25773e07f877f548918a185bf1\",\"license\":\"MIT\"},\"contracts/extensions/RONTransferHelper.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nabstract contract RONTransferHelper {\\n /// @dev Error of sender has insufficient balance.\\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\\n /// @dev Error of recipient not accepting RON when transfer RON.\\n error ErrRecipientRevert(bytes4 msgSig);\\n\\n /**\\n * @dev See `_sendRON`.\\n * Reverts if the recipient does not receive RON.\\n */\\n function _transferRON(address payable recipient, uint256 amount) internal {\\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\\n }\\n\\n /**\\n * @dev Send `amount` RON to the address `recipient`.\\n * Returns whether the recipient receives RON or not.\\n * Reverts once the contract balance is insufficient.\\n *\\n * Note: consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\\n return _unsafeSendRON(recipient, amount);\\n }\\n\\n /**\\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\\n * the call does not revert.\\n *\\n * Note:\\n * - Does not assert whether the balance of sender is sufficient.\\n * - Does not assert whether the recipient accepts RON.\\n * - Consider using `ReentrancyGuard` before calling this function.\\n *\\n */\\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount }(\\\"\\\");\\n }\\n\\n /**\\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\\n */\\n function _unsafeSendRONLimitGas(\\n address payable recipient,\\n uint256 amount,\\n uint256 gas\\n ) internal returns (bool success) {\\n (success, ) = recipient.call{ value: amount, gas: gas }(\\\"\\\");\\n }\\n}\\n\",\"keccak256\":\"0xdece837caa8da00fe031b8139ada009330b8bef149af12b535913c021ab94d0e\",\"license\":\"MIT\"},\"contracts/extensions/TransparentUpgradeableProxyV2.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\\\";\\n\\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\\n constructor(\\n address _logic,\\n address admin_,\\n bytes memory _data\\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\\n\\n /**\\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\\n *\\n * Requirements:\\n * - Only the admin can call this function.\\n *\\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\\n * reviewing the encoded data `_data` and the method which is called before using this.\\n *\\n */\\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\\n address _addr = _implementation();\\n assembly {\\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\\n returndatacopy(0, 0, returndatasize())\\n switch _result\\n case 0 {\\n revert(0, returndatasize())\\n }\\n default {\\n return(0, returndatasize())\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0x6609392ea7d3174439b5715100bee82528fe6e4aff28927d48c27db8475e88c5\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { HasProxyAdmin } from \\\"./HasProxyAdmin.sol\\\";\\nimport \\\"../../interfaces/collections/IHasContracts.sol\\\";\\nimport { IdentityGuard } from \\\"../../utils/IdentityGuard.sol\\\";\\nimport { ErrUnexpectedInternalCall } from \\\"../../utils/CommonErrors.sol\\\";\\n\\n/**\\n * @title HasContracts\\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\\n */\\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\\n /// @dev value is equal to keccak256(\\\"@ronin.dpos.collections.HasContracts.slot\\\") - 1\\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\\n\\n /**\\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\\n * @param contractType The contract type that allowed to call\\n */\\n modifier onlyContract(ContractType contractType) virtual {\\n _requireContract(contractType);\\n _;\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\\n _requireHasCode(addr);\\n _setContract(contractType, addr);\\n }\\n\\n /**\\n * @inheritdoc IHasContracts\\n */\\n function getContract(ContractType contractType) public view returns (address contract_) {\\n contract_ = _getContractMap()[uint8(contractType)];\\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\\n }\\n\\n /**\\n * @dev Internal function to set the address of a contract with a specific role.\\n * @param contractType The contract type of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function _setContract(ContractType contractType, address addr) internal virtual {\\n _getContractMap()[uint8(contractType)] = addr;\\n emit ContractUpdated(contractType, addr);\\n }\\n\\n /**\\n * @dev Internal function to access the mapping of contract addresses with roles.\\n * @return contracts_ The mapping of contract addresses with roles.\\n */\\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\\n assembly {\\n contracts_.slot := _STORAGE_SLOT\\n }\\n }\\n\\n /**\\n * @dev Internal function to check if the calling contract has a specific role.\\n * @param contractType The contract type that the calling contract must have.\\n * @dev Throws an error if the calling contract does not have the specified role.\\n */\\n function _requireContract(ContractType contractType) private view {\\n if (msg.sender != getContract(contractType)) {\\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\\n }\\n }\\n}\\n\",\"keccak256\":\"0x9e1dceb68827adfb8c8184662f29ab5fe14e292a632878150e3b0b6c61bc1dce\",\"license\":\"MIT\"},\"contracts/extensions/collections/HasProxyAdmin.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport \\\"@openzeppelin/contracts/utils/StorageSlot.sol\\\";\\nimport \\\"../../utils/CommonErrors.sol\\\";\\n\\nabstract contract HasProxyAdmin {\\n // bytes32(uint256(keccak256(\\\"eip1967.proxy.admin\\\")) - 1));\\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\\n\\n modifier onlyAdmin() {\\n _requireAdmin();\\n _;\\n }\\n\\n /**\\n * @dev Returns proxy admin.\\n */\\n function _getAdmin() internal view virtual returns (address) {\\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\\n }\\n\\n function _requireAdmin() internal view {\\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\\n }\\n}\\n\",\"keccak256\":\"0x0916021d04ea0c93c54978dc2fd46575fd2bd867369fbf9ce49f316939ddaf25\",\"license\":\"MIT\"},\"contracts/extensions/consumers/PercentageConsumer.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nabstract contract PercentageConsumer {\\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\\n}\\n\",\"keccak256\":\"0x5dc54a24348c5d614de1b4805dddeab4dda72f9f0636b27bf0ed295fee017dcf\",\"license\":\"MIT\"},\"contracts/interfaces/IStakingVesting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\ninterface IStakingVesting {\\n /**\\n * @dev Error thrown when attempting to send a bonus that has already been sent.\\n */\\n error ErrBonusAlreadySent();\\n\\n /// @dev Emitted when the block bonus for block producer is transferred.\\n event BonusTransferred(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount\\n );\\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\\n event BonusTransferFailed(\\n uint256 indexed blockNumber,\\n address indexed recipient,\\n uint256 blockProducerAmount,\\n uint256 bridgeOperatorAmount,\\n uint256 contractBalance\\n );\\n /// @dev Emitted when the block bonus for block producer is updated\\n event BlockProducerBonusPerBlockUpdated(uint256);\\n /// @dev Emitted when the block bonus for bridge operator is updated\\n event BridgeOperatorBonusPerBlockUpdated(uint256);\\n /// @dev Emitted when the percent of fast finality reward is updated\\n event FastFinalityRewardPercentageUpdated(uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the block producer at `_block`.\\n */\\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns the bonus amount for the bridge validator at `_block`.\\n */\\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\\n\\n /**\\n * @dev Returns the percentage of fast finality reward.\\n */\\n function fastFinalityRewardPercentage() external view returns (uint256);\\n\\n /**\\n * @dev Receives RON from any address.\\n */\\n function receiveRON() external payable;\\n\\n /**\\n * @dev Returns the last block number that the staking vesting is sent.\\n */\\n function lastBlockSendingBonus() external view returns (uint256);\\n\\n /**\\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\\n *\\n * Requirements:\\n * - The method caller must be validator contract.\\n * - The method must be called only once per block.\\n *\\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\\n *\\n * Notes:\\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\\n * will not be reverted, and the underlying nodes does not hang.\\n *\\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\\n *\\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\\n *\\n */\\n function requestBonus(\\n bool forBlockProducer,\\n bool forBridgeOperator\\n )\\n external\\n returns (\\n bool success,\\n uint256 blockProducerBonus,\\n uint256 bridgeOperatorBonus,\\n uint256 fastFinalityRewardPercentage\\n );\\n\\n /**\\n * @dev Sets the bonus amount per block for block producer.\\n *\\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\\n\\n /**\\n * @dev Sets the bonus amount per block for bridge operator.\\n *\\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\\n\\n /**\\n * @dev Sets the percent of fast finality reward.\\n *\\n * Emits the event `FastFinalityRewardPercentageUpdated`.\\n *\\n * Requirements:\\n * - The method caller is admin.\\n *\\n */\\n function setFastFinalityRewardPercentage(uint256 _percent) external;\\n}\\n\",\"keccak256\":\"0xdf4e372179731e859e564988eba09fda97810aeda1fec2b84c8abdaa6e1a5912\",\"license\":\"MIT\"},\"contracts/interfaces/collections/IHasContracts.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport { ContractType } from \\\"../../utils/ContractType.sol\\\";\\n\\ninterface IHasContracts {\\n /// @dev Error of invalid role.\\n error ErrContractTypeNotFound(ContractType contractType);\\n\\n /// @dev Emitted when a contract is updated.\\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\\n\\n /**\\n * @dev Returns the address of a contract with a specific role.\\n * Throws an error if no contract is set for the specified role.\\n *\\n * @param contractType The role of the contract to retrieve.\\n * @return contract_ The address of the contract with the specified role.\\n */\\n function getContract(ContractType contractType) external view returns (address contract_);\\n\\n /**\\n * @dev Sets the address of a contract with a specific role.\\n * Emits the event {ContractUpdated}.\\n * @param contractType The role of the contract to set.\\n * @param addr The address of the contract to set.\\n */\\n function setContract(ContractType contractType, address addr) external;\\n}\\n\",\"keccak256\":\"0x99d8213d857e30d367155abd15dc42730afdfbbac3a22dfb3b95ffea2083a92e\",\"license\":\"MIT\"},\"contracts/libraries/AddressArrayUtils.sol\":{\"content\":\"// SPDX-License-Identifier: UNLICENSED\\n\\npragma solidity ^0.8.0;\\n\\nlibrary AddressArrayUtils {\\n /**\\n * @dev Error thrown when a duplicated element is detected in an array.\\n * @param msgSig The function signature that invoke the error.\\n */\\n error ErrDuplicated(bytes4 msgSig);\\n\\n /**\\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\\n * @param A Array to search\\n * @return Returns true if duplicate, false otherwise\\n */\\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\\n if (A.length == 0) {\\n return false;\\n }\\n unchecked {\\n for (uint256 i = 0; i < A.length - 1; i++) {\\n for (uint256 j = i + 1; j < A.length; j++) {\\n if (A[i] == A[j]) {\\n return true;\\n }\\n }\\n }\\n }\\n return false;\\n }\\n\\n /**\\n * @dev Returns whether two arrays of addresses are equal or not.\\n */\\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\\n // Hashing two arrays and compare their hash\\n assembly {\\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\\n yes_ := eq(_thisHash, _otherHash)\\n }\\n }\\n\\n /**\\n * @dev Return the concatenated array from a and b.\\n */\\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\\n uint256 lengthA = a.length;\\n uint256 lengthB = b.length;\\n unchecked {\\n c = new address[](lengthA + lengthB);\\n }\\n uint256 i;\\n for (; i < lengthA; ) {\\n c[i] = a[i];\\n unchecked {\\n ++i;\\n }\\n }\\n for (uint256 j; j < lengthB; ) {\\n c[i] = b[j];\\n unchecked {\\n ++i;\\n ++j;\\n }\\n }\\n }\\n}\\n\",\"keccak256\":\"0xaf760162653a85d6e1b24df4d33c74076f778470112f421a02050fb981242001\",\"license\":\"UNLICENSED\"},\"contracts/ronin/StakingVesting.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\n\\npragma solidity ^0.8.9;\\n\\nimport \\\"@openzeppelin/contracts/proxy/utils/Initializable.sol\\\";\\nimport \\\"../interfaces/IStakingVesting.sol\\\";\\nimport \\\"../extensions/collections/HasContracts.sol\\\";\\nimport \\\"../extensions/consumers/PercentageConsumer.sol\\\";\\nimport { RONTransferHelper } from \\\"../extensions/RONTransferHelper.sol\\\";\\nimport { HasValidatorDeprecated } from \\\"../utils/DeprecatedSlots.sol\\\";\\nimport \\\"../utils/CommonErrors.sol\\\";\\n\\ncontract StakingVesting is\\n IStakingVesting,\\n PercentageConsumer,\\n HasValidatorDeprecated,\\n HasContracts,\\n Initializable,\\n RONTransferHelper\\n{\\n /// @dev The block bonus for the block producer whenever a new block is mined.\\n uint256 internal _blockProducerBonusPerBlock;\\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\\n uint256 internal _bridgeOperatorBonusPerBlock;\\n /// @dev The last block number that the staking vesting sent.\\n uint256 public lastBlockSendingBonus;\\n /// @dev The percentage that extracted from reward of block producer for fast finality.\\n uint256 internal _fastFinalityRewardPercentage;\\n\\n constructor() {\\n _disableInitializers();\\n }\\n\\n /**\\n * @dev Initializes the contract storage.\\n */\\n function initialize(\\n address __validatorContract,\\n uint256 __blockProducerBonusPerBlock,\\n uint256 __bridgeOperatorBonusPerBlock\\n ) external payable initializer {\\n _setContract(ContractType.VALIDATOR, __validatorContract);\\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\\n }\\n\\n function initializeV2() external reinitializer(2) {\\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\\n delete ______deprecatedValidator;\\n }\\n\\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function receiveRON() external payable {}\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\\n return _blockProducerBonusPerBlock;\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\\n return _bridgeOperatorBonusPerBlock;\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function fastFinalityRewardPercentage() external view override returns (uint256) {\\n return _fastFinalityRewardPercentage;\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function requestBonus(\\n bool forBlockProducer,\\n bool forBridgeOperator\\n )\\n external\\n override\\n onlyContract(ContractType.VALIDATOR)\\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\\n {\\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\\n\\n lastBlockSendingBonus = block.number;\\n\\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\\n\\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\\n\\n if (totalAmount > 0) {\\n address payable validatorContractAddr = payable(msg.sender);\\n\\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\\n\\n if (!success) {\\n emit BonusTransferFailed(\\n block.number,\\n validatorContractAddr,\\n blockProducerBonus,\\n bridgeOperatorBonus,\\n address(this).balance\\n );\\n return (success, 0, 0, 0);\\n }\\n\\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\\n }\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\\n _setBlockProducerBonusPerBlock(_amount);\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\\n _setBridgeOperatorBonusPerBlock(_amount);\\n }\\n\\n /**\\n * @inheritdoc IStakingVesting\\n */\\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\\n _setFastFinalityRewardPercentage(percent);\\n }\\n\\n /**\\n * @dev Sets the bonus amount per block for block producer.\\n *\\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\\n *\\n */\\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\\n _blockProducerBonusPerBlock = _amount;\\n emit BlockProducerBonusPerBlockUpdated(_amount);\\n }\\n\\n /**\\n * @dev Sets the bonus amount per block for bridge operator.\\n *\\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\\n *\\n */\\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\\n _bridgeOperatorBonusPerBlock = _amount;\\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\\n }\\n\\n /**\\n * @dev Sets the percent of fast finality reward.\\n *\\n * Emits the event `FastFinalityRewardPercentageUpdated`.\\n *\\n */\\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\\n _fastFinalityRewardPercentage = percent;\\n emit FastFinalityRewardPercentageUpdated(percent);\\n }\\n}\\n\",\"keccak256\":\"0x5e25d80df0170219f12cbd45d22e16e9d0761d044be819acd91d6514d88d795d\",\"license\":\"MIT\"},\"contracts/utils/CommonErrors.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { ContractType } from \\\"./ContractType.sol\\\";\\nimport { RoleAccess } from \\\"./RoleAccess.sol\\\";\\n\\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\\n/**\\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\\n */\\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\\n/**\\n * @dev Error raised when a bridge operator update operation fails.\\n * @param bridgeOperator The address of the bridge operator that failed to update.\\n */\\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\\n/**\\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\\n */\\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\\n/**\\n * @dev The error indicating an unsupported interface.\\n * @param interfaceId The bytes4 interface identifier that is not supported.\\n * @param addr The address where the unsupported interface was encountered.\\n */\\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\\n/**\\n * @dev Error thrown when the return data from a callback function is invalid.\\n * @param callbackFnSig The signature of the callback function that returned invalid data.\\n * @param register The address of the register where the callback function was invoked.\\n * @param returnData The invalid return data received from the callback function.\\n */\\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\\n/**\\n * @dev Error of set to non-contract.\\n */\\nerror ErrZeroCodeContract(address addr);\\n/**\\n * @dev Error indicating that arguments are invalid.\\n */\\nerror ErrInvalidArguments(bytes4 msgSig);\\n/**\\n * @dev Error indicating that given address is null when it should not.\\n */\\nerror ErrZeroAddress(bytes4 msgSig);\\n/**\\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\\n */\\nerror ErrInvalidThreshold(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a function can only be called by the contract itself.\\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\\n */\\nerror ErrOnlySelfCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n * @param expectedRole The role required to perform the function.\\n */\\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\\n */\\nerror ErrUnauthorizedCall(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\\n * @param msgSig The function signature (bytes4).\\n * @param expectedContractType The contract type required to perform the function.\\n * @param actual The actual address that called to the function.\\n */\\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\\n\\n/**\\n * @dev Error indicating that an array is empty when it should contain elements.\\n */\\nerror ErrEmptyArray();\\n\\n/**\\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\\n * @param msgSig The function signature (bytes4) that has a length mismatch.\\n */\\nerror ErrLengthMismatch(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a proxy call to an external contract has failed.\\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\\n */\\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\\n\\n/**\\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\\n */\\nerror ErrCallPrecompiled(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a native token transfer has failed.\\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\\n */\\nerror ErrNativeTransferFailed(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that an order is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\\n */\\nerror ErrInvalidOrder(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the chain ID is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\\n * @param actual Current chain ID that executing function.\\n * @param expected Expected chain ID required for the tx to success.\\n */\\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\\n\\n/**\\n * @dev Error indicating that a vote type is not supported.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\\n */\\nerror ErrUnsupportedVoteType(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that the proposal nonce is invalid.\\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\\n */\\nerror ErrInvalidProposalNonce(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a voter has already voted.\\n * @param voter The address of the voter who has already voted.\\n */\\nerror ErrAlreadyVoted(address voter);\\n\\n/**\\n * @dev Error indicating that a signature is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\\n */\\nerror ErrInvalidSignatures(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a relay call has failed.\\n * @param msgSig The function signature (bytes4) of the relay call that failed.\\n */\\nerror ErrRelayFailed(bytes4 msgSig);\\n/**\\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\\n */\\nerror ErrInvalidVoteWeight(bytes4 msgSig);\\n\\n/**\\n * @dev Error indicating that a query was made for an outdated bridge operator set.\\n */\\nerror ErrQueryForOutdatedBridgeOperatorSet();\\n\\n/**\\n * @dev Error indicating that a request is invalid.\\n */\\nerror ErrInvalidRequest();\\n\\n/**\\n * @dev Error indicating that a token standard is invalid.\\n */\\nerror ErrInvalidTokenStandard();\\n\\n/**\\n * @dev Error indicating that a token is not supported.\\n */\\nerror ErrUnsupportedToken();\\n\\n/**\\n * @dev Error indicating that a receipt kind is invalid.\\n */\\nerror ErrInvalidReceiptKind();\\n\\n/**\\n * @dev Error indicating that a receipt is invalid.\\n */\\nerror ErrInvalidReceipt();\\n\\n/**\\n * @dev Error indicating that an address is not payable.\\n */\\nerror ErrNonpayableAddress(address);\\n\\n/**\\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\\n */\\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\\n\\n/**\\n * @dev Error thrown when an invalid vote hash is provided.\\n */\\nerror ErrInvalidVoteHash();\\n\\n/**\\n * @dev Error thrown when querying for an empty vote.\\n */\\nerror ErrQueryForEmptyVote();\\n\\n/**\\n * @dev Error thrown when querying for an expired vote.\\n */\\nerror ErrQueryForExpiredVote();\\n\\n/**\\n * @dev Error thrown when querying for a non-existent vote.\\n */\\nerror ErrQueryForNonExistentVote();\\n\\n/**\\n * @dev Error indicating that the method is only called once per block.\\n */\\nerror ErrOncePerBlock();\\n\\n/**\\n * @dev Error of method caller must be coinbase\\n */\\nerror ErrCallerMustBeCoinbase();\\n\",\"keccak256\":\"0x22942c8fea2d1ca863ac1f9c1662d714b8ac0856684e36f8aaf19508648c1053\",\"license\":\"MIT\"},\"contracts/utils/ContractType.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum ContractType {\\n /* 0 */ UNKNOWN,\\n /* 1 */ PAUSE_ENFORCER,\\n /* 2 */ BRIDGE,\\n /* 3 */ BRIDGE_TRACKING,\\n /* 4 */ GOVERNANCE_ADMIN,\\n /* 5 */ MAINTENANCE,\\n /* 6 */ SLASH_INDICATOR,\\n /* 7 */ STAKING_VESTING,\\n /* 8 */ VALIDATOR,\\n /* 9 */ STAKING,\\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\\n /* 11 */ BRIDGE_MANAGER,\\n /* 12 */ BRIDGE_SLASH,\\n /* 13 */ BRIDGE_REWARD,\\n /* 14 */ FAST_FINALITY_TRACKING,\\n /* 15 */ PROFILE\\n}\\n\",\"keccak256\":\"0x7f547a44265f4c4b03d8971f7fc5eaa2e6064ea8cd509c1b761108f9800dab68\",\"license\":\"MIT\"},\"contracts/utils/DeprecatedSlots.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\n/**\\n * @title Deprecated Contracts\\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\\n * They provide functionality related to various aspects of a smart contract but have been marked\\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\\n */\\ncontract HasSlashIndicatorDeprecated {\\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\\n address internal ______deprecatedSlashIndicator;\\n}\\n\\ncontract HasStakingVestingDeprecated {\\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\\n address internal ______deprecatedStakingVesting;\\n}\\n\\ncontract HasBridgeDeprecated {\\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\\n address internal ______deprecatedBridge;\\n}\\n\\ncontract HasValidatorDeprecated {\\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\\n address internal ______deprecatedValidator;\\n}\\n\\ncontract HasStakingDeprecated {\\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\\n address internal ______deprecatedStakingContract;\\n}\\n\\ncontract HasMaintenanceDeprecated {\\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\\n address internal ______deprecatedMaintenance;\\n}\\n\\ncontract HasTrustedOrgDeprecated {\\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\\n address internal ______deprecatedTrustedOrg;\\n}\\n\\ncontract HasGovernanceAdminDeprecated {\\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\\n address internal ______deprecatedGovernanceAdmin;\\n}\\n\\ncontract HasBridgeTrackingDeprecated {\\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\\n address internal ______deprecatedBridgeTracking;\\n}\\n\",\"keccak256\":\"0xe93504aed9f67a6d399475c7162560f2ac4f793fab5b67fe504fc694ac9a2892\",\"license\":\"MIT\"},\"contracts/utils/IdentityGuard.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nimport { AddressArrayUtils } from \\\"../libraries/AddressArrayUtils.sol\\\";\\nimport { IERC165 } from \\\"@openzeppelin/contracts/utils/introspection/IERC165.sol\\\";\\nimport { TransparentUpgradeableProxyV2 } from \\\"../extensions/TransparentUpgradeableProxyV2.sol\\\";\\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \\\"./CommonErrors.sol\\\";\\n\\nabstract contract IdentityGuard {\\n using AddressArrayUtils for address[];\\n\\n /// @dev value is equal to keccak256(abi.encode())\\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\\n\\n /**\\n * @dev Modifier to restrict functions to only be called by this contract.\\n * @dev Reverts if the caller is not this contract.\\n */\\n modifier onlySelfCall() virtual {\\n _requireSelfCall();\\n _;\\n }\\n\\n /**\\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\\n *\\n * Requirements:\\n * - The elements in the `arr` array must not contain any duplicates.\\n */\\n modifier nonDuplicate(address[] memory arr) virtual {\\n _requireNonDuplicate(arr);\\n _;\\n }\\n\\n /**\\n * @dev Internal method to check the method caller.\\n * @dev Reverts if the method caller is not this contract.\\n */\\n function _requireSelfCall() internal view virtual {\\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to check if a contract address has code.\\n * @param addr The address of the contract to check.\\n * @dev Throws an error if the contract address has no code.\\n */\\n function _requireHasCode(address addr) internal view {\\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\\n }\\n\\n /**\\n * @dev Checks if an address is zero and reverts if it is.\\n * @param addr The address to check.\\n */\\n function _requireNonZeroAddress(address addr) internal pure {\\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\\n }\\n\\n /**\\n * @dev Check if arr is empty and revert if it is.\\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\\n * @param arr The array of addresses to check.\\n */\\n function _requireNonDuplicate(address[] memory arr) internal pure {\\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\\n }\\n\\n /**\\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\\n * @notice This method only works with non-state EOA accounts\\n */\\n function _requireCreatedEOA(address addr) internal view {\\n _requireNonZeroAddress(addr);\\n bytes32 codehash = addr.codehash;\\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\\n }\\n\\n /**\\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\\n *\\n * @param contractAddr The address of the contract to check for interface support.\\n * @param interfaceId The interface ID to check for support.\\n */\\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\\n if (!success) {\\n (success, returnOrRevertData) = contractAddr.staticcall(\\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\\n );\\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\\n }\\n}\\n\",\"keccak256\":\"0x2d0dfcef3636945bc1785c1fa5a05f5203c79cbb81b2eee92a3ac6a2378c2ce5\",\"license\":\"MIT\"},\"contracts/utils/RoleAccess.sol\":{\"content\":\"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.0;\\n\\nenum RoleAccess {\\n /* 0 */ UNKNOWN,\\n /* 1 */ ADMIN,\\n /* 2 */ COINBASE,\\n /* 3 */ GOVERNOR,\\n /* 4 */ CANDIDATE_ADMIN,\\n /* 5 */ WITHDRAWAL_MIGRATOR,\\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\\n /* 7 */ BLOCK_PRODUCER,\\n /* 8 */ VALIDATOR_CANDIDATE,\\n /* 9 */ CONSENSUS,\\n /* 10 */ TREASURY\\n}\\n\",\"keccak256\":\"0x7da4631824b53be17e246102ad59458f91f2395710561ac9bface18d35fb2502\",\"license\":\"MIT\"}},\"version\":1}", + "bytecode": "0x608060405234801561001057600080fd5b5061001961001e565b6100eb565b600054600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff600160a01b909104811610156100e9576000805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b610c3e806100fa6000396000f3fe6080604052600436106100dd5760003560e01c80637a1ac61e1161007f578063d8209d0711610059578063d8209d071461020c578063de981f1b1461022e578063f13ba64414610266578063fa8674a11461028657600080fd5b80637a1ac61e146101b9578063865e6fd3146101cc5780639e7cb051146101ec57600080fd5b8063434a025d116100bb578063434a025d1461016f57806359f778df1461016d5780635cd8a76b1461018457806367e9941c1461019957600080fd5b80630634f5b9146100e25780630d9160e7146101295780633c3d84101461014d575b600080fd5b3480156100ee57600080fd5b506101026100fd366004610a05565b6102a8565b60408051941515855260208501939093529183015260608201526080015b60405180910390f35b34801561013557600080fd5b5061013f60035481565b604051908152602001610120565b34801561015957600080fd5b5061016d610168366004610a38565b6103e1565b005b34801561017b57600080fd5b5060045461013f565b34801561019057600080fd5b5061016d6104ab565b3480156101a557600080fd5b5061016d6101b4366004610a38565b61057c565b61016d6101c7366004610a68565b610590565b3480156101d857600080fd5b5061016d6101e7366004610aaa565b61068d565b3480156101f857600080fd5b5061016d610207366004610a38565b6106ac565b34801561021857600080fd5b5061013f610227366004610a38565b5060015490565b34801561023a57600080fd5b5061024e610249366004610ad4565b6106ee565b6040516001600160a01b039091168152602001610120565b34801561027257600080fd5b5061016d610281366004610a38565b610769565b34801561029257600080fd5b5061013f6102a1366004610a38565b5060025490565b60008060008060086102b98161077a565b60035443116102db576040516301cb9f2b60e71b815260040160405180910390fd5b43600355866102eb5760006102ef565b6001545b9350856102fd576000610301565b6002545b600454909350915060006103158486610af6565b905080156103d5573361032881836107c6565b96508661038d576040805187815260208101879052478183015290516001600160a01b0383169143917f137e697384eeada9cf7614b88e4ac940aeff18d0fef7e86bce1abdc812b95e099181900360600190a350600094508493508392506103d79050565b60408051878152602081018790526001600160a01b0383169143917f60200441f885b45b3b7f1fdc45a47bb0d0a0884a6a17722f8dd7232830de9bd2910160405180910390a3505b505b5092959194509250565b600054600390600160a81b900460ff1615801561040c575060005460ff808316600160a01b90920416105b6104315760405162461bcd60e51b815260040161042890610b1d565b60405180910390fd5b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b17905561046282610822565b6000805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b565b600054600290600160a81b900460ff161580156104d6575060005460ff808316600160a01b90920416105b6104f25760405162461bcd60e51b815260040161042890610b1d565b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790819055610531906008906001600160a01b0316610857565b60008054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6105846108fb565b61058d81610955565b50565b600054600160a81b900460ff16158080156105b857506000546001600160a01b90910460ff16105b806105d95750303b1580156105d95750600054600160a01b900460ff166001145b6105f55760405162461bcd60e51b815260040161042890610b1d565b6000805460ff60a01b1916600160a01b1790558015610622576000805460ff60a81b1916600160a81b1790555b61062d600885610857565b6106368361098a565b61063f82610955565b8015610687576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b6106956108fb565b61069e816109bf565b6106a88282610857565b5050565b6106b46108fb565b6127108111156106e55760405163053265f160e01b81526001600160e01b0319600035166004820152602401610428565b61058d81610822565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561072557610725610b6b565b60ff1681526020810191909152604001600020546001600160a01b0316905080610764578160405163409140df60e11b81526004016104289190610b95565b919050565b6107716108fb565b61058d8161098a565b610783816106ee565b6001600160a01b0316336001600160a01b03161461058d576000356001600160e01b03191681336040516320e0f98d60e21b815260040161042893929190610ba3565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114610813576040519150601f19603f3d011682016040523d82523d6000602084013e610818565b606091505b5090949350505050565b60048190556040518181527f2ab16834b71343f4e1d560b325168aef35dd575d15d84c31ef788e947709953690602001610571565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561088d5761088d610b6b565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156108ce576108ce610b6b565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031633146104a9576000356001600160e01b0319166001604051620f948f60ea1b8152600401610428929190610bda565b60028190556040518181527f57a23b4b11f619fb9dea21a5a8115bb90103c1043eb3318d773558829d25f12c90602001610571565b60018190556040518181527f861f03c645467325a586235bb3155834f1dddf12413d0a802f416eb6d4035e6d90602001610571565b806001600160a01b03163b60000361058d57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610428565b8035801515811461076457600080fd5b60008060408385031215610a1857600080fd5b610a21836109f5565b9150610a2f602084016109f5565b90509250929050565b600060208284031215610a4a57600080fd5b5035919050565b80356001600160a01b038116811461076457600080fd5b600080600060608486031215610a7d57600080fd5b610a8684610a51565b95602085013595506040909401359392505050565b80356010811061076457600080fd5b60008060408385031215610abd57600080fd5b610ac683610a9b565b9150610a2f60208401610a51565b600060208284031215610ae657600080fd5b610aef82610a9b565b9392505050565b80820180821115610b1757634e487b7160e01b600052601160045260246000fd5b92915050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052602160045260246000fd5b60108110610b9157610b91610b6b565b9052565b60208101610b178284610b81565b6001600160e01b03198416815260608101610bc16020830185610b81565b6001600160a01b03929092166040919091015292915050565b6001600160e01b03198316815260408101600b8310610bfb57610bfb610b6b565b826020830152939250505056fea2646970667358221220f670acf250f786010edac02661a414750d0489157506db14ae46ea6a28ea6e6c64736f6c63430008110033", + "deployedBytecode": "0x6080604052600436106100dd5760003560e01c80637a1ac61e1161007f578063d8209d0711610059578063d8209d071461020c578063de981f1b1461022e578063f13ba64414610266578063fa8674a11461028657600080fd5b80637a1ac61e146101b9578063865e6fd3146101cc5780639e7cb051146101ec57600080fd5b8063434a025d116100bb578063434a025d1461016f57806359f778df1461016d5780635cd8a76b1461018457806367e9941c1461019957600080fd5b80630634f5b9146100e25780630d9160e7146101295780633c3d84101461014d575b600080fd5b3480156100ee57600080fd5b506101026100fd366004610a05565b6102a8565b60408051941515855260208501939093529183015260608201526080015b60405180910390f35b34801561013557600080fd5b5061013f60035481565b604051908152602001610120565b34801561015957600080fd5b5061016d610168366004610a38565b6103e1565b005b34801561017b57600080fd5b5060045461013f565b34801561019057600080fd5b5061016d6104ab565b3480156101a557600080fd5b5061016d6101b4366004610a38565b61057c565b61016d6101c7366004610a68565b610590565b3480156101d857600080fd5b5061016d6101e7366004610aaa565b61068d565b3480156101f857600080fd5b5061016d610207366004610a38565b6106ac565b34801561021857600080fd5b5061013f610227366004610a38565b5060015490565b34801561023a57600080fd5b5061024e610249366004610ad4565b6106ee565b6040516001600160a01b039091168152602001610120565b34801561027257600080fd5b5061016d610281366004610a38565b610769565b34801561029257600080fd5b5061013f6102a1366004610a38565b5060025490565b60008060008060086102b98161077a565b60035443116102db576040516301cb9f2b60e71b815260040160405180910390fd5b43600355866102eb5760006102ef565b6001545b9350856102fd576000610301565b6002545b600454909350915060006103158486610af6565b905080156103d5573361032881836107c6565b96508661038d576040805187815260208101879052478183015290516001600160a01b0383169143917f137e697384eeada9cf7614b88e4ac940aeff18d0fef7e86bce1abdc812b95e099181900360600190a350600094508493508392506103d79050565b60408051878152602081018790526001600160a01b0383169143917f60200441f885b45b3b7f1fdc45a47bb0d0a0884a6a17722f8dd7232830de9bd2910160405180910390a3505b505b5092959194509250565b600054600390600160a81b900460ff1615801561040c575060005460ff808316600160a01b90920416105b6104315760405162461bcd60e51b815260040161042890610b1d565b60405180910390fd5b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b17905561046282610822565b6000805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b565b600054600290600160a81b900460ff161580156104d6575060005460ff808316600160a01b90920416105b6104f25760405162461bcd60e51b815260040161042890610b1d565b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790819055610531906008906001600160a01b0316610857565b60008054600161ff0160a01b031916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6105846108fb565b61058d81610955565b50565b600054600160a81b900460ff16158080156105b857506000546001600160a01b90910460ff16105b806105d95750303b1580156105d95750600054600160a01b900460ff166001145b6105f55760405162461bcd60e51b815260040161042890610b1d565b6000805460ff60a01b1916600160a01b1790558015610622576000805460ff60a81b1916600160a81b1790555b61062d600885610857565b6106368361098a565b61063f82610955565b8015610687576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b6106956108fb565b61069e816109bf565b6106a88282610857565b5050565b6106b46108fb565b6127108111156106e55760405163053265f160e01b81526001600160e01b0319600035166004820152602401610428565b61058d81610822565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561072557610725610b6b565b60ff1681526020810191909152604001600020546001600160a01b0316905080610764578160405163409140df60e11b81526004016104289190610b95565b919050565b6107716108fb565b61058d8161098a565b610783816106ee565b6001600160a01b0316336001600160a01b03161461058d576000356001600160e01b03191681336040516320e0f98d60e21b815260040161042893929190610ba3565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114610813576040519150601f19603f3d011682016040523d82523d6000602084013e610818565b606091505b5090949350505050565b60048190556040518181527f2ab16834b71343f4e1d560b325168aef35dd575d15d84c31ef788e947709953690602001610571565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561088d5761088d610b6b565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f8111156108ce576108ce610b6b565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031633146104a9576000356001600160e01b0319166001604051620f948f60ea1b8152600401610428929190610bda565b60028190556040518181527f57a23b4b11f619fb9dea21a5a8115bb90103c1043eb3318d773558829d25f12c90602001610571565b60018190556040518181527f861f03c645467325a586235bb3155834f1dddf12413d0a802f416eb6d4035e6d90602001610571565b806001600160a01b03163b60000361058d57604051630bfc64a360e21b81526001600160a01b0382166004820152602401610428565b8035801515811461076457600080fd5b60008060408385031215610a1857600080fd5b610a21836109f5565b9150610a2f602084016109f5565b90509250929050565b600060208284031215610a4a57600080fd5b5035919050565b80356001600160a01b038116811461076457600080fd5b600080600060608486031215610a7d57600080fd5b610a8684610a51565b95602085013595506040909401359392505050565b80356010811061076457600080fd5b60008060408385031215610abd57600080fd5b610ac683610a9b565b9150610a2f60208401610a51565b600060208284031215610ae657600080fd5b610aef82610a9b565b9392505050565b80820180821115610b1757634e487b7160e01b600052601160045260246000fd5b92915050565b6020808252602e908201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160408201526d191e481a5b9a5d1a585b1a5e995960921b606082015260800190565b634e487b7160e01b600052602160045260246000fd5b60108110610b9157610b91610b6b565b9052565b60208101610b178284610b81565b6001600160e01b03198416815260608101610bc16020830185610b81565b6001600160a01b03929092166040919091015292915050565b6001600160e01b03198316815260408101600b8310610bfb57610bfb610b6b565b826020830152939250505056fea2646970667358221220f670acf250f786010edac02661a414750d0489157506db14ae46ea6a28ea6e6c64736f6c63430008110033", "devdoc": { "errors": { - "ErrCallerMustBeValidatorContract()": [ + "ErrBonusAlreadySent()": [ + { + "details": "Error thrown when attempting to send a bonus that has already been sent." + } + ], + "ErrContractTypeNotFound(uint8)": [ { - "details": "Error of method caller must be validator contract." + "details": "Error of invalid role." } ], - "ErrInsufficientBalance()": [ + "ErrInsufficientBalance(bytes4,uint256,uint256)": [ { "details": "Error of sender has insufficient balance." } ], - "ErrRecipientRevert()": [ + "ErrInvalidArguments(bytes4)": [ + { + "details": "Error indicating that arguments are invalid." + } + ], + "ErrRecipientRevert(bytes4)": [ { "details": "Error of recipient not accepting RON when transfer RON." } ], - "ErrZeroCodeContract()": [ + "ErrUnauthorized(bytes4,uint8)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "expectedRole": "The role required to perform the function.", + "msgSig": "The function signature (bytes4) that the caller is unauthorized to perform." + } + } + ], + "ErrUnexpectedInternalCall(bytes4,uint8,address)": [ + { + "details": "Error indicating that the caller is unauthorized to perform a specific function.", + "params": { + "actual": "The actual address that called to the function.", + "expectedContractType": "The contract type required to perform the function.", + "msgSig": "The function signature (bytes4)." + } + } + ], + "ErrZeroCodeContract(address)": [ { "details": "Error of set to non-contract." } @@ -380,6 +577,18 @@ "bridgeOperatorBlockBonus(uint256)": { "details": "Returns the bonus amount for the bridge validator at `_block`." }, + "fastFinalityRewardPercentage()": { + "details": "Returns the percentage of fast finality reward." + }, + "getContract(uint8)": { + "details": "Returns the address of a contract with a specific role. Throws an error if no contract is set for the specified role.", + "params": { + "contractType": "The role of the contract to retrieve." + }, + "returns": { + "contract_": "The address of the contract with the specified role." + } + }, "initialize(address,uint256,uint256)": { "details": "Initializes the contract storage." }, @@ -389,13 +598,14 @@ "requestBonus(bool,bool)": { "details": "Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined. Requirements: - The method caller must be validator contract. - The method must be called only once per block. Emits the event `BonusTransferred` or `BonusTransferFailed`. Notes: - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method will not be reverted, and the underlying nodes does not hang.", "params": { - "_forBlockProducer": "Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.", - "_forBridgeOperator": "Indicates whether requesting the bonus for the bridge operator." + "forBlockProducer": "Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.", + "forBridgeOperator": "Indicates whether requesting the bonus for the bridge operator." }, "returns": { - "_blockProducerBonus": "The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.", - "_bridgeOperatorBonus": "The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.", - "_success": "Whether the transfer is successfully. This returns false mostly because this contract is out of balance." + "blockProducerBonus": "The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.", + "bridgeOperatorBonus": "The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.", + "fastFinalityRewardPercent": "The percent of fast finality reward, returns 0 when the transfer is failed.", + "success": "Whether the transfer is successfully. This returns false mostly because this contract is out of balance." } }, "setBlockProducerBonusPerBlock(uint256)": { @@ -404,11 +614,15 @@ "setBridgeOperatorBonusPerBlock(uint256)": { "details": "Sets the bonus amount per block for bridge operator. Emits the event `BridgeOperatorBonusPerBlockUpdated`. Requirements: - The method caller is admin." }, - "setValidatorContract(address)": { - "details": "Sets the validator contract. Requirements: - The method caller is admin. - The new address is a contract. Emits the event `ValidatorContractUpdated`." + "setContract(uint8,address)": { + "details": "Sets the address of a contract with a specific role. Emits the event {ContractUpdated}.", + "params": { + "addr": "The address of the contract to set.", + "contractType": "The role of the contract to set." + } }, - "validatorContract()": { - "details": "Returns the validator contract." + "setFastFinalityRewardPercentage(uint256)": { + "details": "Sets the percent of fast finality reward. Emits the event `FastFinalityRewardPercentageUpdated`. Requirements: - The method caller is admin." } }, "stateVariables": { @@ -418,6 +632,9 @@ "_bridgeOperatorBonusPerBlock": { "details": "The block bonus for the bridge operator whenever a new block is mined." }, + "_fastFinalityRewardPercentage": { + "details": "The percentage that extracted from reward of block producer for fast finality." + }, "lastBlockSendingBonus": { "details": "The last block number that the staking vesting sent." } @@ -432,12 +649,12 @@ "storageLayout": { "storage": [ { - "astId": 7051, + "astId": 41900, "contract": "contracts/ronin/StakingVesting.sol:StakingVesting", - "label": "_validatorContract", + "label": "______deprecatedValidator", "offset": 0, "slot": "0", - "type": "t_contract(IRoninValidatorSet)11967" + "type": "t_address" }, { "astId": 1373, @@ -456,7 +673,7 @@ "type": "t_bool" }, { - "astId": 22723, + "astId": 25700, "contract": "contracts/ronin/StakingVesting.sol:StakingVesting", "label": "_blockProducerBonusPerBlock", "offset": 0, @@ -464,7 +681,7 @@ "type": "t_uint256" }, { - "astId": 22726, + "astId": 25703, "contract": "contracts/ronin/StakingVesting.sol:StakingVesting", "label": "_bridgeOperatorBonusPerBlock", "offset": 0, @@ -472,25 +689,33 @@ "type": "t_uint256" }, { - "astId": 22729, + "astId": 25706, "contract": "contracts/ronin/StakingVesting.sol:StakingVesting", "label": "lastBlockSendingBonus", "offset": 0, "slot": "3", "type": "t_uint256" + }, + { + "astId": 25709, + "contract": "contracts/ronin/StakingVesting.sol:StakingVesting", + "label": "_fastFinalityRewardPercentage", + "offset": 0, + "slot": "4", + "type": "t_uint256" } ], "types": { + "t_address": { + "encoding": "inplace", + "label": "address", + "numberOfBytes": "20" + }, "t_bool": { "encoding": "inplace", "label": "bool", "numberOfBytes": "1" }, - "t_contract(IRoninValidatorSet)11967": { - "encoding": "inplace", - "label": "contract IRoninValidatorSet", - "numberOfBytes": "20" - }, "t_uint256": { "encoding": "inplace", "label": "uint256", diff --git a/deployments/ronin-mainnet/solcInputs/03301f9cfaf1eb8782a7c2a7b1973053.json b/deployments/ronin-mainnet/solcInputs/03301f9cfaf1eb8782a7c2a7b1973053.json new file mode 100644 index 000000000..c444ceecf --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/03301f9cfaf1eb8782a7c2a7b1973053.json @@ -0,0 +1,154 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 10 + }, + "metadata": { + "bytecodeHash": "none" + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata" + ], + "": [ + "ast" + ] + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/0e13282b1de32a862f3ea9c3dc0543e9.json b/deployments/ronin-mainnet/solcInputs/0e13282b1de32a862f3ea9c3dc0543e9.json new file mode 100644 index 000000000..d28f83d64 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/0e13282b1de32a862f3ea9c3dc0543e9.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV3.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV3 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV3-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV3 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV3.sol\";\n\ncontract MainchainGatewayV3 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV3\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV3\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV3Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV3.sol\";\n\ncontract MockRoninGatewayV3Extended is RoninGatewayV3 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV3.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV3.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV3 is\n GatewayV3,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value)\n bool private ___deprecated4;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata /* _withdrawalMigrators */,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getWithdrawalSignatures(\n uint256 withdrawalId,\n address[] calldata operators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](operators.length);\n for (uint256 _i = 0; _i < operators.length; ) {\n _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata withdrawals,\n bytes[] calldata signatures\n ) external whenNotPaused onlyBridgeOperator {\n address operator = msg.sender;\n\n if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < withdrawals.length; ) {\n id = withdrawals[_i];\n _withdrawalSig[id][operator] = signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id];\n VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal {\n uint256 id = receipt.id;\n receipt.info.validate();\n if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId);\n\n if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id];\n bytes32 _receiptHash = receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash);\n emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n receipt.id\n );\n emit Deposited(_receiptHash, receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/20f35804d80bd26382f04e7db0eee067.json b/deployments/ronin-mainnet/solcInputs/20f35804d80bd26382f04e7db0eee067.json new file mode 100644 index 000000000..3a77f7ab2 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/20f35804d80bd26382f04e7db0eee067.json @@ -0,0 +1,223 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 10 + }, + "metadata": { + "bytecodeHash": "none" + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata" + ], + "": [ + "ast" + ] + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/8a10de68ec323e5be85b46f42143fc19.json b/deployments/ronin-mainnet/solcInputs/8a10de68ec323e5be85b46f42143fc19.json new file mode 100644 index 000000000..40d4bc781 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/8a10de68ec323e5be85b46f42143fc19.json @@ -0,0 +1,564 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV3.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV3 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV3-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV3 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV3.sol\";\n\ncontract MainchainGatewayV3 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV3Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV3.sol\";\n\ncontract MockRoninGatewayV3Extended is RoninGatewayV3 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV3.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV3.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV3 is\n GatewayV3,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value)\n bool private ___deprecated4;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata /* _withdrawalMigrators */,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getWithdrawalSignatures(\n uint256 withdrawalId,\n address[] calldata operators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](operators.length);\n for (uint256 _i = 0; _i < operators.length; ) {\n _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata withdrawals,\n bytes[] calldata signatures\n ) external whenNotPaused onlyBridgeOperator {\n address operator = msg.sender;\n\n if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < withdrawals.length; ) {\n id = withdrawals[_i];\n _withdrawalSig[id][operator] = signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id];\n VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal {\n uint256 id = receipt.id;\n receipt.info.validate();\n if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId);\n\n if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id];\n bytes32 _receiptHash = receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash);\n emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n receipt.id\n );\n emit Deposited(_receiptHash, receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/c681844a462c08b610099ffca6511819.json b/deployments/ronin-mainnet/solcInputs/c681844a462c08b610099ffca6511819.json new file mode 100644 index 000000000..036a6d9a8 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/c681844a462c08b610099ffca6511819.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV2 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV2.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV2 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV2-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external returns (bool slashed);\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV2 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV2 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV2.sol\";\n\ncontract MainchainGatewayV2 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV2Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV2.sol\";\n\ncontract MockRoninGatewayV2Extended is RoninGatewayV2 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setRewardPerPeriod(rewardPerPeriod);\n _syncLatestRewardedPeriod();\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Internal function to synchronize the latest rewarded period based on the current period of the validator set contract.\n * @notice This function is used internally to synchronize the latest rewarded period with the current period of the validator set contract.\n * @notice The `currentPeriod` of the validator set contract is retrieved and stored in the `LATEST_REWARDED_PERIOD_SLOT`.\n * @notice This function ensures that the latest rewarded period is updated to reflect the current period in the validator set contract.\n */\n function _syncLatestRewardedPeriod() internal {\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory allBridgeOperators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) onlyPeriodHasEnoughVotes(totalVote) returns (bool slashed) {\n uint256 length = allBridgeOperators.length;\n if (length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) return false;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return false;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = allBridgeOperators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n slashed = true;\n\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnUnstarted() {\n _skipOnUnstarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnUnstarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(address bridgeManager, address bridgeSlash, address bridgeReward) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnUnstarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnUnstarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV2.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV2.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV2 is\n GatewayV2,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_MIGRATOR = keccak256(\"WITHDRAWAL_MIGRATOR\");\n\n /// @dev Flag indicating whether the withdrawal migrate progress is done\n bool public withdrawalMigrated;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata _withdrawalMigrators,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n\n for (uint256 _i; _i < _withdrawalMigrators.length; ) {\n _grantRole(WITHDRAWAL_MIGRATOR, _withdrawalMigrators[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @dev Migrates withdrawals.\n *\n * Requirements:\n * - The method caller is the migrator.\n * - The arrays have the same length and its length larger than 0.\n *\n */\n function migrateWithdrawals(\n Transfer.Request[] calldata _requests,\n address[] calldata _requesters\n ) external onlyRole(WITHDRAWAL_MIGRATOR) {\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n if (!(_requesters.length == _requests.length && _requests.length > 0)) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _requests.length; ) {\n MappedToken memory _token = getMainchainToken(_requests[_i].tokenAddr, 1);\n if (_requests[_i].info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _storeAsReceipt(_requests[_i], 1, _requesters[_i], _token.tokenAddr);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Mark the migration as done.\n */\n function markWithdrawalMigrated() external {\n if (!(hasRole(DEFAULT_ADMIN_ROLE, msg.sender) || hasRole(WITHDRAWAL_MIGRATOR, msg.sender))) {\n revert ErrUnauthorized(msg.sig, RoleAccess.WITHDRAWAL_MIGRATOR);\n }\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n\n withdrawalMigrated = true;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](_validators.length);\n for (uint256 _i = 0; _i < _validators.length; ) {\n _signatures[_i] = _withdrawalSig[_withdrawalId][_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata _withdrawals,\n bytes[] calldata _signatures\n ) external whenNotPaused onlyBridgeOperator {\n address _validator = msg.sender;\n\n if (!(_withdrawals.length > 0 && _withdrawals.length == _signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawals.length; ) {\n _id = _withdrawals[_i];\n _withdrawalSig[_id][_validator] = _signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, _id, _validator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[_id];\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, bytes32(_id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, _id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory _receipt, address _validator, uint256 _minVoteWeight) internal {\n uint256 _id = _receipt.id;\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (_receipt.ronin.chainId != block.chainid)\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(_receipt.ronin.tokenAddr, _receipt.mainchain.chainId);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[_receipt.mainchain.chainId][_id];\n bytes32 _receiptHash = _receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, _receiptHash);\n emit DepositVoted(_validator, _id, _receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _receipt.info.handleAssetTransfer(payable(_receipt.ronin.addr), _receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id\n );\n emit Deposited(_receiptHash, _receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateTestnet() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[25] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1\n ];\n for (uint i; i < consensusList.length; i++) {\n _migrateMainnetHelper(consensusList[i]);\n }\n\n address[4] memory renouncedList = [\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n CandidateProfile storage _profile;\n for (uint i; i < renouncedList.length; i++) {\n _profile = _id2Profile[renouncedList[i]];\n _setConsensus(_profile, renouncedList[i]);\n }\n }\n\n function _migrateMainnetHelper(address consensus) internal {\n CandidateProfile storage _profile = _id2Profile[consensus];\n ICandidateManager.ValidatorCandidate memory info = IRoninValidatorSet(getContract(ContractType.VALIDATOR))\n .getCandidateInfo(consensus);\n _setConsensus(_profile, consensus);\n _setAdmin(_profile, info.admin);\n _setTreasury(_profile, payable(info.treasuryAddr));\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { HasProxyAdmin, HasContracts } from \"../../../extensions/collections/HasContracts.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl, HasContracts {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override(ConditionalImplementControl, IdentityGuard) {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json b/deployments/ronin-mainnet/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json new file mode 100644 index 000000000..399649bc2 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/d5751a51f1eb067d18a7dec1633f85eb.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV2 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV2.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV2 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV2-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV2 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV2 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV2.sol\";\n\ncontract MainchainGatewayV2 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV2\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV2Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV2.sol\";\n\ncontract MockRoninGatewayV2Extended is RoninGatewayV2 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV2.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV2.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV2 is\n GatewayV2,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV2,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_MIGRATOR = keccak256(\"WITHDRAWAL_MIGRATOR\");\n\n /// @dev Flag indicating whether the withdrawal migrate progress is done\n bool public withdrawalMigrated;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata _withdrawalMigrators,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n\n for (uint256 _i; _i < _withdrawalMigrators.length; ) {\n _grantRole(WITHDRAWAL_MIGRATOR, _withdrawalMigrators[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @dev Migrates withdrawals.\n *\n * Requirements:\n * - The method caller is the migrator.\n * - The arrays have the same length and its length larger than 0.\n *\n */\n function migrateWithdrawals(\n Transfer.Request[] calldata _requests,\n address[] calldata _requesters\n ) external onlyRole(WITHDRAWAL_MIGRATOR) {\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n if (!(_requesters.length == _requests.length && _requests.length > 0)) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _requests.length; ) {\n MappedToken memory _token = getMainchainToken(_requests[_i].tokenAddr, 1);\n if (_requests[_i].info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _storeAsReceipt(_requests[_i], 1, _requesters[_i], _token.tokenAddr);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Mark the migration as done.\n */\n function markWithdrawalMigrated() external {\n if (!(hasRole(DEFAULT_ADMIN_ROLE, msg.sender) || hasRole(WITHDRAWAL_MIGRATOR, msg.sender))) {\n revert ErrUnauthorized(msg.sig, RoleAccess.WITHDRAWAL_MIGRATOR);\n }\n if (withdrawalMigrated) revert ErrWithdrawalsMigrated();\n\n withdrawalMigrated = true;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](_validators.length);\n for (uint256 _i = 0; _i < _validators.length; ) {\n _signatures[_i] = _withdrawalSig[_withdrawalId][_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata _withdrawals,\n bytes[] calldata _signatures\n ) external whenNotPaused onlyBridgeOperator {\n address _validator = msg.sender;\n\n if (!(_withdrawals.length > 0 && _withdrawals.length == _signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawals.length; ) {\n _id = _withdrawals[_i];\n _withdrawalSig[_id][_validator] = _signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, _id, _validator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[_id];\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, bytes32(_id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, _id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV2\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory _receipt, address _validator, uint256 _minVoteWeight) internal {\n uint256 _id = _receipt.id;\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (_receipt.ronin.chainId != block.chainid)\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(_receipt.ronin.tokenAddr, _receipt.mainchain.chainId);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[_receipt.mainchain.chainId][_id];\n bytes32 _receiptHash = _receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, _validator, _minVoteWeight, _receiptHash);\n emit DepositVoted(_validator, _id, _receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _receipt.info.handleAssetTransfer(payable(_receipt.ronin.addr), _receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id\n );\n emit Deposited(_receiptHash, _receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV2\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/d621ebdfe20690422990472986e02493.json b/deployments/ronin-mainnet/solcInputs/d621ebdfe20690422990472986e02493.json new file mode 100644 index 000000000..06b8edee6 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/d621ebdfe20690422990472986e02493.json @@ -0,0 +1,132 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/dc057a85cb82f6c5109f62edfa65ae8d.json b/deployments/ronin-mainnet/solcInputs/dc057a85cb82f6c5109f62edfa65ae8d.json new file mode 100644 index 000000000..fe0db04d4 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/dc057a85cb82f6c5109f62edfa65ae8d.json @@ -0,0 +1,154 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 10 + }, + "metadata": { + "useLiteralContent": true + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata" + ], + "": [ + "ast" + ] + } + } + } +} \ No newline at end of file diff --git a/deployments/ronin-mainnet/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json b/deployments/ronin-mainnet/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json new file mode 100644 index 000000000..ae441e766 --- /dev/null +++ b/deployments/ronin-mainnet/solcInputs/f9f5036294d35a88da21dae55fc8b26c.json @@ -0,0 +1,636 @@ +{ + "language": "Solidity", + "sources": { + "@openzeppelin/contracts/access/AccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/AccessControl.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\nimport \"../utils/Context.sol\";\nimport \"../utils/Strings.sol\";\nimport \"../utils/introspection/ERC165.sol\";\n\n/**\n * @dev Contract module that allows children to implement role-based access\n * control mechanisms. This is a lightweight version that doesn't allow enumerating role\n * members except through off-chain means by accessing the contract event logs. Some\n * applications may benefit from on-chain enumerability, for those cases see\n * {AccessControlEnumerable}.\n *\n * Roles are referred to by their `bytes32` identifier. These should be exposed\n * in the external API and be unique. The best way to achieve this is by\n * using `public constant` hash digests:\n *\n * ```\n * bytes32 public constant MY_ROLE = keccak256(\"MY_ROLE\");\n * ```\n *\n * Roles can be used to represent a set of permissions. To restrict access to a\n * function call, use {hasRole}:\n *\n * ```\n * function foo() public {\n * require(hasRole(MY_ROLE, msg.sender));\n * ...\n * }\n * ```\n *\n * Roles can be granted and revoked dynamically via the {grantRole} and\n * {revokeRole} functions. Each role has an associated admin role, and only\n * accounts that have a role's admin role can call {grantRole} and {revokeRole}.\n *\n * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means\n * that only accounts with this role will be able to grant or revoke other\n * roles. More complex role relationships can be created by using\n * {_setRoleAdmin}.\n *\n * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to\n * grant and revoke this role. Extra precautions should be taken to secure\n * accounts that have been granted it.\n */\nabstract contract AccessControl is Context, IAccessControl, ERC165 {\n struct RoleData {\n mapping(address => bool) members;\n bytes32 adminRole;\n }\n\n mapping(bytes32 => RoleData) private _roles;\n\n bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;\n\n /**\n * @dev Modifier that checks that an account has a specific role. Reverts\n * with a standardized message including the required role.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n *\n * _Available since v4.1._\n */\n modifier onlyRole(bytes32 role) {\n _checkRole(role);\n _;\n }\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) public view virtual override returns (bool) {\n return _roles[role].members[account];\n }\n\n /**\n * @dev Revert with a standard message if `_msgSender()` is missing `role`.\n * Overriding this function changes the behavior of the {onlyRole} modifier.\n *\n * Format of the revert message is described in {_checkRole}.\n *\n * _Available since v4.6._\n */\n function _checkRole(bytes32 role) internal view virtual {\n _checkRole(role, _msgSender());\n }\n\n /**\n * @dev Revert with a standard message if `account` is missing `role`.\n *\n * The format of the revert reason is given by the following regular expression:\n *\n * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/\n */\n function _checkRole(bytes32 role, address account) internal view virtual {\n if (!hasRole(role, account)) {\n revert(\n string(\n abi.encodePacked(\n \"AccessControl: account \",\n Strings.toHexString(uint160(account), 20),\n \" is missing role \",\n Strings.toHexString(uint256(role), 32)\n )\n )\n );\n }\n }\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) {\n return _roles[role].adminRole;\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleGranted} event.\n */\n function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _grantRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n *\n * May emit a {RoleRevoked} event.\n */\n function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) {\n _revokeRole(role, account);\n }\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been revoked `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n *\n * May emit a {RoleRevoked} event.\n */\n function renounceRole(bytes32 role, address account) public virtual override {\n require(account == _msgSender(), \"AccessControl: can only renounce roles for self\");\n\n _revokeRole(role, account);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event. Note that unlike {grantRole}, this function doesn't perform any\n * checks on the calling account.\n *\n * May emit a {RoleGranted} event.\n *\n * [WARNING]\n * ====\n * This function should only be called from the constructor when setting\n * up the initial roles for the system.\n *\n * Using this function in any other way is effectively circumventing the admin\n * system imposed by {AccessControl}.\n * ====\n *\n * NOTE: This function is deprecated in favor of {_grantRole}.\n */\n function _setupRole(bytes32 role, address account) internal virtual {\n _grantRole(role, account);\n }\n\n /**\n * @dev Sets `adminRole` as ``role``'s admin role.\n *\n * Emits a {RoleAdminChanged} event.\n */\n function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {\n bytes32 previousAdminRole = getRoleAdmin(role);\n _roles[role].adminRole = adminRole;\n emit RoleAdminChanged(role, previousAdminRole, adminRole);\n }\n\n /**\n * @dev Grants `role` to `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleGranted} event.\n */\n function _grantRole(bytes32 role, address account) internal virtual {\n if (!hasRole(role, account)) {\n _roles[role].members[account] = true;\n emit RoleGranted(role, account, _msgSender());\n }\n }\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * Internal function without access restriction.\n *\n * May emit a {RoleRevoked} event.\n */\n function _revokeRole(bytes32 role, address account) internal virtual {\n if (hasRole(role, account)) {\n _roles[role].members[account] = false;\n emit RoleRevoked(role, account, _msgSender());\n }\n }\n}\n" + }, + "@openzeppelin/contracts/access/AccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (access/AccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControlEnumerable.sol\";\nimport \"./AccessControl.sol\";\nimport \"../utils/structs/EnumerableSet.sol\";\n\n/**\n * @dev Extension of {AccessControl} that allows enumerating the members of each role.\n */\nabstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n mapping(bytes32 => EnumerableSet.AddressSet) private _roleMembers;\n\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IAccessControlEnumerable).interfaceId || super.supportsInterface(interfaceId);\n }\n\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) public view virtual override returns (address) {\n return _roleMembers[role].at(index);\n }\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) public view virtual override returns (uint256) {\n return _roleMembers[role].length();\n }\n\n /**\n * @dev Overload {_grantRole} to track enumerable memberships\n */\n function _grantRole(bytes32 role, address account) internal virtual override {\n super._grantRole(role, account);\n _roleMembers[role].add(account);\n }\n\n /**\n * @dev Overload {_revokeRole} to track enumerable memberships\n */\n function _revokeRole(bytes32 role, address account) internal virtual override {\n super._revokeRole(role, account);\n _roleMembers[role].remove(account);\n }\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControl.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev External interface of AccessControl declared to support ERC165 detection.\n */\ninterface IAccessControl {\n /**\n * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`\n *\n * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite\n * {RoleAdminChanged} not being emitted signaling this.\n *\n * _Available since v3.1._\n */\n event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);\n\n /**\n * @dev Emitted when `account` is granted `role`.\n *\n * `sender` is the account that originated the contract call, an admin role\n * bearer except when using {AccessControl-_setupRole}.\n */\n event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Emitted when `account` is revoked `role`.\n *\n * `sender` is the account that originated the contract call:\n * - if using `revokeRole`, it is the admin role bearer\n * - if using `renounceRole`, it is the role bearer (i.e. `account`)\n */\n event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);\n\n /**\n * @dev Returns `true` if `account` has been granted `role`.\n */\n function hasRole(bytes32 role, address account) external view returns (bool);\n\n /**\n * @dev Returns the admin role that controls `role`. See {grantRole} and\n * {revokeRole}.\n *\n * To change a role's admin, use {AccessControl-_setRoleAdmin}.\n */\n function getRoleAdmin(bytes32 role) external view returns (bytes32);\n\n /**\n * @dev Grants `role` to `account`.\n *\n * If `account` had not been already granted `role`, emits a {RoleGranted}\n * event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function grantRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from `account`.\n *\n * If `account` had been granted `role`, emits a {RoleRevoked} event.\n *\n * Requirements:\n *\n * - the caller must have ``role``'s admin role.\n */\n function revokeRole(bytes32 role, address account) external;\n\n /**\n * @dev Revokes `role` from the calling account.\n *\n * Roles are often managed via {grantRole} and {revokeRole}: this function's\n * purpose is to provide a mechanism for accounts to lose their privileges\n * if they are compromised (such as when a trusted device is misplaced).\n *\n * If the calling account had been granted `role`, emits a {RoleRevoked}\n * event.\n *\n * Requirements:\n *\n * - the caller must be `account`.\n */\n function renounceRole(bytes32 role, address account) external;\n}\n" + }, + "@openzeppelin/contracts/access/IAccessControlEnumerable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (access/IAccessControlEnumerable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IAccessControl.sol\";\n\n/**\n * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.\n */\ninterface IAccessControlEnumerable is IAccessControl {\n /**\n * @dev Returns one of the accounts that have `role`. `index` must be a\n * value between 0 and {getRoleMemberCount}, non-inclusive.\n *\n * Role bearers are not sorted in any particular way, and their ordering may\n * change at any point.\n *\n * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure\n * you perform all queries on the same block. See the following\n * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]\n * for more information.\n */\n function getRoleMember(bytes32 role, uint256 index) external view returns (address);\n\n /**\n * @dev Returns the number of accounts that have `role`. Can be used\n * together with {getRoleMember} to enumerate all bearers of a role.\n */\n function getRoleMemberCount(bytes32 role) external view returns (uint256);\n}\n" + }, + "@openzeppelin/contracts/access/Ownable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which provides a basic access control mechanism, where\n * there is an account (an owner) that can be granted exclusive access to\n * specific functions.\n *\n * By default, the owner account will be the one that deploys the contract. This\n * can later be changed with {transferOwnership}.\n *\n * This module is used through inheritance. It will make available the modifier\n * `onlyOwner`, which can be applied to your functions to restrict their use to\n * the owner.\n */\nabstract contract Ownable is Context {\n address private _owner;\n\n event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);\n\n /**\n * @dev Initializes the contract setting the deployer as the initial owner.\n */\n constructor() {\n _transferOwnership(_msgSender());\n }\n\n /**\n * @dev Throws if called by any account other than the owner.\n */\n modifier onlyOwner() {\n _checkOwner();\n _;\n }\n\n /**\n * @dev Returns the address of the current owner.\n */\n function owner() public view virtual returns (address) {\n return _owner;\n }\n\n /**\n * @dev Throws if the sender is not the owner.\n */\n function _checkOwner() internal view virtual {\n require(owner() == _msgSender(), \"Ownable: caller is not the owner\");\n }\n\n /**\n * @dev Leaves the contract without owner. It will not be possible to call\n * `onlyOwner` functions anymore. Can only be called by the current owner.\n *\n * NOTE: Renouncing ownership will leave the contract without an owner,\n * thereby removing any functionality that is only available to the owner.\n */\n function renounceOwnership() public virtual onlyOwner {\n _transferOwnership(address(0));\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Can only be called by the current owner.\n */\n function transferOwnership(address newOwner) public virtual onlyOwner {\n require(newOwner != address(0), \"Ownable: new owner is the zero address\");\n _transferOwnership(newOwner);\n }\n\n /**\n * @dev Transfers ownership of the contract to a new account (`newOwner`).\n * Internal function without access restriction.\n */\n function _transferOwnership(address newOwner) internal virtual {\n address oldOwner = _owner;\n _owner = newOwner;\n emit OwnershipTransferred(oldOwner, newOwner);\n }\n}\n" + }, + "@openzeppelin/contracts/interfaces/draft-IERC1822.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (interfaces/draft-IERC1822.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev ERC1822: Universal Upgradeable Proxy Standard (UUPS) documents a method for upgradeability through a simplified\n * proxy whose upgrades are fully controlled by the current implementation.\n */\ninterface IERC1822Proxiable {\n /**\n * @dev Returns the storage slot that the proxiable contract assumes is being used to store the implementation\n * address.\n *\n * IMPORTANT: A proxy pointing at a proxiable contract should not be considered proxiable itself, because this risks\n * bricking a proxy that upgrades to it, by delegating to itself until out of gas. Thus it is critical that this\n * function revert if invoked through a proxy.\n */\n function proxiableUUID() external view returns (bytes32);\n}\n" + }, + "@openzeppelin/contracts/proxy/beacon/IBeacon.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/beacon/IBeacon.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This is the interface that {BeaconProxy} expects of its beacon.\n */\ninterface IBeacon {\n /**\n * @dev Must return an address that can be used as a delegate call target.\n *\n * {BeaconProxy} will check that this address is a contract.\n */\n function implementation() external view returns (address);\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/ERC1967/ERC1967Proxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Proxy.sol\";\nimport \"./ERC1967Upgrade.sol\";\n\n/**\n * @dev This contract implements an upgradeable proxy. It is upgradeable because calls are delegated to an\n * implementation address that can be changed. This address is stored in storage in the location specified by\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967], so that it doesn't conflict with the storage layout of the\n * implementation behind the proxy.\n */\ncontract ERC1967Proxy is Proxy, ERC1967Upgrade {\n /**\n * @dev Initializes the upgradeable proxy with an initial implementation specified by `_logic`.\n *\n * If `_data` is nonempty, it's used as data in a delegate call to `_logic`. This will typically be an encoded\n * function call, and allows initializing the storage of the proxy like a Solidity constructor.\n */\n constructor(address _logic, bytes memory _data) payable {\n _upgradeToAndCall(_logic, _data, false);\n }\n\n /**\n * @dev Returns the current implementation address.\n */\n function _implementation() internal view virtual override returns (address impl) {\n return ERC1967Upgrade._getImplementation();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (proxy/ERC1967/ERC1967Upgrade.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../beacon/IBeacon.sol\";\nimport \"../../interfaces/draft-IERC1822.sol\";\nimport \"../../utils/Address.sol\";\nimport \"../../utils/StorageSlot.sol\";\n\n/**\n * @dev This abstract contract provides getters and event emitting update functions for\n * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.\n *\n * _Available since v4.1._\n *\n * @custom:oz-upgrades-unsafe-allow delegatecall\n */\nabstract contract ERC1967Upgrade {\n // This is the keccak-256 hash of \"eip1967.proxy.rollback\" subtracted by 1\n bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Returns the current implementation address.\n */\n function _getImplementation() internal view returns (address) {\n return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 implementation slot.\n */\n function _setImplementation(address newImplementation) private {\n require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n }\n\n /**\n * @dev Perform implementation upgrade\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeTo(address newImplementation) internal {\n _setImplementation(newImplementation);\n emit Upgraded(newImplementation);\n }\n\n /**\n * @dev Perform implementation upgrade with additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCall(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n _upgradeTo(newImplementation);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(newImplementation, data);\n }\n }\n\n /**\n * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.\n *\n * Emits an {Upgraded} event.\n */\n function _upgradeToAndCallUUPS(\n address newImplementation,\n bytes memory data,\n bool forceCall\n ) internal {\n // Upgrades from old implementations will perform a rollback test. This test requires the new\n // implementation to upgrade back to the old, non-ERC1822 compliant, implementation. Removing\n // this special case will break upgrade paths from old UUPS implementation to new ones.\n if (StorageSlot.getBooleanSlot(_ROLLBACK_SLOT).value) {\n _setImplementation(newImplementation);\n } else {\n try IERC1822Proxiable(newImplementation).proxiableUUID() returns (bytes32 slot) {\n require(slot == _IMPLEMENTATION_SLOT, \"ERC1967Upgrade: unsupported proxiableUUID\");\n } catch {\n revert(\"ERC1967Upgrade: new implementation is not UUPS\");\n }\n _upgradeToAndCall(newImplementation, data, forceCall);\n }\n }\n\n /**\n * @dev Storage slot with the admin of the contract.\n * This is the keccak-256 hash of \"eip1967.proxy.admin\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n /**\n * @dev Emitted when the admin account has changed.\n */\n event AdminChanged(address previousAdmin, address newAdmin);\n\n /**\n * @dev Returns the current admin.\n */\n function _getAdmin() internal view returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n /**\n * @dev Stores a new address in the EIP1967 admin slot.\n */\n function _setAdmin(address newAdmin) private {\n require(newAdmin != address(0), \"ERC1967: new admin is the zero address\");\n StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n */\n function _changeAdmin(address newAdmin) internal {\n emit AdminChanged(_getAdmin(), newAdmin);\n _setAdmin(newAdmin);\n }\n\n /**\n * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.\n * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.\n */\n bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;\n\n /**\n * @dev Emitted when the beacon is upgraded.\n */\n event BeaconUpgraded(address indexed beacon);\n\n /**\n * @dev Returns the current beacon.\n */\n function _getBeacon() internal view returns (address) {\n return StorageSlot.getAddressSlot(_BEACON_SLOT).value;\n }\n\n /**\n * @dev Stores a new beacon in the EIP1967 beacon slot.\n */\n function _setBeacon(address newBeacon) private {\n require(Address.isContract(newBeacon), \"ERC1967: new beacon is not a contract\");\n require(\n Address.isContract(IBeacon(newBeacon).implementation()),\n \"ERC1967: beacon implementation is not a contract\"\n );\n StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;\n }\n\n /**\n * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does\n * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).\n *\n * Emits a {BeaconUpgraded} event.\n */\n function _upgradeBeaconToAndCall(\n address newBeacon,\n bytes memory data,\n bool forceCall\n ) internal {\n _setBeacon(newBeacon);\n emit BeaconUpgraded(newBeacon);\n if (data.length > 0 || forceCall) {\n Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/Proxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (proxy/Proxy.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM\n * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to\n * be specified by overriding the virtual {_implementation} function.\n *\n * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a\n * different contract through the {_delegate} function.\n *\n * The success and return data of the delegated call will be returned back to the caller of the proxy.\n */\nabstract contract Proxy {\n /**\n * @dev Delegates the current call to `implementation`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _delegate(address implementation) internal virtual {\n assembly {\n // Copy msg.data. We take full control of memory in this inline assembly\n // block because it will not return to Solidity code. We overwrite the\n // Solidity scratch pad at memory position 0.\n calldatacopy(0, 0, calldatasize())\n\n // Call the implementation.\n // out and outsize are 0 because we don't know the size yet.\n let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)\n\n // Copy the returned data.\n returndatacopy(0, 0, returndatasize())\n\n switch result\n // delegatecall returns 0 on error.\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n\n /**\n * @dev This is a virtual function that should be overridden so it returns the address to which the fallback function\n * and {_fallback} should delegate.\n */\n function _implementation() internal view virtual returns (address);\n\n /**\n * @dev Delegates the current call to the address returned by `_implementation()`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _fallback() internal virtual {\n _beforeFallback();\n _delegate(_implementation());\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other\n * function in the contract matches the call data.\n */\n fallback() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data\n * is empty.\n */\n receive() external payable virtual {\n _fallback();\n }\n\n /**\n * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`\n * call, or as part of the Solidity `fallback` or `receive` functions.\n *\n * If overridden should call `super._beforeFallback()`.\n */\n function _beforeFallback() internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (proxy/transparent/ProxyAdmin.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./TransparentUpgradeableProxy.sol\";\nimport \"../../access/Ownable.sol\";\n\n/**\n * @dev This is an auxiliary contract meant to be assigned as the admin of a {TransparentUpgradeableProxy}. For an\n * explanation of why you would want to use this see the documentation for {TransparentUpgradeableProxy}.\n */\ncontract ProxyAdmin is Ownable {\n /**\n * @dev Returns the current implementation of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyImplementation(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"5c60da1b\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Returns the current admin of `proxy`.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function getProxyAdmin(TransparentUpgradeableProxy proxy) public view virtual returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n (bool success, bytes memory returndata) = address(proxy).staticcall(hex\"f851a440\");\n require(success);\n return abi.decode(returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `proxy` to `newAdmin`.\n *\n * Requirements:\n *\n * - This contract must be the current admin of `proxy`.\n */\n function changeProxyAdmin(TransparentUpgradeableProxy proxy, address newAdmin) public virtual onlyOwner {\n proxy.changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation`. See {TransparentUpgradeableProxy-upgradeTo}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgrade(TransparentUpgradeableProxy proxy, address implementation) public virtual onlyOwner {\n proxy.upgradeTo(implementation);\n }\n\n /**\n * @dev Upgrades `proxy` to `implementation` and calls a function on the new implementation. See\n * {TransparentUpgradeableProxy-upgradeToAndCall}.\n *\n * Requirements:\n *\n * - This contract must be the admin of `proxy`.\n */\n function upgradeAndCall(\n TransparentUpgradeableProxy proxy,\n address implementation,\n bytes memory data\n ) public payable virtual onlyOwner {\n proxy.upgradeToAndCall{value: msg.value}(implementation, data);\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/transparent/TransparentUpgradeableProxy.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC1967/ERC1967Proxy.sol\";\n\n/**\n * @dev This contract implements a proxy that is upgradeable by an admin.\n *\n * To avoid https://medium.com/nomic-labs-blog/malicious-backdoors-in-ethereum-proxies-62629adf3357[proxy selector\n * clashing], which can potentially be used in an attack, this contract uses the\n * https://blog.openzeppelin.com/the-transparent-proxy-pattern/[transparent proxy pattern]. This pattern implies two\n * things that go hand in hand:\n *\n * 1. If any account other than the admin calls the proxy, the call will be forwarded to the implementation, even if\n * that call matches one of the admin functions exposed by the proxy itself.\n * 2. If the admin calls the proxy, it can access the admin functions, but its calls will never be forwarded to the\n * implementation. If the admin tries to call a function on the implementation it will fail with an error that says\n * \"admin cannot fallback to proxy target\".\n *\n * These properties mean that the admin account can only be used for admin actions like upgrading the proxy or changing\n * the admin, so it's best if it's a dedicated account that is not used for anything else. This will avoid headaches due\n * to sudden errors when trying to call a function from the proxy implementation.\n *\n * Our recommendation is for the dedicated account to be an instance of the {ProxyAdmin} contract. If set up this way,\n * you should think of the `ProxyAdmin` instance as the real administrative interface of your proxy.\n */\ncontract TransparentUpgradeableProxy is ERC1967Proxy {\n /**\n * @dev Initializes an upgradeable proxy managed by `_admin`, backed by the implementation at `_logic`, and\n * optionally initialized with `_data` as explained in {ERC1967Proxy-constructor}.\n */\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable ERC1967Proxy(_logic, _data) {\n _changeAdmin(admin_);\n }\n\n /**\n * @dev Modifier used internally that will delegate the call to the implementation unless the sender is the admin.\n */\n modifier ifAdmin() {\n if (msg.sender == _getAdmin()) {\n _;\n } else {\n _fallback();\n }\n }\n\n /**\n * @dev Returns the current admin.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyAdmin}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103`\n */\n function admin() external ifAdmin returns (address admin_) {\n admin_ = _getAdmin();\n }\n\n /**\n * @dev Returns the current implementation.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-getProxyImplementation}.\n *\n * TIP: To get this value clients can read directly from the storage slot shown below (specified by EIP1967) using the\n * https://eth.wiki/json-rpc/API#eth_getstorageat[`eth_getStorageAt`] RPC call.\n * `0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc`\n */\n function implementation() external ifAdmin returns (address implementation_) {\n implementation_ = _implementation();\n }\n\n /**\n * @dev Changes the admin of the proxy.\n *\n * Emits an {AdminChanged} event.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-changeProxyAdmin}.\n */\n function changeAdmin(address newAdmin) external virtual ifAdmin {\n _changeAdmin(newAdmin);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgrade}.\n */\n function upgradeTo(address newImplementation) external ifAdmin {\n _upgradeToAndCall(newImplementation, bytes(\"\"), false);\n }\n\n /**\n * @dev Upgrade the implementation of the proxy, and then call a function from the new implementation as specified\n * by `data`, which should be an encoded function call. This is useful to initialize new storage variables in the\n * proxied contract.\n *\n * NOTE: Only the admin can call this function. See {ProxyAdmin-upgradeAndCall}.\n */\n function upgradeToAndCall(address newImplementation, bytes calldata data) external payable ifAdmin {\n _upgradeToAndCall(newImplementation, data, true);\n }\n\n /**\n * @dev Returns the current admin.\n */\n function _admin() internal view virtual returns (address) {\n return _getAdmin();\n }\n\n /**\n * @dev Makes sure the admin cannot access the fallback function. See {Proxy-_beforeFallback}.\n */\n function _beforeFallback() internal virtual override {\n require(msg.sender != _getAdmin(), \"TransparentUpgradeableProxy: admin cannot fallback to proxy target\");\n super._beforeFallback();\n }\n}\n" + }, + "@openzeppelin/contracts/proxy/utils/Initializable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (proxy/utils/Initializable.sol)\n\npragma solidity ^0.8.2;\n\nimport \"../../utils/Address.sol\";\n\n/**\n * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed\n * behind a proxy. Since proxied contracts do not make use of a constructor, it's common to move constructor logic to an\n * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer\n * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.\n *\n * The initialization functions use a version number. Once a version number is used, it is consumed and cannot be\n * reused. This mechanism prevents re-execution of each \"step\" but allows the creation of new initialization steps in\n * case an upgrade adds a module that needs to be initialized.\n *\n * For example:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * contract MyToken is ERC20Upgradeable {\n * function initialize() initializer public {\n * __ERC20_init(\"MyToken\", \"MTK\");\n * }\n * }\n * contract MyTokenV2 is MyToken, ERC20PermitUpgradeable {\n * function initializeV2() reinitializer(2) public {\n * __ERC20Permit_init(\"MyToken\");\n * }\n * }\n * ```\n *\n * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as\n * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.\n *\n * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure\n * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.\n *\n * [CAUTION]\n * ====\n * Avoid leaving a contract uninitialized.\n *\n * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation\n * contract, which may impact the proxy. To prevent the implementation contract from being used, you should invoke\n * the {_disableInitializers} function in the constructor to automatically lock it when it is deployed:\n *\n * [.hljs-theme-light.nopadding]\n * ```\n * /// @custom:oz-upgrades-unsafe-allow constructor\n * constructor() {\n * _disableInitializers();\n * }\n * ```\n * ====\n */\nabstract contract Initializable {\n /**\n * @dev Indicates that the contract has been initialized.\n * @custom:oz-retyped-from bool\n */\n uint8 private _initialized;\n\n /**\n * @dev Indicates that the contract is in the process of being initialized.\n */\n bool private _initializing;\n\n /**\n * @dev Triggered when the contract has been initialized or reinitialized.\n */\n event Initialized(uint8 version);\n\n /**\n * @dev A modifier that defines a protected initializer function that can be invoked at most once. In its scope,\n * `onlyInitializing` functions can be used to initialize parent contracts. Equivalent to `reinitializer(1)`.\n */\n modifier initializer() {\n bool isTopLevelCall = !_initializing;\n require(\n (isTopLevelCall && _initialized < 1) || (!Address.isContract(address(this)) && _initialized == 1),\n \"Initializable: contract is already initialized\"\n );\n _initialized = 1;\n if (isTopLevelCall) {\n _initializing = true;\n }\n _;\n if (isTopLevelCall) {\n _initializing = false;\n emit Initialized(1);\n }\n }\n\n /**\n * @dev A modifier that defines a protected reinitializer function that can be invoked at most once, and only if the\n * contract hasn't been initialized to a greater version before. In its scope, `onlyInitializing` functions can be\n * used to initialize parent contracts.\n *\n * `initializer` is equivalent to `reinitializer(1)`, so a reinitializer may be used after the original\n * initialization step. This is essential to configure modules that are added through upgrades and that require\n * initialization.\n *\n * Note that versions can jump in increments greater than 1; this implies that if multiple reinitializers coexist in\n * a contract, executing them in the right order is up to the developer or operator.\n */\n modifier reinitializer(uint8 version) {\n require(!_initializing && _initialized < version, \"Initializable: contract is already initialized\");\n _initialized = version;\n _initializing = true;\n _;\n _initializing = false;\n emit Initialized(version);\n }\n\n /**\n * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the\n * {initializer} and {reinitializer} modifiers, directly or indirectly.\n */\n modifier onlyInitializing() {\n require(_initializing, \"Initializable: contract is not initializing\");\n _;\n }\n\n /**\n * @dev Locks the contract, preventing any future reinitialization. This cannot be part of an initializer call.\n * Calling this in the constructor of a contract will prevent that contract from being initialized or reinitialized\n * to any version. It is recommended to use this to lock implementation contracts that are designed to be called\n * through proxies.\n */\n function _disableInitializers() internal virtual {\n require(!_initializing, \"Initializable: contract is initializing\");\n if (_initialized < type(uint8).max) {\n _initialized = type(uint8).max;\n emit Initialized(type(uint8).max);\n }\n }\n}\n" + }, + "@openzeppelin/contracts/security/Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (security/Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../utils/Context.sol\";\n\n/**\n * @dev Contract module which allows children to implement an emergency stop\n * mechanism that can be triggered by an authorized account.\n *\n * This module is used through inheritance. It will make available the\n * modifiers `whenNotPaused` and `whenPaused`, which can be applied to\n * the functions of your contract. Note that they will not be pausable by\n * simply including this module, only once the modifiers are put in place.\n */\nabstract contract Pausable is Context {\n /**\n * @dev Emitted when the pause is triggered by `account`.\n */\n event Paused(address account);\n\n /**\n * @dev Emitted when the pause is lifted by `account`.\n */\n event Unpaused(address account);\n\n bool private _paused;\n\n /**\n * @dev Initializes the contract in unpaused state.\n */\n constructor() {\n _paused = false;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is not paused.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n modifier whenNotPaused() {\n _requireNotPaused();\n _;\n }\n\n /**\n * @dev Modifier to make a function callable only when the contract is paused.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n modifier whenPaused() {\n _requirePaused();\n _;\n }\n\n /**\n * @dev Returns true if the contract is paused, and false otherwise.\n */\n function paused() public view virtual returns (bool) {\n return _paused;\n }\n\n /**\n * @dev Throws if the contract is paused.\n */\n function _requireNotPaused() internal view virtual {\n require(!paused(), \"Pausable: paused\");\n }\n\n /**\n * @dev Throws if the contract is not paused.\n */\n function _requirePaused() internal view virtual {\n require(paused(), \"Pausable: not paused\");\n }\n\n /**\n * @dev Triggers stopped state.\n *\n * Requirements:\n *\n * - The contract must not be paused.\n */\n function _pause() internal virtual whenNotPaused {\n _paused = true;\n emit Paused(_msgSender());\n }\n\n /**\n * @dev Returns to normal state.\n *\n * Requirements:\n *\n * - The contract must be paused.\n */\n function _unpause() internal virtual whenPaused {\n _paused = false;\n emit Unpaused(_msgSender());\n }\n}\n" + }, + "@openzeppelin/contracts/security/ReentrancyGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Contract module that helps prevent reentrant calls to a function.\n *\n * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier\n * available, which can be applied to functions to make sure there are no nested\n * (reentrant) calls to them.\n *\n * Note that because there is a single `nonReentrant` guard, functions marked as\n * `nonReentrant` may not call one another. This can be worked around by making\n * those functions `private`, and then adding `external` `nonReentrant` entry\n * points to them.\n *\n * TIP: If you would like to learn more about reentrancy and alternative ways\n * to protect against it, check out our blog post\n * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].\n */\nabstract contract ReentrancyGuard {\n // Booleans are more expensive than uint256 or any type that takes up a full\n // word because each write operation emits an extra SLOAD to first read the\n // slot's contents, replace the bits taken up by the boolean, and then write\n // back. This is the compiler's defense against contract upgrades and\n // pointer aliasing, and it cannot be disabled.\n\n // The values being non-zero value makes deployment a bit more expensive,\n // but in exchange the refund on every call to nonReentrant will be lower in\n // amount. Since refunds are capped to a percentage of the total\n // transaction's gas, it is best to keep them low in cases like this one, to\n // increase the likelihood of the full refund coming into effect.\n uint256 private constant _NOT_ENTERED = 1;\n uint256 private constant _ENTERED = 2;\n\n uint256 private _status;\n\n constructor() {\n _status = _NOT_ENTERED;\n }\n\n /**\n * @dev Prevents a contract from calling itself, directly or indirectly.\n * Calling a `nonReentrant` function from another `nonReentrant`\n * function is not supported. It is possible to prevent this from happening\n * by making the `nonReentrant` function external, and making it call a\n * `private` function that does the actual work.\n */\n modifier nonReentrant() {\n // On the first call to nonReentrant, _notEntered will be true\n require(_status != _ENTERED, \"ReentrancyGuard: reentrant call\");\n\n // Any calls to nonReentrant after this point will fail\n _status = _ENTERED;\n\n _;\n\n // By storing the original value once again, a refund is triggered (see\n // https://eips.ethereum.org/EIPS/eip-2200)\n _status = _NOT_ENTERED;\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/ERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC20/ERC20.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC20.sol\";\nimport \"./extensions/IERC20Metadata.sol\";\nimport \"../../utils/Context.sol\";\n\n/**\n * @dev Implementation of the {IERC20} interface.\n *\n * This implementation is agnostic to the way tokens are created. This means\n * that a supply mechanism has to be added in a derived contract using {_mint}.\n * For a generic mechanism see {ERC20PresetMinterPauser}.\n *\n * TIP: For a detailed writeup see our guide\n * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How\n * to implement supply mechanisms].\n *\n * We have followed general OpenZeppelin Contracts guidelines: functions revert\n * instead returning `false` on failure. This behavior is nonetheless\n * conventional and does not conflict with the expectations of ERC20\n * applications.\n *\n * Additionally, an {Approval} event is emitted on calls to {transferFrom}.\n * This allows applications to reconstruct the allowance for all accounts just\n * by listening to said events. Other implementations of the EIP may not emit\n * these events, as it isn't required by the specification.\n *\n * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}\n * functions have been added to mitigate the well-known issues around setting\n * allowances. See {IERC20-approve}.\n */\ncontract ERC20 is Context, IERC20, IERC20Metadata {\n mapping(address => uint256) private _balances;\n\n mapping(address => mapping(address => uint256)) private _allowances;\n\n uint256 private _totalSupply;\n\n string private _name;\n string private _symbol;\n\n /**\n * @dev Sets the values for {name} and {symbol}.\n *\n * The default value of {decimals} is 18. To select a different value for\n * {decimals} you should overload it.\n *\n * All two of these values are immutable: they can only be set once during\n * construction.\n */\n constructor(string memory name_, string memory symbol_) {\n _name = name_;\n _symbol = symbol_;\n }\n\n /**\n * @dev Returns the name of the token.\n */\n function name() public view virtual override returns (string memory) {\n return _name;\n }\n\n /**\n * @dev Returns the symbol of the token, usually a shorter version of the\n * name.\n */\n function symbol() public view virtual override returns (string memory) {\n return _symbol;\n }\n\n /**\n * @dev Returns the number of decimals used to get its user representation.\n * For example, if `decimals` equals `2`, a balance of `505` tokens should\n * be displayed to a user as `5.05` (`505 / 10 ** 2`).\n *\n * Tokens usually opt for a value of 18, imitating the relationship between\n * Ether and Wei. This is the value {ERC20} uses, unless this function is\n * overridden;\n *\n * NOTE: This information is only used for _display_ purposes: it in\n * no way affects any of the arithmetic of the contract, including\n * {IERC20-balanceOf} and {IERC20-transfer}.\n */\n function decimals() public view virtual override returns (uint8) {\n return 18;\n }\n\n /**\n * @dev See {IERC20-totalSupply}.\n */\n function totalSupply() public view virtual override returns (uint256) {\n return _totalSupply;\n }\n\n /**\n * @dev See {IERC20-balanceOf}.\n */\n function balanceOf(address account) public view virtual override returns (uint256) {\n return _balances[account];\n }\n\n /**\n * @dev See {IERC20-transfer}.\n *\n * Requirements:\n *\n * - `to` cannot be the zero address.\n * - the caller must have a balance of at least `amount`.\n */\n function transfer(address to, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _transfer(owner, to, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-allowance}.\n */\n function allowance(address owner, address spender) public view virtual override returns (uint256) {\n return _allowances[owner][spender];\n }\n\n /**\n * @dev See {IERC20-approve}.\n *\n * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on\n * `transferFrom`. This is semantically equivalent to an infinite approval.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function approve(address spender, uint256 amount) public virtual override returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, amount);\n return true;\n }\n\n /**\n * @dev See {IERC20-transferFrom}.\n *\n * Emits an {Approval} event indicating the updated allowance. This is not\n * required by the EIP. See the note at the beginning of {ERC20}.\n *\n * NOTE: Does not update the allowance if the current allowance\n * is the maximum `uint256`.\n *\n * Requirements:\n *\n * - `from` and `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n * - the caller must have allowance for ``from``'s tokens of at least\n * `amount`.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) public virtual override returns (bool) {\n address spender = _msgSender();\n _spendAllowance(from, spender, amount);\n _transfer(from, to, amount);\n return true;\n }\n\n /**\n * @dev Atomically increases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n */\n function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {\n address owner = _msgSender();\n _approve(owner, spender, allowance(owner, spender) + addedValue);\n return true;\n }\n\n /**\n * @dev Atomically decreases the allowance granted to `spender` by the caller.\n *\n * This is an alternative to {approve} that can be used as a mitigation for\n * problems described in {IERC20-approve}.\n *\n * Emits an {Approval} event indicating the updated allowance.\n *\n * Requirements:\n *\n * - `spender` cannot be the zero address.\n * - `spender` must have allowance for the caller of at least\n * `subtractedValue`.\n */\n function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {\n address owner = _msgSender();\n uint256 currentAllowance = allowance(owner, spender);\n require(currentAllowance >= subtractedValue, \"ERC20: decreased allowance below zero\");\n unchecked {\n _approve(owner, spender, currentAllowance - subtractedValue);\n }\n\n return true;\n }\n\n /**\n * @dev Moves `amount` of tokens from `from` to `to`.\n *\n * This internal function is equivalent to {transfer}, and can be used to\n * e.g. implement automatic token fees, slashing mechanisms, etc.\n *\n * Emits a {Transfer} event.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `from` must have a balance of at least `amount`.\n */\n function _transfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {\n require(from != address(0), \"ERC20: transfer from the zero address\");\n require(to != address(0), \"ERC20: transfer to the zero address\");\n\n _beforeTokenTransfer(from, to, amount);\n\n uint256 fromBalance = _balances[from];\n require(fromBalance >= amount, \"ERC20: transfer amount exceeds balance\");\n unchecked {\n _balances[from] = fromBalance - amount;\n }\n _balances[to] += amount;\n\n emit Transfer(from, to, amount);\n\n _afterTokenTransfer(from, to, amount);\n }\n\n /** @dev Creates `amount` tokens and assigns them to `account`, increasing\n * the total supply.\n *\n * Emits a {Transfer} event with `from` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n */\n function _mint(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: mint to the zero address\");\n\n _beforeTokenTransfer(address(0), account, amount);\n\n _totalSupply += amount;\n _balances[account] += amount;\n emit Transfer(address(0), account, amount);\n\n _afterTokenTransfer(address(0), account, amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, reducing the\n * total supply.\n *\n * Emits a {Transfer} event with `to` set to the zero address.\n *\n * Requirements:\n *\n * - `account` cannot be the zero address.\n * - `account` must have at least `amount` tokens.\n */\n function _burn(address account, uint256 amount) internal virtual {\n require(account != address(0), \"ERC20: burn from the zero address\");\n\n _beforeTokenTransfer(account, address(0), amount);\n\n uint256 accountBalance = _balances[account];\n require(accountBalance >= amount, \"ERC20: burn amount exceeds balance\");\n unchecked {\n _balances[account] = accountBalance - amount;\n }\n _totalSupply -= amount;\n\n emit Transfer(account, address(0), amount);\n\n _afterTokenTransfer(account, address(0), amount);\n }\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.\n *\n * This internal function is equivalent to `approve`, and can be used to\n * e.g. set automatic allowances for certain subsystems, etc.\n *\n * Emits an {Approval} event.\n *\n * Requirements:\n *\n * - `owner` cannot be the zero address.\n * - `spender` cannot be the zero address.\n */\n function _approve(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n require(owner != address(0), \"ERC20: approve from the zero address\");\n require(spender != address(0), \"ERC20: approve to the zero address\");\n\n _allowances[owner][spender] = amount;\n emit Approval(owner, spender, amount);\n }\n\n /**\n * @dev Updates `owner` s allowance for `spender` based on spent `amount`.\n *\n * Does not update the allowance amount in case of infinite allowance.\n * Revert if not enough allowance is available.\n *\n * Might emit an {Approval} event.\n */\n function _spendAllowance(\n address owner,\n address spender,\n uint256 amount\n ) internal virtual {\n uint256 currentAllowance = allowance(owner, spender);\n if (currentAllowance != type(uint256).max) {\n require(currentAllowance >= amount, \"ERC20: insufficient allowance\");\n unchecked {\n _approve(owner, spender, currentAllowance - amount);\n }\n }\n }\n\n /**\n * @dev Hook that is called before any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * will be transferred to `to`.\n * - when `from` is zero, `amount` tokens will be minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens will be burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n\n /**\n * @dev Hook that is called after any transfer of tokens. This includes\n * minting and burning.\n *\n * Calling conditions:\n *\n * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens\n * has been transferred to `to`.\n * - when `from` is zero, `amount` tokens have been minted for `to`.\n * - when `to` is zero, `amount` of ``from``'s tokens have been burned.\n * - `from` and `to` are never both zero.\n *\n * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].\n */\n function _afterTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual {}\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev Extension of {ERC20} that allows token holders to destroy both their own\n * tokens and those that they have an allowance for, in a way that can be\n * recognized off-chain (via event analysis).\n */\nabstract contract ERC20Burnable is Context, ERC20 {\n /**\n * @dev Destroys `amount` tokens from the caller.\n *\n * See {ERC20-_burn}.\n */\n function burn(uint256 amount) public virtual {\n _burn(_msgSender(), amount);\n }\n\n /**\n * @dev Destroys `amount` tokens from `account`, deducting from the caller's\n * allowance.\n *\n * See {ERC20-_burn} and {ERC20-allowance}.\n *\n * Requirements:\n *\n * - the caller must have allowance for ``accounts``'s tokens of at least\n * `amount`.\n */\n function burnFrom(address account, uint256 amount) public virtual {\n _spendAllowance(account, _msgSender(), amount);\n _burn(account, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/ERC20Pausable.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/ERC20Pausable.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../../../security/Pausable.sol\";\n\n/**\n * @dev ERC20 token with pausable token transfers, minting and burning.\n *\n * Useful for scenarios such as preventing trades until the end of an evaluation\n * period, or having an emergency switch for freezing all token transfers in the\n * event of a large bug.\n */\nabstract contract ERC20Pausable is ERC20, Pausable {\n /**\n * @dev See {ERC20-_beforeTokenTransfer}.\n *\n * Requirements:\n *\n * - the contract must not be paused.\n */\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override {\n super._beforeTokenTransfer(from, to, amount);\n\n require(!paused(), \"ERC20Pausable: token transfer while paused\");\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../IERC20.sol\";\n\n/**\n * @dev Interface for the optional metadata functions from the ERC20 standard.\n *\n * _Available since v4.1._\n */\ninterface IERC20Metadata is IERC20 {\n /**\n * @dev Returns the name of the token.\n */\n function name() external view returns (string memory);\n\n /**\n * @dev Returns the symbol of the token.\n */\n function symbol() external view returns (string memory);\n\n /**\n * @dev Returns the decimals places of the token.\n */\n function decimals() external view returns (uint8);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/IERC20.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC20 standard as defined in the EIP.\n */\ninterface IERC20 {\n /**\n * @dev Emitted when `value` tokens are moved from one account (`from`) to\n * another (`to`).\n *\n * Note that `value` may be zero.\n */\n event Transfer(address indexed from, address indexed to, uint256 value);\n\n /**\n * @dev Emitted when the allowance of a `spender` for an `owner` is set by\n * a call to {approve}. `value` is the new allowance.\n */\n event Approval(address indexed owner, address indexed spender, uint256 value);\n\n /**\n * @dev Returns the amount of tokens in existence.\n */\n function totalSupply() external view returns (uint256);\n\n /**\n * @dev Returns the amount of tokens owned by `account`.\n */\n function balanceOf(address account) external view returns (uint256);\n\n /**\n * @dev Moves `amount` tokens from the caller's account to `to`.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transfer(address to, uint256 amount) external returns (bool);\n\n /**\n * @dev Returns the remaining number of tokens that `spender` will be\n * allowed to spend on behalf of `owner` through {transferFrom}. This is\n * zero by default.\n *\n * This value changes when {approve} or {transferFrom} are called.\n */\n function allowance(address owner, address spender) external view returns (uint256);\n\n /**\n * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * IMPORTANT: Beware that changing an allowance with this method brings the risk\n * that someone may use both the old and the new allowance by unfortunate\n * transaction ordering. One possible solution to mitigate this race\n * condition is to first reduce the spender's allowance to 0 and set the\n * desired value afterwards:\n * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729\n *\n * Emits an {Approval} event.\n */\n function approve(address spender, uint256 amount) external returns (bool);\n\n /**\n * @dev Moves `amount` tokens from `from` to `to` using the\n * allowance mechanism. `amount` is then deducted from the caller's\n * allowance.\n *\n * Returns a boolean value indicating whether the operation succeeded.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 amount\n ) external returns (bool);\n}\n" + }, + "@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/presets/ERC20PresetMinterPauser.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../ERC20.sol\";\nimport \"../extensions/ERC20Burnable.sol\";\nimport \"../extensions/ERC20Pausable.sol\";\nimport \"../../../access/AccessControlEnumerable.sol\";\nimport \"../../../utils/Context.sol\";\n\n/**\n * @dev {ERC20} token, including:\n *\n * - ability for holders to burn (destroy) their tokens\n * - a minter role that allows for token minting (creation)\n * - a pauser role that allows to stop all token transfers\n *\n * This contract uses {AccessControl} to lock permissioned functions using the\n * different roles - head to its documentation for details.\n *\n * The account that deploys the contract will be granted the minter and pauser\n * roles, as well as the default admin role, which will let it grant both minter\n * and pauser roles to other accounts.\n *\n * _Deprecated in favor of https://wizard.openzeppelin.com/[Contracts Wizard]._\n */\ncontract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {\n bytes32 public constant MINTER_ROLE = keccak256(\"MINTER_ROLE\");\n bytes32 public constant PAUSER_ROLE = keccak256(\"PAUSER_ROLE\");\n\n /**\n * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the\n * account that deploys the contract.\n *\n * See {ERC20-constructor}.\n */\n constructor(string memory name, string memory symbol) ERC20(name, symbol) {\n _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());\n\n _setupRole(MINTER_ROLE, _msgSender());\n _setupRole(PAUSER_ROLE, _msgSender());\n }\n\n /**\n * @dev Creates `amount` new tokens for `to`.\n *\n * See {ERC20-_mint}.\n *\n * Requirements:\n *\n * - the caller must have the `MINTER_ROLE`.\n */\n function mint(address to, uint256 amount) public virtual {\n require(hasRole(MINTER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have minter role to mint\");\n _mint(to, amount);\n }\n\n /**\n * @dev Pauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_pause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function pause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to pause\");\n _pause();\n }\n\n /**\n * @dev Unpauses all token transfers.\n *\n * See {ERC20Pausable} and {Pausable-_unpause}.\n *\n * Requirements:\n *\n * - the caller must have the `PAUSER_ROLE`.\n */\n function unpause() public virtual {\n require(hasRole(PAUSER_ROLE, _msgSender()), \"ERC20PresetMinterPauser: must have pauser role to unpause\");\n _unpause();\n }\n\n function _beforeTokenTransfer(\n address from,\n address to,\n uint256 amount\n ) internal virtual override(ERC20, ERC20Pausable) {\n super._beforeTokenTransfer(from, to, amount);\n }\n}\n" + }, + "@openzeppelin/contracts/token/ERC721/IERC721.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (token/ERC721/IERC721.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../../utils/introspection/IERC165.sol\";\n\n/**\n * @dev Required interface of an ERC721 compliant contract.\n */\ninterface IERC721 is IERC165 {\n /**\n * @dev Emitted when `tokenId` token is transferred from `from` to `to`.\n */\n event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.\n */\n event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);\n\n /**\n * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.\n */\n event ApprovalForAll(address indexed owner, address indexed operator, bool approved);\n\n /**\n * @dev Returns the number of tokens in ``owner``'s account.\n */\n function balanceOf(address owner) external view returns (uint256 balance);\n\n /**\n * @dev Returns the owner of the `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function ownerOf(uint256 tokenId) external view returns (address owner);\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId,\n bytes calldata data\n ) external;\n\n /**\n * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients\n * are aware of the ERC721 protocol to prevent tokens from being forever locked.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must exist and be owned by `from`.\n * - If the caller is not `from`, it must have been allowed to move this token by either {approve} or {setApprovalForAll}.\n * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.\n *\n * Emits a {Transfer} event.\n */\n function safeTransferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Transfers `tokenId` token from `from` to `to`.\n *\n * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.\n *\n * Requirements:\n *\n * - `from` cannot be the zero address.\n * - `to` cannot be the zero address.\n * - `tokenId` token must be owned by `from`.\n * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.\n *\n * Emits a {Transfer} event.\n */\n function transferFrom(\n address from,\n address to,\n uint256 tokenId\n ) external;\n\n /**\n * @dev Gives permission to `to` to transfer `tokenId` token to another account.\n * The approval is cleared when the token is transferred.\n *\n * Only a single account can be approved at a time, so approving the zero address clears previous approvals.\n *\n * Requirements:\n *\n * - The caller must own the token or be an approved operator.\n * - `tokenId` must exist.\n *\n * Emits an {Approval} event.\n */\n function approve(address to, uint256 tokenId) external;\n\n /**\n * @dev Approve or remove `operator` as an operator for the caller.\n * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.\n *\n * Requirements:\n *\n * - The `operator` cannot be the caller.\n *\n * Emits an {ApprovalForAll} event.\n */\n function setApprovalForAll(address operator, bool _approved) external;\n\n /**\n * @dev Returns the account approved for `tokenId` token.\n *\n * Requirements:\n *\n * - `tokenId` must exist.\n */\n function getApproved(uint256 tokenId) external view returns (address operator);\n\n /**\n * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.\n *\n * See {setApprovalForAll}\n */\n function isApprovedForAll(address owner, address operator) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/Address.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Address.sol)\n\npragma solidity ^0.8.1;\n\n/**\n * @dev Collection of functions related to the address type\n */\nlibrary Address {\n /**\n * @dev Returns true if `account` is a contract.\n *\n * [IMPORTANT]\n * ====\n * It is unsafe to assume that an address for which this function returns\n * false is an externally-owned account (EOA) and not a contract.\n *\n * Among others, `isContract` will return false for the following\n * types of addresses:\n *\n * - an externally-owned account\n * - a contract in construction\n * - an address where a contract will be created\n * - an address where a contract lived, but was destroyed\n * ====\n *\n * [IMPORTANT]\n * ====\n * You shouldn't rely on `isContract` to protect against flash loan attacks!\n *\n * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets\n * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract\n * constructor.\n * ====\n */\n function isContract(address account) internal view returns (bool) {\n // This method relies on extcodesize/address.code.length, which returns 0\n // for contracts in construction, since the code is only stored at the end\n // of the constructor execution.\n\n return account.code.length > 0;\n }\n\n /**\n * @dev Replacement for Solidity's `transfer`: sends `amount` wei to\n * `recipient`, forwarding all available gas and reverting on errors.\n *\n * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost\n * of certain opcodes, possibly making contracts go over the 2300 gas limit\n * imposed by `transfer`, making them unable to receive funds via\n * `transfer`. {sendValue} removes this limitation.\n *\n * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].\n *\n * IMPORTANT: because control is transferred to `recipient`, care must be\n * taken to not create reentrancy vulnerabilities. Consider using\n * {ReentrancyGuard} or the\n * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].\n */\n function sendValue(address payable recipient, uint256 amount) internal {\n require(address(this).balance >= amount, \"Address: insufficient balance\");\n\n (bool success, ) = recipient.call{value: amount}(\"\");\n require(success, \"Address: unable to send value, recipient may have reverted\");\n }\n\n /**\n * @dev Performs a Solidity function call using a low level `call`. A\n * plain `call` is an unsafe replacement for a function call: use this\n * function instead.\n *\n * If `target` reverts with a revert reason, it is bubbled up by this\n * function (like regular Solidity function calls).\n *\n * Returns the raw returned data. To convert to the expected return value,\n * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].\n *\n * Requirements:\n *\n * - `target` must be a contract.\n * - calling `target` with `data` must not revert.\n *\n * _Available since v3.1._\n */\n function functionCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionCall(target, data, \"Address: low-level call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with\n * `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, 0, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but also transferring `value` wei to `target`.\n *\n * Requirements:\n *\n * - the calling contract must have an ETH balance of at least `value`.\n * - the called Solidity function must be `payable`.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value\n ) internal returns (bytes memory) {\n return functionCallWithValue(target, data, value, \"Address: low-level call with value failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but\n * with `errorMessage` as a fallback revert reason when `target` reverts.\n *\n * _Available since v3.1._\n */\n function functionCallWithValue(\n address target,\n bytes memory data,\n uint256 value,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(address(this).balance >= value, \"Address: insufficient balance for call\");\n require(isContract(target), \"Address: call to non-contract\");\n\n (bool success, bytes memory returndata) = target.call{value: value}(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {\n return functionStaticCall(target, data, \"Address: low-level static call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a static call.\n *\n * _Available since v3.3._\n */\n function functionStaticCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal view returns (bytes memory) {\n require(isContract(target), \"Address: static call to non-contract\");\n\n (bool success, bytes memory returndata) = target.staticcall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {\n return functionDelegateCall(target, data, \"Address: low-level delegate call failed\");\n }\n\n /**\n * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],\n * but performing a delegate call.\n *\n * _Available since v3.4._\n */\n function functionDelegateCall(\n address target,\n bytes memory data,\n string memory errorMessage\n ) internal returns (bytes memory) {\n require(isContract(target), \"Address: delegate call to non-contract\");\n\n (bool success, bytes memory returndata) = target.delegatecall(data);\n return verifyCallResult(success, returndata, errorMessage);\n }\n\n /**\n * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the\n * revert reason using the provided one.\n *\n * _Available since v4.3._\n */\n function verifyCallResult(\n bool success,\n bytes memory returndata,\n string memory errorMessage\n ) internal pure returns (bytes memory) {\n if (success) {\n return returndata;\n } else {\n // Look for revert reason and bubble it up if present\n if (returndata.length > 0) {\n // The easiest way to bubble the revert reason is using memory via assembly\n /// @solidity memory-safe-assembly\n assembly {\n let returndata_size := mload(returndata)\n revert(add(32, returndata), returndata_size)\n }\n } else {\n revert(errorMessage);\n }\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Context.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Provides information about the current execution context, including the\n * sender of the transaction and its data. While these are generally available\n * via msg.sender and msg.data, they should not be accessed in such a direct\n * manner, since when dealing with meta-transactions the account sending and\n * paying for execution may not be the actual sender (as far as an application\n * is concerned).\n *\n * This contract is only required for intermediate, library-like contracts.\n */\nabstract contract Context {\n function _msgSender() internal view virtual returns (address) {\n return msg.sender;\n }\n\n function _msgData() internal view virtual returns (bytes calldata) {\n return msg.data;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/cryptography/ECDSA.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.3) (utils/cryptography/ECDSA.sol)\n\npragma solidity ^0.8.0;\n\nimport \"../Strings.sol\";\n\n/**\n * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.\n *\n * These functions can be used to verify that a message was signed by the holder\n * of the private keys of a given address.\n */\nlibrary ECDSA {\n enum RecoverError {\n NoError,\n InvalidSignature,\n InvalidSignatureLength,\n InvalidSignatureS,\n InvalidSignatureV\n }\n\n function _throwError(RecoverError error) private pure {\n if (error == RecoverError.NoError) {\n return; // no error: do nothing\n } else if (error == RecoverError.InvalidSignature) {\n revert(\"ECDSA: invalid signature\");\n } else if (error == RecoverError.InvalidSignatureLength) {\n revert(\"ECDSA: invalid signature length\");\n } else if (error == RecoverError.InvalidSignatureS) {\n revert(\"ECDSA: invalid signature 's' value\");\n } else if (error == RecoverError.InvalidSignatureV) {\n revert(\"ECDSA: invalid signature 'v' value\");\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature` or error string. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n *\n * Documentation for signature generation:\n * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]\n * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]\n *\n * _Available since v4.3._\n */\n function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {\n if (signature.length == 65) {\n bytes32 r;\n bytes32 s;\n uint8 v;\n // ecrecover takes the signature parameters, and the only way to get them\n // currently is to use assembly.\n /// @solidity memory-safe-assembly\n assembly {\n r := mload(add(signature, 0x20))\n s := mload(add(signature, 0x40))\n v := byte(0, mload(add(signature, 0x60)))\n }\n return tryRecover(hash, v, r, s);\n } else {\n return (address(0), RecoverError.InvalidSignatureLength);\n }\n }\n\n /**\n * @dev Returns the address that signed a hashed message (`hash`) with\n * `signature`. This address can then be used for verification purposes.\n *\n * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:\n * this function rejects them by requiring the `s` value to be in the lower\n * half order, and the `v` value to be either 27 or 28.\n *\n * IMPORTANT: `hash` _must_ be the result of a hash operation for the\n * verification to be secure: it is possible to craft signatures that\n * recover to arbitrary addresses for non-hashed data. A safe way to ensure\n * this is by receiving a hash of the original message (which may otherwise\n * be too long), and then calling {toEthSignedMessageHash} on it.\n */\n function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, signature);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.\n *\n * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address, RecoverError) {\n bytes32 s = vs & bytes32(0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff);\n uint8 v = uint8((uint256(vs) >> 255) + 27);\n return tryRecover(hash, v, r, s);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.\n *\n * _Available since v4.2._\n */\n function recover(\n bytes32 hash,\n bytes32 r,\n bytes32 vs\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, r, vs);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Overload of {ECDSA-tryRecover} that receives the `v`,\n * `r` and `s` signature fields separately.\n *\n * _Available since v4.3._\n */\n function tryRecover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address, RecoverError) {\n // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature\n // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines\n // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most\n // signatures from current libraries generate a unique signature with an s-value in the lower half order.\n //\n // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value\n // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or\n // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept\n // these malleable signatures as well.\n if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {\n return (address(0), RecoverError.InvalidSignatureS);\n }\n if (v != 27 && v != 28) {\n return (address(0), RecoverError.InvalidSignatureV);\n }\n\n // If the signature is valid (and not malleable), return the signer address\n address signer = ecrecover(hash, v, r, s);\n if (signer == address(0)) {\n return (address(0), RecoverError.InvalidSignature);\n }\n\n return (signer, RecoverError.NoError);\n }\n\n /**\n * @dev Overload of {ECDSA-recover} that receives the `v`,\n * `r` and `s` signature fields separately.\n */\n function recover(\n bytes32 hash,\n uint8 v,\n bytes32 r,\n bytes32 s\n ) internal pure returns (address) {\n (address recovered, RecoverError error) = tryRecover(hash, v, r, s);\n _throwError(error);\n return recovered;\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from a `hash`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {\n // 32 is the length in bytes of hash,\n // enforced by the type signature above\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n32\", hash));\n }\n\n /**\n * @dev Returns an Ethereum Signed Message, created from `s`. This\n * produces hash corresponding to the one signed with the\n * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]\n * JSON-RPC method as part of EIP-191.\n *\n * See {recover}.\n */\n function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19Ethereum Signed Message:\\n\", Strings.toString(s.length), s));\n }\n\n /**\n * @dev Returns an Ethereum Signed Typed Data, created from a\n * `domainSeparator` and a `structHash`. This produces hash corresponding\n * to the one signed with the\n * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]\n * JSON-RPC method as part of EIP-712.\n *\n * See {recover}.\n */\n function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {\n return keccak256(abi.encodePacked(\"\\x19\\x01\", domainSeparator, structHash));\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/ERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)\n\npragma solidity ^0.8.0;\n\nimport \"./IERC165.sol\";\n\n/**\n * @dev Implementation of the {IERC165} interface.\n *\n * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check\n * for the additional interface id that will be supported. For example:\n *\n * ```solidity\n * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);\n * }\n * ```\n *\n * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.\n */\nabstract contract ERC165 is IERC165 {\n /**\n * @dev See {IERC165-supportsInterface}.\n */\n function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {\n return interfaceId == type(IERC165).interfaceId;\n }\n}\n" + }, + "@openzeppelin/contracts/utils/introspection/IERC165.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Interface of the ERC165 standard, as defined in the\n * https://eips.ethereum.org/EIPS/eip-165[EIP].\n *\n * Implementers can declare support of contract interfaces, which can then be\n * queried by others ({ERC165Checker}).\n *\n * For an implementation, see {ERC165}.\n */\ninterface IERC165 {\n /**\n * @dev Returns true if this contract implements the interface defined by\n * `interfaceId`. See the corresponding\n * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]\n * to learn more about how these ids are created.\n *\n * This function call must use less than 30 000 gas.\n */\n function supportsInterface(bytes4 interfaceId) external view returns (bool);\n}\n" + }, + "@openzeppelin/contracts/utils/StorageSlot.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/StorageSlot.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for reading and writing primitive types to specific storage slots.\n *\n * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.\n * This library helps with reading and writing to such slots without the need for inline assembly.\n *\n * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.\n *\n * Example usage to set ERC1967 implementation slot:\n * ```\n * contract ERC1967 {\n * bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n *\n * function _getImplementation() internal view returns (address) {\n * return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;\n * }\n *\n * function _setImplementation(address newImplementation) internal {\n * require(Address.isContract(newImplementation), \"ERC1967: new implementation is not a contract\");\n * StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;\n * }\n * }\n * ```\n *\n * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._\n */\nlibrary StorageSlot {\n struct AddressSlot {\n address value;\n }\n\n struct BooleanSlot {\n bool value;\n }\n\n struct Bytes32Slot {\n bytes32 value;\n }\n\n struct Uint256Slot {\n uint256 value;\n }\n\n /**\n * @dev Returns an `AddressSlot` with member `value` located at `slot`.\n */\n function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `BooleanSlot` with member `value` located at `slot`.\n */\n function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.\n */\n function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n\n /**\n * @dev Returns an `Uint256Slot` with member `value` located at `slot`.\n */\n function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {\n /// @solidity memory-safe-assembly\n assembly {\n r.slot := slot\n }\n }\n}\n" + }, + "@openzeppelin/contracts/utils/Strings.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/Strings.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev String operations.\n */\nlibrary Strings {\n bytes16 private constant _HEX_SYMBOLS = \"0123456789abcdef\";\n uint8 private constant _ADDRESS_LENGTH = 20;\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` decimal representation.\n */\n function toString(uint256 value) internal pure returns (string memory) {\n // Inspired by OraclizeAPI's implementation - MIT licence\n // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol\n\n if (value == 0) {\n return \"0\";\n }\n uint256 temp = value;\n uint256 digits;\n while (temp != 0) {\n digits++;\n temp /= 10;\n }\n bytes memory buffer = new bytes(digits);\n while (value != 0) {\n digits -= 1;\n buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));\n value /= 10;\n }\n return string(buffer);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.\n */\n function toHexString(uint256 value) internal pure returns (string memory) {\n if (value == 0) {\n return \"0x00\";\n }\n uint256 temp = value;\n uint256 length = 0;\n while (temp != 0) {\n length++;\n temp >>= 8;\n }\n return toHexString(value, length);\n }\n\n /**\n * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.\n */\n function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {\n bytes memory buffer = new bytes(2 * length + 2);\n buffer[0] = \"0\";\n buffer[1] = \"x\";\n for (uint256 i = 2 * length + 1; i > 1; --i) {\n buffer[i] = _HEX_SYMBOLS[value & 0xf];\n value >>= 4;\n }\n require(value == 0, \"Strings: hex length insufficient\");\n return string(buffer);\n }\n\n /**\n * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation.\n */\n function toHexString(address addr) internal pure returns (string memory) {\n return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH);\n }\n}\n" + }, + "@openzeppelin/contracts/utils/structs/EnumerableSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n// OpenZeppelin Contracts (last updated v4.7.0) (utils/structs/EnumerableSet.sol)\n\npragma solidity ^0.8.0;\n\n/**\n * @dev Library for managing\n * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive\n * types.\n *\n * Sets have the following properties:\n *\n * - Elements are added, removed, and checked for existence in constant time\n * (O(1)).\n * - Elements are enumerated in O(n). No guarantees are made on the ordering.\n *\n * ```\n * contract Example {\n * // Add the library methods\n * using EnumerableSet for EnumerableSet.AddressSet;\n *\n * // Declare a set state variable\n * EnumerableSet.AddressSet private mySet;\n * }\n * ```\n *\n * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)\n * and `uint256` (`UintSet`) are supported.\n *\n * [WARNING]\n * ====\n * Trying to delete such a structure from storage will likely result in data corruption, rendering the structure unusable.\n * See https://github.com/ethereum/solidity/pull/11843[ethereum/solidity#11843] for more info.\n *\n * In order to clean an EnumerableSet, you can either remove all elements one by one or create a fresh instance using an array of EnumerableSet.\n * ====\n */\nlibrary EnumerableSet {\n // To implement this library for multiple types with as little code\n // repetition as possible, we write it in terms of a generic Set type with\n // bytes32 values.\n // The Set implementation uses private functions, and user-facing\n // implementations (such as AddressSet) are just wrappers around the\n // underlying Set.\n // This means that we can only create new EnumerableSets for types that fit\n // in bytes32.\n\n struct Set {\n // Storage of set values\n bytes32[] _values;\n // Position of the value in the `values` array, plus 1 because index 0\n // means a value is not in the set.\n mapping(bytes32 => uint256) _indexes;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function _add(Set storage set, bytes32 value) private returns (bool) {\n if (!_contains(set, value)) {\n set._values.push(value);\n // The value is stored at length-1, but we add 1 to all indexes\n // and use 0 as a sentinel value\n set._indexes[value] = set._values.length;\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function _remove(Set storage set, bytes32 value) private returns (bool) {\n // We read and store the value's index to prevent multiple reads from the same storage slot\n uint256 valueIndex = set._indexes[value];\n\n if (valueIndex != 0) {\n // Equivalent to contains(set, value)\n // To delete an element from the _values array in O(1), we swap the element to delete with the last one in\n // the array, and then remove the last element (sometimes called as 'swap and pop').\n // This modifies the order of the array, as noted in {at}.\n\n uint256 toDeleteIndex = valueIndex - 1;\n uint256 lastIndex = set._values.length - 1;\n\n if (lastIndex != toDeleteIndex) {\n bytes32 lastValue = set._values[lastIndex];\n\n // Move the last value to the index where the value to delete is\n set._values[toDeleteIndex] = lastValue;\n // Update the index for the moved value\n set._indexes[lastValue] = valueIndex; // Replace lastValue's index to valueIndex\n }\n\n // Delete the slot where the moved value was stored\n set._values.pop();\n\n // Delete the index for the deleted slot\n delete set._indexes[value];\n\n return true;\n } else {\n return false;\n }\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function _contains(Set storage set, bytes32 value) private view returns (bool) {\n return set._indexes[value] != 0;\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function _length(Set storage set) private view returns (uint256) {\n return set._values.length;\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function _at(Set storage set, uint256 index) private view returns (bytes32) {\n return set._values[index];\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function _values(Set storage set) private view returns (bytes32[] memory) {\n return set._values;\n }\n\n // Bytes32Set\n\n struct Bytes32Set {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _add(set._inner, value);\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {\n return _remove(set._inner, value);\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {\n return _contains(set._inner, value);\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(Bytes32Set storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {\n return _at(set._inner, index);\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(Bytes32Set storage set) internal view returns (bytes32[] memory) {\n return _values(set._inner);\n }\n\n // AddressSet\n\n struct AddressSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(AddressSet storage set, address value) internal returns (bool) {\n return _add(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(AddressSet storage set, address value) internal returns (bool) {\n return _remove(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(AddressSet storage set, address value) internal view returns (bool) {\n return _contains(set._inner, bytes32(uint256(uint160(value))));\n }\n\n /**\n * @dev Returns the number of values in the set. O(1).\n */\n function length(AddressSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(AddressSet storage set, uint256 index) internal view returns (address) {\n return address(uint160(uint256(_at(set._inner, index))));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(AddressSet storage set) internal view returns (address[] memory) {\n bytes32[] memory store = _values(set._inner);\n address[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n\n // UintSet\n\n struct UintSet {\n Set _inner;\n }\n\n /**\n * @dev Add a value to a set. O(1).\n *\n * Returns true if the value was added to the set, that is if it was not\n * already present.\n */\n function add(UintSet storage set, uint256 value) internal returns (bool) {\n return _add(set._inner, bytes32(value));\n }\n\n /**\n * @dev Removes a value from a set. O(1).\n *\n * Returns true if the value was removed from the set, that is if it was\n * present.\n */\n function remove(UintSet storage set, uint256 value) internal returns (bool) {\n return _remove(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns true if the value is in the set. O(1).\n */\n function contains(UintSet storage set, uint256 value) internal view returns (bool) {\n return _contains(set._inner, bytes32(value));\n }\n\n /**\n * @dev Returns the number of values on the set. O(1).\n */\n function length(UintSet storage set) internal view returns (uint256) {\n return _length(set._inner);\n }\n\n /**\n * @dev Returns the value stored at position `index` in the set. O(1).\n *\n * Note that there are no guarantees on the ordering of values inside the\n * array, and it may change when more values are added or removed.\n *\n * Requirements:\n *\n * - `index` must be strictly less than {length}.\n */\n function at(UintSet storage set, uint256 index) internal view returns (uint256) {\n return uint256(_at(set._inner, index));\n }\n\n /**\n * @dev Return the entire set in an array\n *\n * WARNING: This operation will copy the entire storage to memory, which can be quite expensive. This is designed\n * to mostly be used by view accessors that are queried without any gas fees. Developers should keep in mind that\n * this function has an unbounded cost, and using it as part of a state-changing function may render the function\n * uncallable if the set grows to a point where copying to memory consumes too much gas to fit in a block.\n */\n function values(UintSet storage set) internal view returns (uint256[] memory) {\n bytes32[] memory store = _values(set._inner);\n uint256[] memory result;\n\n /// @solidity memory-safe-assembly\n assembly {\n result := store\n }\n\n return result;\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerCallback, EnumerableSet, BridgeManagerCallbackRegister } from \"./BridgeManagerCallbackRegister.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IQuorum } from \"../../interfaces/IQuorum.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { RoleAccess } from \"../../utils/RoleAccess.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract BridgeManager is IQuorum, IBridgeManager, BridgeManagerCallbackRegister, HasContracts {\n using AddressArrayUtils for address[];\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governorToBridgeOperatorInfo.slot\") - 1\n bytes32 private constant GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT =\n 0x88547008e60f5748911f2e59feb3093b7e4c2e87b2dd69d61f112fcc932de8e3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.govenorOf.slot\") - 1\n bytes32 private constant GOVENOR_OF_SLOT = 0x8400683eb2cb350596d73644c0c89fe45f108600003457374f4ab3e87b4f3aa3;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.governors.slot\") - 1\n bytes32 private constant GOVERNOR_SET_SLOT = 0x546f6b46ab35b030b6816596b352aef78857377176c8b24baa2046a62cf1998c;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.bridgeOperators.slot\") - 1\n bytes32 private constant BRIDGE_OPERATOR_SET_SLOT =\n 0xd38c234075fde25875da8a6b7e36b58b86681d483271a99eeeee1d78e258a24d;\n\n /**\n * @dev The numerator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.numerator.slot\") - 1\n */\n TUint256Slot internal constant NUMERATOR_SLOT =\n TUint256Slot.wrap(0xc55405a488814eaa0e2a685a0131142785b8d033d311c8c8244e34a7c12ca40f);\n\n /**\n * @dev The denominator value used for calculations in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.denominator.slot\") - 1\n */\n TUint256Slot internal constant DENOMINATOR_SLOT =\n TUint256Slot.wrap(0xac1ff16a4f04f2a37a9ba5252a69baa100b460e517d1f8019c054a5ad698f9ff);\n\n /**\n * @dev The nonce value used for tracking nonces in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.nonce.slot\") - 1\n */\n TUint256Slot internal constant NONCE_SLOT =\n TUint256Slot.wrap(0x92872d32822c9d44b36a2537d3e0d4c46fc4de1ce154ccfaed560a8a58445f1d);\n\n /**\n * @dev The total weight value used for storing the cumulative weight in the contract.\n * @notice value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.totalWeights.slot\") - 1\n */\n TUint256Slot internal constant TOTAL_WEIGHTS_SLOT =\n TUint256Slot.wrap(0x6924fe71b0c8b61aea02ca498b5f53b29bd95726278b1fe4eb791bb24a42644c);\n\n /**\n * @inheritdoc IBridgeManager\n */\n bytes32 public immutable DOMAIN_SEPARATOR;\n\n modifier onlyGovernor() virtual {\n _requireGovernor(msg.sender);\n _;\n }\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManagerCallbackRegister(callbackRegisters) {\n NONCE_SLOT.store(1);\n\n _setThreshold(num, denom);\n _setContract(ContractType.BRIDGE, bridgeContract);\n\n DOMAIN_SEPARATOR = keccak256(\n abi.encode(\n keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n keccak256(\"BridgeAdmin\"), // name hash\n keccak256(\"2\"), // version hash\n keccak256(abi.encode(\"BRIDGE_ADMIN\", roninChainId)) // salt\n )\n );\n\n _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory addeds) {\n addeds = _addBridgeOperators(voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function removeBridgeOperators(\n address[] calldata bridgeOperators\n ) external onlySelfCall returns (bool[] memory removeds) {\n removeds = _removeBridgeOperators(bridgeOperators);\n }\n\n /**\n * @inheritdoc IBridgeManager\n * @notice This method checks authorization by querying the corresponding operator of the msg.sender and then\n * attempts to remove it from the `_bridgeOperatorSet` for gas optimization. In case we allow a governor can leave\n * their operator address blank null `address(0)`, consider add authorization check.\n */\n function updateBridgeOperator(address newBridgeOperator) external onlyGovernor {\n _requireNonZeroAddress(newBridgeOperator);\n\n // Queries the previous bridge operator\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n address currentBridgeOperator = _gorvernorToBridgeOperatorInfo[msg.sender].addr;\n if (currentBridgeOperator == newBridgeOperator) {\n revert ErrBridgeOperatorAlreadyExisted(newBridgeOperator);\n }\n\n // Tries replace the bridge operator\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n bool updated = _bridgeOperatorSet.remove(currentBridgeOperator) && _bridgeOperatorSet.add(newBridgeOperator);\n if (!updated) revert ErrBridgeOperatorUpdateFailed(newBridgeOperator);\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n delete _governorOf[currentBridgeOperator];\n _governorOf[newBridgeOperator] = msg.sender;\n _gorvernorToBridgeOperatorInfo[msg.sender].addr = newBridgeOperator;\n\n _notifyRegisters(\n IBridgeManagerCallback.onBridgeOperatorUpdated.selector,\n abi.encode(currentBridgeOperator, newBridgeOperator)\n );\n\n emit BridgeOperatorUpdated(msg.sender, currentBridgeOperator, newBridgeOperator);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 numerator,\n uint256 denominator\n ) external override onlySelfCall returns (uint256, uint256) {\n return _setThreshold(numerator, denominator);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getTotalWeight() public view returns (uint256) {\n return TOTAL_WEIGHTS_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights) {\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorWeight(address governor) external view returns (uint96 weight) {\n weight = _getGovernorWeight(governor);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function sumGovernorsWeight(\n address[] calldata governors\n ) external view nonDuplicate(governors) returns (uint256 sum) {\n sum = _sumGovernorsWeight(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function totalBridgeOperator() external view returns (uint256) {\n return _getBridgeOperatorSet().length();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function isBridgeOperator(address addr) external view returns (bool) {\n return _getBridgeOperatorSet().contains(addr);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperators() external view returns (address[] memory) {\n return _getBridgeOperators();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernors() external view returns (address[] memory) {\n return _getGovernors();\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorOf(address[] memory governors) public view returns (address[] memory bridgeOperators) {\n uint256 length = governors.length;\n bridgeOperators = new address[](length);\n\n mapping(address => BridgeOperatorInfo) storage _gorvernorToBridgeOperator = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n bridgeOperators[i] = _gorvernorToBridgeOperator[governors[i]].addr;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors) {\n uint256 length = bridgeOperators.length;\n governors = new address[](length);\n mapping(address => address) storage _governorOf = _getGovernorOf();\n\n for (uint256 i; i < length; ) {\n governors[i] = _governorOf[bridgeOperators[i]];\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights)\n {\n governors = _getGovernors();\n bridgeOperators = getBridgeOperatorOf(governors);\n weights = _getGovernorWeights(governors);\n }\n\n /**\n * @inheritdoc IBridgeManager\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight) {\n mapping(address => address) storage _governorOf = _getGovernorOf();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n weight = _governorToBridgeOperatorInfo[_governorOf[bridgeOperator]].voteWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return (NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load()) + DENOMINATOR_SLOT.load() - 1) / DENOMINATOR_SLOT.load();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (NUMERATOR_SLOT.load(), DENOMINATOR_SLOT.load());\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * DENOMINATOR_SLOT.load() >= NUMERATOR_SLOT.mul(TOTAL_WEIGHTS_SLOT.load());\n }\n\n /**\n * @dev Internal function to add bridge operators.\n *\n * This function adds the specified `bridgeOperators` to the bridge operator set and establishes the associated mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to add bridge operators.\n * - The lengths of `voteWeights`, `governors`, and `bridgeOperators` arrays must be equal.\n *\n * @param voteWeights An array of uint256 values representing the vote weights for each bridge operator.\n * @param governors An array of addresses representing the governors for each bridge operator.\n * @return addeds An array of boolean values indicating whether each bridge operator was successfully added.\n */\n function _addBridgeOperators(\n uint96[] memory voteWeights,\n address[] memory governors,\n address[] memory bridgeOperators\n ) internal nonDuplicate(governors.extend(bridgeOperators)) returns (bool[] memory addeds) {\n uint256 length = bridgeOperators.length;\n if (!(length == voteWeights.length && length == governors.length)) revert ErrLengthMismatch(msg.sig);\n addeds = new bool[](length);\n // simply skip add operations if inputs are empty.\n if (length == 0) return addeds;\n\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n governor = governors[i];\n bridgeOperator = bridgeOperators[i];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n if (voteWeights[i] == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n addeds[i] = !(_governorSet.contains(governor) ||\n _governorSet.contains(bridgeOperator) ||\n _bridgeOperatorSet.contains(governor) ||\n _bridgeOperatorSet.contains(bridgeOperator));\n\n if (addeds[i]) {\n _governorSet.add(governor);\n _bridgeOperatorSet.add(bridgeOperator);\n _governorOf[bridgeOperator] = governor;\n bridgeOperatorInfo.addr = bridgeOperator;\n accumulatedWeight += bridgeOperatorInfo.voteWeight = voteWeights[i];\n _governorToBridgeOperatorInfo[governor] = bridgeOperatorInfo;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.addAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsAdded.selector, abi.encode(bridgeOperators, addeds));\n\n emit BridgeOperatorsAdded(addeds, voteWeights, governors, bridgeOperators);\n }\n\n /**\n * @dev Internal function to remove bridge operators.\n *\n * This function removes the specified `bridgeOperators` from the bridge operator set and related mappings.\n *\n * Requirements:\n * - The caller must have the necessary permission to remove bridge operators.\n *\n * @param bridgeOperators An array of addresses representing the bridge operators to be removed.\n * @return removeds An array of boolean values indicating whether each bridge operator was successfully removed.\n */\n function _removeBridgeOperators(\n address[] memory bridgeOperators\n ) internal nonDuplicate(bridgeOperators) returns (bool[] memory removeds) {\n uint256 length = bridgeOperators.length;\n removeds = new bool[](length);\n // simply skip remove operations if inputs are empty.\n if (length == 0) return removeds;\n\n mapping(address => address) storage _governorOf = _getGovernorOf();\n EnumerableSet.AddressSet storage _governorSet = _getGovernorsSet();\n EnumerableSet.AddressSet storage _bridgeOperatorSet = _getBridgeOperatorSet();\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n address governor;\n address bridgeOperator;\n uint256 accumulatedWeight;\n BridgeOperatorInfo memory bridgeOperatorInfo;\n\n for (uint256 i; i < length; ) {\n bridgeOperator = bridgeOperators[i];\n governor = _governorOf[bridgeOperator];\n\n _requireNonZeroAddress(governor);\n _requireNonZeroAddress(bridgeOperator);\n\n bridgeOperatorInfo = _governorToBridgeOperatorInfo[governor];\n if (bridgeOperatorInfo.addr != bridgeOperator) revert ErrInvalidArguments(msg.sig);\n\n removeds[i] = _bridgeOperatorSet.contains(bridgeOperator) && _governorSet.contains(governor);\n if (removeds[i]) {\n _governorSet.remove(governor);\n _bridgeOperatorSet.remove(bridgeOperator);\n\n delete _governorOf[bridgeOperator];\n delete _governorToBridgeOperatorInfo[governor];\n accumulatedWeight += bridgeOperatorInfo.voteWeight;\n }\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_WEIGHTS_SLOT.subAssign(accumulatedWeight);\n\n _notifyRegisters(IBridgeManagerCallback.onBridgeOperatorsRemoved.selector, abi.encode(bridgeOperators, removeds));\n\n emit BridgeOperatorsRemoved(removeds, bridgeOperators);\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 numerator,\n uint256 denominator\n ) internal virtual returns (uint256 previousNum, uint256 previousDenom) {\n if (numerator > denominator) revert ErrInvalidThreshold(msg.sig);\n\n previousNum = NUMERATOR_SLOT.load();\n previousDenom = DENOMINATOR_SLOT.load();\n NUMERATOR_SLOT.store(numerator);\n DENOMINATOR_SLOT.store(denominator);\n\n emit ThresholdUpdated(NONCE_SLOT.postIncrement(), numerator, denominator, previousNum, previousDenom);\n }\n\n /**\n * @dev Internal function to get all bridge operators.\n * @return bridgeOperators An array containing all the registered bridge operator addresses.\n */\n function _getBridgeOperators() internal view returns (address[] memory) {\n return _getBridgeOperatorSet().values();\n }\n\n /**\n * @dev Internal function to get all governors.\n * @return governors An array containing all the registered governor addresses.\n */\n function _getGovernors() internal view returns (address[] memory) {\n return _getGovernorsSet().values();\n }\n\n /**\n * @dev Internal function to get the vote weights of a given array of governors.\n * @param governors An array containing the addresses of governors.\n * @return weights An array containing the vote weights of the corresponding governors.\n */\n function _getGovernorWeights(address[] memory governors) internal view returns (uint96[] memory weights) {\n uint256 length = governors.length;\n weights = new uint96[](length);\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n for (uint256 i; i < length; ) {\n weights[i] = _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to calculate the sum of vote weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of vote weights.\n * @return sum The total sum of vote weights for the provided governors.\n * @notice The input array `governors` must contain unique addresses to avoid duplicate calculations.\n */\n function _sumGovernorsWeight(address[] memory governors) internal view nonDuplicate(governors) returns (uint256 sum) {\n mapping(address => BridgeOperatorInfo) storage _governorToBridgeOperatorInfo = _getGovernorToBridgeOperatorInfo();\n\n for (uint256 i; i < governors.length; ) {\n sum += _governorToBridgeOperatorInfo[governors[i]].voteWeight;\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to require that the caller has governor role access.\n * @param addr The address to check for governor role access.\n * @dev If the address does not have governor role access (vote weight is zero), a revert with the corresponding error message is triggered.\n */\n function _requireGovernor(address addr) internal view {\n if (_getGovernorWeight(addr) == 0) {\n revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n }\n\n /**\n * @dev Internal function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function _getGovernorWeight(address governor) internal view returns (uint96) {\n return _getGovernorToBridgeOperatorInfo()[governor].voteWeight;\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return bridgeOperators the storage address set.\n */\n function _getBridgeOperatorSet() internal pure returns (EnumerableSet.AddressSet storage bridgeOperators) {\n assembly (\"memory-safe\") {\n bridgeOperators.slot := BRIDGE_OPERATOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the address set of bridge operators.\n * @return governors the storage address set.\n */\n function _getGovernorsSet() internal pure returns (EnumerableSet.AddressSet storage governors) {\n assembly (\"memory-safe\") {\n governors.slot := GOVERNOR_SET_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from governor => BridgeOperatorInfo.\n * @return governorToBridgeOperatorInfo the mapping from governor => BridgeOperatorInfo.\n */\n function _getGovernorToBridgeOperatorInfo()\n internal\n pure\n returns (mapping(address => BridgeOperatorInfo) storage governorToBridgeOperatorInfo)\n {\n assembly (\"memory-safe\") {\n governorToBridgeOperatorInfo.slot := GOVERNOR_TO_BRIDGE_OPERATOR_INFO_SLOT\n }\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => governor.\n * @return governorOf the mapping from bridge operator => governor.\n */\n function _getGovernorOf() internal pure returns (mapping(address => address) storage governorOf) {\n assembly (\"memory-safe\") {\n governorOf.slot := GOVENOR_OF_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { EnumerableSet } from \"@openzeppelin/contracts/utils/structs/EnumerableSet.sol\";\nimport { IBridgeManagerCallbackRegister } from \"../../interfaces/bridge/IBridgeManagerCallbackRegister.sol\";\nimport { IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { TransparentUpgradeableProxyV2, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title BridgeManagerCallbackRegister\n * @dev A contract that manages callback registrations and execution for a bridge.\n */\nabstract contract BridgeManagerCallbackRegister is IdentityGuard, IBridgeManagerCallbackRegister {\n using EnumerableSet for EnumerableSet.AddressSet;\n\n /**\n * @dev Storage slot for the address set of callback registers.\n * @dev Value is equal to keccak256(\"@ronin.dpos.gateway.BridgeAdmin.callbackRegisters.slot\") - 1.\n */\n bytes32 private constant CALLBACK_REGISTERS_SLOT = 0x5da136eb38f8d8e354915fc8a767c0dc81d49de5fb65d5477122a82ddd976240;\n\n constructor(address[] memory callbackRegisters) payable {\n _registerCallbacks(callbackRegisters);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function registerCallbacks(address[] calldata registers) external onlySelfCall returns (bool[] memory registereds) {\n registereds = _registerCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function unregisterCallbacks(\n address[] calldata registers\n ) external onlySelfCall returns (bool[] memory unregistereds) {\n unregistereds = _unregisterCallbacks(registers);\n }\n\n /**\n * @inheritdoc IBridgeManagerCallbackRegister\n */\n function getCallbackRegisters() external view returns (address[] memory registers) {\n registers = _getCallbackRegisters().values();\n }\n\n /**\n * @dev Internal function to register multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function _registerCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory registereds) {\n uint256 length = registers.length;\n registereds = new bool[](length);\n if (length == 0) return registereds;\n\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n address register;\n bytes4 callbackInterface = type(IBridgeManagerCallback).interfaceId;\n\n for (uint256 i; i < length; ) {\n register = registers[i];\n\n _requireHasCode(register);\n _requireSupportsInterface(register, callbackInterface);\n\n registereds[i] = _callbackRegisters.add(register);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to unregister multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function _unregisterCallbacks(\n address[] memory registers\n ) internal nonDuplicate(registers) returns (bool[] memory unregistereds) {\n uint256 length = registers.length;\n unregistereds = new bool[](length);\n EnumerableSet.AddressSet storage _callbackRegisters = _getCallbackRegisters();\n\n for (uint256 i; i < length; ) {\n unregistereds[i] = _callbackRegisters.remove(registers[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to notify all registered callbacks with the provided function signature and data.\n * @param callbackFnSig The function signature of the callback method.\n * @param inputs The data to pass to the callback method.\n */\n function _notifyRegisters(bytes4 callbackFnSig, bytes memory inputs) internal {\n address[] memory registers = _getCallbackRegisters().values();\n uint256 length = registers.length;\n if (length == 0) return;\n\n bool[] memory successes = new bool[](length);\n bytes[] memory returnDatas = new bytes[](length);\n bytes memory callData = abi.encodePacked(callbackFnSig, inputs);\n bytes memory proxyCallData = abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (callData));\n\n for (uint256 i; i < length; ) {\n (successes[i], returnDatas[i]) = registers[i].call(callData);\n if (!successes[i]) {\n (successes[i], returnDatas[i]) = registers[i].call(proxyCallData);\n }\n\n unchecked {\n ++i;\n }\n }\n\n emit Notified(callData, registers, successes, returnDatas);\n }\n\n /**\n * @dev Internal function to retrieve the address set of callback registers.\n * @return callbackRegisters The storage reference to the callback registers.\n */\n function _getCallbackRegisters() internal pure returns (EnumerableSet.AddressSet storage callbackRegisters) {\n assembly (\"memory-safe\") {\n callbackRegisters.slot := CALLBACK_REGISTERS_SLOT\n }\n }\n}\n" + }, + "contracts/extensions/bridge-operator-governance/BridgeTrackingHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract BridgeTrackingHelper {\n /// @dev Event emited when the bridge tracking contract tracks the invalid data, cause malform in sharing bridge reward.\n event BridgeTrackingIncorrectlyResponded();\n\n /**\n * @dev Internal function to validate the bridge tracking response for a given set of ballots.\n * @param totalBallot The total number of ballots available for the tracking response.\n * @param totalVote The total number of votes recorded in the tracking response.\n * @param ballots An array containing the individual ballot counts in the tracking response.\n * @return valid A boolean indicating whether the bridge tracking response is valid or not.\n * @notice The function checks if each individual ballot count is not greater than the total votes recorded.\n * @notice It also verifies that the sum of all individual ballot counts does not exceed the total available ballots.\n */\n function _isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal pure returns (bool valid) {\n valid = true;\n uint256 sumBallot;\n uint256 length = ballots.length;\n\n unchecked {\n for (uint256 i; i < length; ++i) {\n if (ballots[i] > totalVote) {\n valid = false;\n break;\n }\n\n sumBallot += ballots[i];\n }\n }\n\n valid = valid && (sumBallot <= totalBallot);\n }\n}\n" + }, + "contracts/extensions/collections/HasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasProxyAdmin } from \"./HasProxyAdmin.sol\";\nimport \"../../interfaces/collections/IHasContracts.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrUnexpectedInternalCall } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title HasContracts\n * @dev A contract that provides functionality to manage multiple contracts with different roles.\n */\nabstract contract HasContracts is HasProxyAdmin, IHasContracts, IdentityGuard {\n /// @dev value is equal to keccak256(\"@ronin.dpos.collections.HasContracts.slot\") - 1\n bytes32 private constant _STORAGE_SLOT = 0xdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb;\n\n /**\n * @dev Modifier to restrict access to functions only to contracts with a specific role.\n * @param contractType The contract type that allowed to call\n */\n modifier onlyContract(ContractType contractType) virtual {\n _requireContract(contractType);\n _;\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual onlyAdmin {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function getContract(ContractType contractType) public view returns (address contract_) {\n contract_ = _getContractMap()[uint8(contractType)];\n if (contract_ == address(0)) revert ErrContractTypeNotFound(contractType);\n }\n\n /**\n * @dev Internal function to set the address of a contract with a specific role.\n * @param contractType The contract type of the contract to set.\n * @param addr The address of the contract to set.\n */\n function _setContract(ContractType contractType, address addr) internal virtual {\n _getContractMap()[uint8(contractType)] = addr;\n emit ContractUpdated(contractType, addr);\n }\n\n /**\n * @dev Internal function to access the mapping of contract addresses with roles.\n * @return contracts_ The mapping of contract addresses with roles.\n */\n function _getContractMap() private pure returns (mapping(uint8 => address) storage contracts_) {\n assembly {\n contracts_.slot := _STORAGE_SLOT\n }\n }\n\n /**\n * @dev Internal function to check if the calling contract has a specific role.\n * @param contractType The contract type that the calling contract must have.\n * @dev Throws an error if the calling contract does not have the specified role.\n */\n function _requireContract(ContractType contractType) private view {\n if (msg.sender != getContract(contractType)) {\n revert ErrUnexpectedInternalCall(msg.sig, contractType, msg.sender);\n }\n }\n}\n" + }, + "contracts/extensions/collections/HasProxyAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/StorageSlot.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract HasProxyAdmin {\n // bytes32(uint256(keccak256(\"eip1967.proxy.admin\")) - 1));\n bytes32 private constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;\n\n modifier onlyAdmin() {\n _requireAdmin();\n _;\n }\n\n /**\n * @dev Returns proxy admin.\n */\n function _getAdmin() internal view virtual returns (address) {\n return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;\n }\n\n function _requireAdmin() internal view {\n if (msg.sender != _getAdmin()) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n}\n" + }, + "contracts/extensions/consumers/GlobalConfigConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract GlobalConfigConsumer {\n /// @dev The addition amount of gas sending along in external calls. Total gas stipend is added with default 2300 gas.\n uint256 public constant DEFAULT_ADDITION_GAS = 1200;\n /// @dev The length of a period in second.\n uint256 public constant PERIOD_DURATION = 1 days;\n}\n" + }, + "contracts/extensions/consumers/PercentageConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nabstract contract PercentageConsumer {\n uint256 internal constant _MAX_PERCENTAGE = 100_00;\n}\n" + }, + "contracts/extensions/forwarder/Forwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\n\ncontract Forwarder is AccessControlEnumerable {\n using ErrorHandler for bool;\n\n /**\n * @dev Error thrown when an invalid forward value is provided.\n */\n error ErrInvalidForwardValue();\n\n /// @dev Only user with moderator role can invoke {functionCall} method to forward the call to the target.\n bytes32 public constant MODERATOR_ROLE = keccak256(\"MODERATOR_ROLE\");\n\n /**\n * @dev The target contracts must be registerred by the admin before called to. The admin can register the targets at\n * the contract construction or by assigning {TARGET_ROLE} to the target addresses.\n */\n bytes32 public constant TARGET_ROLE = keccak256(\"TARGET_ROLE\");\n\n /**\n * @dev Initializes the forwarder with an initial target address and a contract admin.\n */\n constructor(address[] memory _targets, address _admin, address _moderator) payable {\n for (uint _i = 0; _i < _targets.length; ) {\n _setupRole(TARGET_ROLE, _targets[_i]);\n\n unchecked {\n ++_i;\n }\n }\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n _setupRole(MODERATOR_ROLE, _moderator);\n }\n\n modifier validTarget(address _target) {\n _checkRole(TARGET_ROLE, _target);\n _;\n }\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n fallback() external payable {}\n\n /**\n * @dev Receives RON transfer from all addresses.\n */\n receive() external payable {}\n\n /**\n * @dev Forwards the encoded call specified by `_data` to the target. The forwarder attachs `_val` value\n * from the forwarder contract and sends along with the call.\n *\n * Requirements:\n * - Only target with {TARGET_ROLE} can be called to.\n * - Only user with {MODERATOR_ROLE} can call this method.\n */\n function functionCall(\n address _target,\n bytes memory _data,\n uint256 _val\n ) external payable validTarget(_target) onlyRole(MODERATOR_ROLE) {\n if (_val > address(this).balance) revert ErrInvalidForwardValue();\n _call(_target, _data, _val);\n }\n\n /**\n * @dev Forwards the current call to `target`.\n *\n * This function does not return to its internal call site, it will return directly to the external caller.\n */\n function _call(address _target, bytes memory _data, uint256 _value) internal {\n (bool _success, bytes memory _res) = _target.call{ value: _value }(_data);\n _success.handleRevert(bytes4(_data), _res);\n }\n}\n" + }, + "contracts/extensions/GatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/security/Pausable.sol\";\nimport \"../interfaces/IQuorum.sol\";\nimport \"./collections/HasProxyAdmin.sol\";\n\nabstract contract GatewayV3 is HasProxyAdmin, Pausable, IQuorum {\n uint256 internal _num;\n uint256 internal _denom;\n\n address private ______deprecated;\n uint256 public nonce;\n\n address public emergencyPauser;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @dev Grant emergency pauser role for `_addr`.\n */\n function setEmergencyPauser(address _addr) external onlyAdmin {\n emergencyPauser = _addr;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _getTotalWeight();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @dev Triggers paused state.\n */\n function pause() external {\n _requireAuth();\n _pause();\n }\n\n /**\n * @dev Triggers unpaused state.\n */\n function unpause() external {\n _requireAuth();\n _unpause();\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() public view virtual returns (uint256) {\n return _minimumVoteWeight(_getTotalWeight());\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Returns minimum vote weight.\n */\n function _minimumVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be admin or pauser.\n *\n */\n function _requireAuth() private view {\n if (!(msg.sender == _getAdmin() || msg.sender == emergencyPauser)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n }\n }\n\n /**\n * @dev Returns the total weight.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/GovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IdentityGuard } from \"../utils/IdentityGuard.sol\";\nimport { HasGovernanceAdminDeprecated, HasBridgeDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\nabstract contract GovernanceAdmin is\n CoreGovernance,\n IdentityGuard,\n HasContracts,\n HasGovernanceAdminDeprecated,\n HasBridgeDeprecated\n{\n using ErrorHandler for bool;\n\n uint256 public roninChainId;\n /// @dev Domain separator\n bytes32 public DOMAIN_SEPARATOR;\n\n constructor(uint256 _roninChainId, address _roninTrustedOrganizationContract) {\n roninChainId = _roninChainId;\n\n /*\n * DOMAIN_SEPARATOR = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\"),\n * keccak256(\"GovernanceAdmin\"), // name hash\n * keccak256(\"2\"), // version hash\n * keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId)) // salt\n * )\n */\n assembly {\n let ptr := mload(0x40)\n\n // See abi.encode implementation: https://github.com/axieinfinity/ronin/blob/569ebd5a782da5601c6aba22799dc9b4afd39da9/accounts/abi/argument.go#L227-L267\n mstore(ptr, 0x40) // offset bytes\n mstore(add(ptr, 0x20), _roninChainId)\n mstore(add(ptr, 0x40), 0x16) // \"RONIN_GOVERNANCE_ADMIN\".length\n mstore(add(ptr, 0x60), 0x524f4e494e5f474f5645524e414e43455f41444d494e00000000000000000000) // bytes(\"RONIN_GOVERNANCE_ADMIN\")\n let salt := keccak256(ptr, 0x80) // keccak256(abi.encode(\"RONIN_GOVERNANCE_ADMIN\", _roninChainId))\n\n mstore(ptr, 0x599a80fcaa47b95e2323ab4d34d34e0cc9feda4b843edafcc30c7bdf60ea15bf) // keccak256(\"EIP712Domain(string name,string version,bytes32 salt)\")\n mstore(add(ptr, 0x20), 0x7e7935007966eb860f4a2ee3dcc9fd53fb3205ce2aa86b0126d4893d4d4c14b9) // keccak256(\"GovernanceAdmin\")\n mstore(add(ptr, 0x40), 0x2a80e1ef1d7842f27f2e6be0972bb708b9a135c38860dbe73c27c3486c34f4de) // keccak256(\"3\")\n mstore(add(ptr, 0x60), salt)\n sstore(DOMAIN_SEPARATOR.slot, keccak256(ptr, 0x80))\n }\n\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, _roninTrustedOrganizationContract);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(ContractType contractType, address addr) external virtual override onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n *\n * Requirements:\n * - Only allowing self-call to this method, since this contract does not have admin.\n *\n */\n function setProposalExpiryDuration(uint256 _expiryDuration) external onlySelfCall {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Returns the current implementation of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyImplementation(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"implementation()\")) == 0x5c60da1b\n bytes4 _selector = 0x5c60da1b;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Returns the proposal expiry duration.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return super._getProposalExpiryDuration();\n }\n\n /**\n * @dev Returns the current admin of `_proxy`.\n *\n * Requirements:\n * - This contract must be the admin of `_proxy`.\n *\n */\n function getProxyAdmin(address _proxy) external view returns (address) {\n // We need to manually run the static call since the getter cannot be flagged as view\n // bytes4(keccak256(\"admin()\")) == 0xf851a440\n bytes4 _selector = 0xf851a440;\n (bool _success, bytes memory _returndata) = _proxy.staticcall(abi.encodeWithSelector(_selector));\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (address));\n }\n\n /**\n * @dev Changes the admin of `_proxy` to `newAdmin`.\n *\n * Requirements:\n * - This contract must be the current admin of `_proxy`.\n *\n */\n function changeProxyAdmin(address _proxy, address _newAdmin) external onlySelfCall {\n // bytes4(keccak256(\"changeAdmin(address)\"))\n bytes4 _selector = 0x8f283970;\n (bool _success, bytes memory _returndata) = _proxy.call(abi.encodeWithSelector(_selector, _newAdmin));\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev Override `CoreGovernance-_getMinimumVoteWeight`.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IQuorum.minimumVoteWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Override `CoreGovernance-_getTotalWeights`.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.totalWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n}\n" + }, + "contracts/extensions/MinimumWithdrawal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./collections/HasProxyAdmin.sol\";\nimport \"../libraries/Transfer.sol\";\n\nabstract contract MinimumWithdrawal is HasProxyAdmin {\n /// @dev Throwed when the ERC20 withdrawal quantity is less than the minimum threshold.\n error ErrQueryForTooSmallQuantity();\n\n /// @dev Emitted when the minimum thresholds are updated\n event MinimumThresholdsUpdated(address[] tokens, uint256[] threshold);\n\n /// @dev Mapping from token address => minimum thresholds\n mapping(address => uint256) public minimumThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Sets the minimum thresholds to withdraw.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setMinimumThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets minimum thresholds.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `MinimumThresholdsUpdated` event.\n *\n */\n function _setMinimumThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n minimumThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit MinimumThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Checks whether the request is larger than or equal to the minimum threshold.\n */\n function _checkWithdrawal(Transfer.Request calldata _request) internal view {\n if (_request.info.erc == Token.Standard.ERC20 && _request.info.quantity < minimumThreshold[_request.tokenAddr]) {\n revert ErrQueryForTooSmallQuantity();\n }\n }\n}\n" + }, + "contracts/extensions/RONTransferHelper.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nabstract contract RONTransferHelper {\n /// @dev Error of sender has insufficient balance.\n error ErrInsufficientBalance(bytes4 msgSig, uint256 currentBalance, uint256 sendAmount);\n /// @dev Error of recipient not accepting RON when transfer RON.\n error ErrRecipientRevert(bytes4 msgSig);\n\n /**\n * @dev See `_sendRON`.\n * Reverts if the recipient does not receive RON.\n */\n function _transferRON(address payable recipient, uint256 amount) internal {\n if (!_sendRON(recipient, amount)) revert ErrRecipientRevert(msg.sig);\n }\n\n /**\n * @dev Send `amount` RON to the address `recipient`.\n * Returns whether the recipient receives RON or not.\n * Reverts once the contract balance is insufficient.\n *\n * Note: consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _sendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n if (address(this).balance < amount) revert ErrInsufficientBalance(msg.sig, address(this).balance, amount);\n return _unsafeSendRON(recipient, amount);\n }\n\n /**\n * @dev Unsafe send `amount` RON to the address `recipient`. If the sender's balance is insufficient,\n * the call does not revert.\n *\n * Note:\n * - Does not assert whether the balance of sender is sufficient.\n * - Does not assert whether the recipient accepts RON.\n * - Consider using `ReentrancyGuard` before calling this function.\n *\n */\n function _unsafeSendRON(address payable recipient, uint256 amount) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount }(\"\");\n }\n\n /**\n * @dev Same purpose with {_unsafeSendRONLimitGas(address,uin256)} but containing gas limit stipend forwarded in the call.\n */\n function _unsafeSendRONLimitGas(\n address payable recipient,\n uint256 amount,\n uint256 gas\n ) internal returns (bool success) {\n (success, ) = recipient.call{ value: amount, gas: gas }(\"\");\n }\n}\n" + }, + "contracts/extensions/sequential-governance/CoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"../../utils/CommonErrors.sol\";\nimport \"../../libraries/Ballot.sol\";\nimport \"../../interfaces/consumers/ChainTypeConsumer.sol\";\nimport \"../../interfaces/consumers/SignatureConsumer.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\n\nabstract contract CoreGovernance is SignatureConsumer, VoteStatusConsumer, ChainTypeConsumer {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when attempting to interact with a finalized vote.\n */\n error ErrVoteIsFinalized();\n\n /**\n * @dev Error thrown when the current proposal is not completed.\n */\n error ErrCurrentProposalIsNotCompleted();\n\n struct ProposalVote {\n VoteStatus status;\n bytes32 hash;\n uint256 againstVoteWeight; // Total weight of against votes\n uint256 forVoteWeight; // Total weight of for votes\n address[] forVoteds; // Array of addresses voting for\n address[] againstVoteds; // Array of addresses voting against\n uint256 expiryTimestamp;\n mapping(address => Signature) sig;\n mapping(address => bool) voted;\n }\n\n /// @dev Emitted when a proposal is created\n event ProposalCreated(\n uint256 indexed chainId,\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n address creator\n );\n /// @dev Emitted when the proposal is voted\n event ProposalVoted(bytes32 indexed proposalHash, address indexed voter, Ballot.VoteType support, uint256 weight);\n /// @dev Emitted when the proposal is approved\n event ProposalApproved(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is reject\n event ProposalRejected(bytes32 indexed proposalHash);\n /// @dev Emitted when the vote is expired\n event ProposalExpired(bytes32 indexed proposalHash);\n /// @dev Emitted when the proposal is executed\n event ProposalExecuted(bytes32 indexed proposalHash, bool[] successCalls, bytes[] returnDatas);\n /// @dev Emitted when the proposal expiry duration is changed.\n event ProposalExpiryDurationChanged(uint256 indexed duration);\n\n /// @dev Mapping from chain id => vote round\n /// @notice chain id = 0 for global proposal\n mapping(uint256 => uint256) public round;\n /// @dev Mapping from chain id => vote round => proposal vote\n mapping(uint256 => mapping(uint256 => ProposalVote)) public vote;\n\n uint256 internal _proposalExpiryDuration;\n\n constructor(uint256 _expiryDuration) {\n _setProposalExpiryDuration(_expiryDuration);\n }\n\n /**\n * @dev Creates new voting round by calculating the `_round` number of chain `_chainId`.\n * Increases the `_round` number if the previous one is not expired. Delete the previous proposal\n * if it is expired and not increase the `_round`.\n */\n function _createVotingRound(uint256 _chainId) internal returns (uint256 _round) {\n _round = round[_chainId];\n // Skip checking for the first ever round\n if (_round == 0) {\n _round = round[_chainId] = 1;\n } else {\n ProposalVote storage _latestProposalVote = vote[_chainId][_round];\n bool _isExpired = _tryDeleteExpiredVotingRound(_latestProposalVote);\n // Skip increasing round number if the latest round is expired, allow the vote to be overridden\n if (!_isExpired) {\n if (_latestProposalVote.status == VoteStatus.Pending) revert ErrCurrentProposalIsNotCompleted();\n unchecked {\n _round = ++round[_chainId];\n }\n }\n }\n }\n\n /**\n * @dev Saves new round voting for the proposal `_proposalHash` of chain `_chainId`.\n */\n function _saveVotingRound(ProposalVote storage _vote, bytes32 _proposalHash, uint256 _expiryTimestamp) internal {\n _vote.hash = _proposalHash;\n _vote.expiryTimestamp = _expiryTimestamp;\n }\n\n /**\n * @dev Proposes for a new proposal.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposal(\n uint256 chainId,\n uint256 expiryTimestamp,\n address[] memory targets,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n uint256 round_ = _createVotingRound(chainId);\n\n proposal = Proposal.ProposalDetail(round_, chainId, expiryTimestamp, targets, values, calldatas, gasAmounts);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[chainId][round_], proposalHash, expiryTimestamp);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Proposes proposal struct.\n *\n * Requirements:\n * - The chain id is not equal to 0.\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `ProposalCreated` event.\n *\n */\n function _proposeProposalStruct(\n Proposal.ProposalDetail memory proposal,\n address creator\n ) internal virtual returns (uint256 round_) {\n uint256 chainId = proposal.chainId;\n if (chainId == 0) revert ErrInvalidChainId(msg.sig, 0, block.chainid);\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n round_ = _createVotingRound(chainId);\n _saveVotingRound(vote[chainId][round_], proposalHash, proposal.expiryTimestamp);\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit ProposalCreated(chainId, round_, proposalHash, proposal, creator);\n }\n\n /**\n * @dev Casts vote for the proposal with data and returns whether the voting is done.\n *\n * Requirements:\n * - The proposal nonce is equal to the round.\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n * Emits the `ProposalVoted` event. Emits the `ProposalApproved`, `ProposalExecuted` or `ProposalRejected` once the\n * proposal is approved, executed or rejected.\n *\n */\n function _castVote(\n Proposal.ProposalDetail memory proposal,\n Ballot.VoteType support,\n uint256 minimumForVoteWeight,\n uint256 minimumAgainstVoteWeight,\n address voter,\n Signature memory signature,\n uint256 voterWeight\n ) internal virtual returns (bool done) {\n uint256 chainId = proposal.chainId;\n uint256 round_ = proposal.nonce;\n ProposalVote storage _vote = vote[chainId][round_];\n\n if (_tryDeleteExpiredVotingRound(_vote)) {\n return true;\n }\n\n if (round[proposal.chainId] != round_) revert ErrInvalidProposalNonce(msg.sig);\n if (_vote.status != VoteStatus.Pending) revert ErrVoteIsFinalized();\n if (_voted(_vote, voter)) revert ErrAlreadyVoted(voter);\n\n _vote.voted[voter] = true;\n // Stores the signature if it is not empty\n if (signature.r > 0 || signature.s > 0 || signature.v > 0) {\n _vote.sig[voter] = signature;\n }\n emit ProposalVoted(_vote.hash, voter, support, voterWeight);\n\n uint256 _forVoteWeight;\n uint256 _againstVoteWeight;\n if (support == Ballot.VoteType.For) {\n _vote.forVoteds.push(voter);\n _forVoteWeight = _vote.forVoteWeight += voterWeight;\n } else if (support == Ballot.VoteType.Against) {\n _vote.againstVoteds.push(voter);\n _againstVoteWeight = _vote.againstVoteWeight += voterWeight;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_forVoteWeight >= minimumForVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, proposal);\n } else if (_againstVoteWeight >= minimumAgainstVoteWeight) {\n done = true;\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n }\n }\n\n /**\n * @dev When the contract is on Ronin chain, checks whether the proposal is expired and delete it if is expired.\n *\n * Emits the event `ProposalExpired` if the vote is expired.\n *\n * Note: This function assumes the vote `_proposalVote` is already created, consider verifying the vote's existence\n * before or it will emit an unexpected event of `ProposalExpired`.\n */\n function _tryDeleteExpiredVotingRound(ProposalVote storage proposalVote) internal returns (bool isExpired) {\n isExpired =\n _getChainType() == ChainType.RoninChain &&\n proposalVote.status == VoteStatus.Pending &&\n proposalVote.expiryTimestamp <= block.timestamp;\n\n if (isExpired) {\n emit ProposalExpired(proposalVote.hash);\n\n for (uint256 _i; _i < proposalVote.forVoteds.length; ) {\n delete proposalVote.voted[proposalVote.forVoteds[_i]];\n delete proposalVote.sig[proposalVote.forVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < proposalVote.againstVoteds.length; ) {\n delete proposalVote.voted[proposalVote.againstVoteds[_i]];\n delete proposalVote.sig[proposalVote.againstVoteds[_i]];\n\n unchecked {\n ++_i;\n }\n }\n delete proposalVote.status;\n delete proposalVote.hash;\n delete proposalVote.againstVoteWeight;\n delete proposalVote.forVoteWeight;\n delete proposalVote.forVoteds;\n delete proposalVote.againstVoteds;\n delete proposalVote.expiryTimestamp;\n }\n }\n\n /**\n * @dev Executes the proposal and update the vote status once the proposal is executable.\n */\n function _tryExecute(ProposalVote storage vote_, Proposal.ProposalDetail memory proposal) internal {\n if (proposal.executable()) {\n vote_.status = VoteStatus.Executed;\n (bool[] memory _successCalls, bytes[] memory _returnDatas) = proposal.execute();\n emit ProposalExecuted(vote_.hash, _successCalls, _returnDatas);\n }\n }\n\n /**\n * @dev Sets the expiry duration for a new proposal.\n */\n function _setProposalExpiryDuration(uint256 expiryDuration) internal {\n _proposalExpiryDuration = expiryDuration;\n emit ProposalExpiryDurationChanged(expiryDuration);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function _getProposalExpiryDuration() internal view returns (uint256) {\n return _proposalExpiryDuration;\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function _voted(ProposalVote storage vote_, address voter) internal view returns (bool) {\n return vote_.voted[voter];\n }\n\n /**\n * @dev Returns total weight from validators.\n */\n function _getTotalWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns minimum vote to pass a proposal.\n */\n function _getMinimumVoteWeight() internal view virtual returns (uint256);\n\n /**\n * @dev Returns current context is running on whether Ronin chain or on mainchain.\n */\n function _getChainType() internal view virtual returns (ChainType);\n}\n" + }, + "contracts/extensions/sequential-governance/GlobalCoreGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Proposal.sol\";\nimport \"../../libraries/GlobalProposal.sol\";\nimport \"./CoreGovernance.sol\";\n\nabstract contract GlobalCoreGovernance is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n mapping(GlobalProposal.TargetOption => address) internal _targetOptionsMap;\n\n /// @dev Emitted when a proposal is created\n event GlobalProposalCreated(\n uint256 indexed round,\n bytes32 indexed proposalHash,\n Proposal.ProposalDetail proposal,\n bytes32 globalProposalHash,\n GlobalProposal.GlobalProposalDetail globalProposal,\n address creator\n );\n\n /// @dev Emitted when the target options are updated\n event TargetOptionUpdated(GlobalProposal.TargetOption indexed targetOption, address indexed addr);\n\n constructor(GlobalProposal.TargetOption[] memory targetOptions, address[] memory addrs) {\n _updateTargetOption(GlobalProposal.TargetOption.BridgeManager, address(this));\n _updateManyTargetOption(targetOptions, addrs);\n }\n\n /**\n * @dev Proposes for a global proposal.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] memory values,\n bytes[] memory calldatas,\n uint256[] memory gasAmounts,\n address creator\n ) internal virtual {\n uint256 round_ = _createVotingRound(0);\n GlobalProposal.GlobalProposalDetail memory globalProposal = GlobalProposal.GlobalProposalDetail(\n round_,\n expiryTimestamp,\n targetOptions,\n values,\n calldatas,\n gasAmounts\n );\n Proposal.ProposalDetail memory proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n _saveVotingRound(vote[0][round_], proposalHash, expiryTimestamp);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Proposes global proposal struct.\n *\n * Requirements:\n * - The proposal nonce is equal to the new round.\n *\n * Emits the `GlobalProposalCreated` event.\n *\n */\n function _proposeGlobalStruct(\n GlobalProposal.GlobalProposalDetail memory globalProposal,\n address creator\n ) internal virtual returns (Proposal.ProposalDetail memory proposal) {\n proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n proposal.validate(_proposalExpiryDuration);\n\n bytes32 proposalHash = proposal.hash();\n uint256 round_ = _createVotingRound(0);\n _saveVotingRound(vote[0][round_], proposalHash, globalProposal.expiryTimestamp);\n\n if (round_ != proposal.nonce) revert ErrInvalidProposalNonce(msg.sig);\n emit GlobalProposalCreated(round_, proposalHash, proposal, globalProposal.hash(), globalProposal, creator);\n }\n\n /**\n * @dev Returns corresponding address of target options. Return address(0) on non-existent target.\n */\n function resolveTargets(\n GlobalProposal.TargetOption[] calldata targetOptions\n ) external view returns (address[] memory targets) {\n return _resolveTargets({ targetOptions: targetOptions, strict: false });\n }\n\n /**\n * @dev Internal helper of {resolveTargets}.\n *\n * @param strict When the param is set to `true`, revert on non-existent target.\n */\n function _resolveTargets(\n GlobalProposal.TargetOption[] memory targetOptions,\n bool strict\n ) internal view returns (address[] memory targets) {\n targets = new address[](targetOptions.length);\n\n for (uint256 i; i < targetOptions.length; ) {\n targets[i] = _targetOptionsMap[targetOptions[i]];\n if (strict && targets[i] == address(0)) revert ErrInvalidArguments(msg.sig);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n *\n * Requirement:\n * - Only allow self-call through proposal.\n * */\n function updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) external {\n // HACK: Cannot reuse the existing library due to too deep stack\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n _updateManyTargetOption(targetOptions, targets);\n }\n\n /**\n * @dev Updates list of `targetOptions` to `targets`.\n */\n function _updateManyTargetOption(\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n ) internal {\n for (uint256 i; i < targetOptions.length; ) {\n if (targets[i] == address(this)) revert ErrInvalidArguments(msg.sig);\n _updateTargetOption(targetOptions[i], targets[i]);\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Updates `targetOption` to `target`.\n *\n * Requirement:\n * - Emit a `TargetOptionUpdated` event.\n */\n function _updateTargetOption(GlobalProposal.TargetOption targetOption, address target) internal {\n _targetOptionsMap[targetOption] = target;\n emit TargetOptionUpdated(targetOption, target);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/CommonGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceProposal is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Error thrown when an invalid proposal is encountered.\n * @param actual The actual value of the proposal.\n * @param expected The expected value of the proposal.\n */\n error ErrInvalidProposal(bytes32 actual, bytes32 expected);\n\n /**\n * @dev Casts votes by signatures.\n *\n * Note: This method does not verify the proposal hash with the vote hash. Please consider checking it before.\n *\n */\n function _castVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length != 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n\n address _lastSigner;\n address _signer;\n Signature calldata _sig;\n bool _hasValidVotes;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n\n if (_supports[_i] == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n } else if (_supports[_i] == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n uint256 _weight = _getWeight(_signer);\n if (_weight > 0) {\n _hasValidVotes = true;\n if (\n _castVote(_proposal, _supports[_i], _minimumForVoteWeight, _minimumAgainstVoteWeight, _signer, _sig, _weight)\n ) {\n return;\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_hasValidVotes) revert ErrInvalidSignatures(msg.sig);\n }\n\n /**\n * @dev Returns the voted signatures for the proposals.\n *\n * Note: The signatures can be empty in case the proposal is voted on the current network.\n *\n */\n function _getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n internal\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n ProposalVote storage _vote = vote[_chainId][_round];\n\n uint256 _forLength = _vote.forVoteds.length;\n uint256 _againstLength = _vote.againstVoteds.length;\n uint256 _voterLength = _forLength + _againstLength;\n\n _supports = new Ballot.VoteType[](_voterLength);\n _signatures = new Signature[](_voterLength);\n _voters = new address[](_voterLength);\n for (uint256 _i; _i < _forLength; ) {\n _supports[_i] = Ballot.VoteType.For;\n _signatures[_i] = vote[_chainId][_round].sig[_vote.forVoteds[_i]];\n _voters[_i] = _vote.forVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n for (uint256 _i; _i < _againstLength; ) {\n _supports[_i + _forLength] = Ballot.VoteType.Against;\n _signatures[_i + _forLength] = vote[_chainId][_round].sig[_vote.againstVoteds[_i]];\n _voters[_i + _forLength] = _vote.againstVoteds[_i];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function _proposalVoted(uint256 _chainId, uint256 _round, address _voter) internal view returns (bool) {\n return _voted(vote[_chainId][_round], _voter);\n }\n\n /**\n * @dev Returns the weight of a governor.\n */\n function _getWeight(address _governor) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../../libraries/Proposal.sol\";\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GlobalGovernanceProposal is GlobalCoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Proposes and votes by signature.\n */\n function _proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal returns (Proposal.ProposalDetail memory proposal) {\n proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 _globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(_globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a global proposal struct and casts votes by signature.\n */\n function _castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator\n ) internal {\n Proposal.ProposalDetail memory _proposal = globalProposal.intoProposalDetail(\n _resolveTargets({ targetOptions: globalProposal.targetOptions, strict: true })\n );\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[0][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[0][_proposal.nonce].hash);\n\n bytes32 globalProposalHash = globalProposal.hash();\n _castVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getGlobalProposalSignatures(\n uint256 round_\n ) external view returns (address[] memory voters, Ballot.VoteType[] memory supports_, Signature[] memory signatures) {\n return _getProposalSignatures(0, round_);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function globalProposalVoted(uint256 round_, address voter) external view returns (bool) {\n return _proposalVoted(0, round_, voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-proposal/GovernanceProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceProposal.sol\";\n\nabstract contract GovernanceProposal is CoreGovernance, CommonGovernanceProposal {\n using Proposal for Proposal.ProposalDetail;\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev Proposes a proposal struct and casts votes by signature.\n */\n function _castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator\n ) internal {\n bytes32 _proposalHash = _proposal.hash();\n\n if (vote[_proposal.chainId][_proposal.nonce].hash != _proposalHash) {\n revert ErrInvalidProposal(_proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n }\n\n _castVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n\n /**\n * @dev See `castProposalVoteForCurrentNetwork`.\n */\n function _castProposalVoteForCurrentNetwork(\n address _voter,\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType _support\n ) internal {\n if (_proposal.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n bytes32 proposalHash = _proposal.hash();\n if (vote[_proposal.chainId][_proposal.nonce].hash != proposalHash)\n revert ErrInvalidProposal(proposalHash, vote[_proposal.chainId][_proposal.nonce].hash);\n\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n Signature memory _emptySignature;\n _castVote(\n _proposal,\n _support,\n _minimumForVoteWeight,\n _minimumAgainstVoteWeight,\n _voter,\n _emptySignature,\n _getWeight(_voter)\n );\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_getProposalSignatures}\n */\n function getProposalSignatures(\n uint256 _chainId,\n uint256 _round\n )\n external\n view\n returns (address[] memory _voters, Ballot.VoteType[] memory _supports, Signature[] memory _signatures)\n {\n return _getProposalSignatures(_chainId, _round);\n }\n\n /**\n * @dev See {CommonGovernanceProposal-_proposalVoted}\n */\n function proposalVoted(uint256 _chainId, uint256 _round, address _voter) external view returns (bool) {\n return _proposalVoted(_chainId, _round, _voter);\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/CommonGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\n\nabstract contract CommonGovernanceRelay is CoreGovernance {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays votes by signatures.\n *\n * @notice Does not store the voter signature into storage.\n *\n */\n function _relayVotesBySignatures(\n Proposal.ProposalDetail memory _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _forDigest,\n bytes32 _againstDigest\n ) internal {\n if (!(_supports.length > 0 && _supports.length == _signatures.length)) revert ErrLengthMismatch(msg.sig);\n\n uint256 _forVoteCount;\n uint256 _againstVoteCount;\n address[] memory _forVoteSigners = new address[](_signatures.length);\n address[] memory _againstVoteSigners = new address[](_signatures.length);\n\n {\n address _signer;\n address _lastSigner;\n Ballot.VoteType _support;\n Signature calldata _sig;\n\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _support = _supports[_i];\n\n if (_support == Ballot.VoteType.For) {\n _signer = ECDSA.recover(_forDigest, _sig.v, _sig.r, _sig.s);\n _forVoteSigners[_forVoteCount++] = _signer;\n } else if (_support == Ballot.VoteType.Against) {\n _signer = ECDSA.recover(_againstDigest, _sig.v, _sig.r, _sig.s);\n _againstVoteSigners[_againstVoteCount++] = _signer;\n } else revert ErrUnsupportedVoteType(msg.sig);\n\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n _lastSigner = _signer;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n assembly {\n mstore(_forVoteSigners, _forVoteCount)\n mstore(_againstVoteSigners, _againstVoteCount)\n }\n\n ProposalVote storage _vote = vote[_proposal.chainId][_proposal.nonce];\n uint256 _minimumForVoteWeight = _getMinimumVoteWeight();\n uint256 _totalForVoteWeight = _sumWeight(_forVoteSigners);\n if (_totalForVoteWeight >= _minimumForVoteWeight) {\n if (_totalForVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Approved;\n emit ProposalApproved(_vote.hash);\n _tryExecute(_vote, _proposal);\n return;\n }\n\n uint256 _minimumAgainstVoteWeight = _getTotalWeight() - _minimumForVoteWeight + 1;\n uint256 _totalAgainstVoteWeight = _sumWeight(_againstVoteSigners);\n if (_totalAgainstVoteWeight >= _minimumAgainstVoteWeight) {\n if (_totalAgainstVoteWeight == 0) revert ErrInvalidVoteWeight(msg.sig);\n _vote.status = VoteStatus.Rejected;\n emit ProposalRejected(_vote.hash);\n return;\n }\n\n revert ErrRelayFailed(msg.sig);\n }\n\n /**\n * @dev Returns the weight of the governor list.\n */\n function _sumWeight(address[] memory _governors) internal view virtual returns (uint256);\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../GlobalCoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GlobalGovernanceRelay is CommonGovernanceRelay, GlobalCoreGovernance {\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Returns whether the voter `_voter` casted vote for the proposal.\n */\n function globalProposalRelayed(uint256 _round) external view returns (bool) {\n return vote[0][_round].status != VoteStatus.Pending;\n }\n\n /**\n * @dev Relays voted global proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures,\n bytes32 domainSeparator,\n address creator\n ) internal {\n Proposal.ProposalDetail memory _proposal = _proposeGlobalStruct(globalProposal, creator);\n bytes32 globalProposalHash = globalProposal.hash();\n _relayVotesBySignatures(\n _proposal,\n supports_,\n signatures,\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(domainSeparator, Ballot.hash(globalProposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/sequential-governance/governance-relay/GovernanceRelay.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../CoreGovernance.sol\";\nimport \"./CommonGovernanceRelay.sol\";\n\nabstract contract GovernanceRelay is CoreGovernance, CommonGovernanceRelay {\n using Proposal for Proposal.ProposalDetail;\n using GlobalProposal for GlobalProposal.GlobalProposalDetail;\n\n /**\n * @dev Relays voted proposal.\n *\n * Requirements:\n * - The relay proposal is finalized.\n *\n */\n function _relayProposal(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures,\n bytes32 _domainSeparator,\n address _creator\n ) internal {\n _proposeProposalStruct(_proposal, _creator);\n bytes32 _proposalHash = _proposal.hash();\n _relayVotesBySignatures(\n _proposal,\n _supports,\n _signatures,\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.For)),\n ECDSA.toTypedDataHash(_domainSeparator, Ballot.hash(_proposalHash, Ballot.VoteType.Against))\n );\n }\n}\n" + }, + "contracts/extensions/TransparentUpgradeableProxyV2.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol\";\n\ncontract TransparentUpgradeableProxyV2 is TransparentUpgradeableProxy {\n constructor(\n address _logic,\n address admin_,\n bytes memory _data\n ) payable TransparentUpgradeableProxy(_logic, admin_, _data) {}\n\n /**\n * @dev Calls a function from the current implementation as specified by `_data`, which should be an encoded function call.\n *\n * Requirements:\n * - Only the admin can call this function.\n *\n * Note: The proxy admin is not allowed to interact with the proxy logic through the fallback function to avoid\n * triggering some unexpected logic. This is to allow the administrator to explicitly call the proxy, please consider\n * reviewing the encoded data `_data` and the method which is called before using this.\n *\n */\n function functionDelegateCall(bytes memory _data) public payable ifAdmin {\n address _addr = _implementation();\n assembly {\n let _result := delegatecall(gas(), _addr, add(_data, 32), mload(_data), 0, 0)\n returndatacopy(0, 0, returndatasize())\n switch _result\n case 0 {\n revert(0, returndatasize())\n }\n default {\n return(0, returndatasize())\n }\n }\n }\n}\n" + }, + "contracts/extensions/version-control/ConditionalImplementControl.sol": { + "content": "/// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { HasContracts } from \"../collections/HasContracts.sol\";\nimport { IConditionalImplementControl } from \"../../interfaces/version-control/IConditionalImplementControl.sol\";\nimport { ErrorHandler } from \"../../libraries/ErrorHandler.sol\";\nimport { AddressArrayUtils } from \"../../libraries/AddressArrayUtils.sol\";\nimport { ErrOnlySelfCall, IdentityGuard } from \"../../utils/IdentityGuard.sol\";\n\n/**\n * @title ConditionalImplementControl\n * @dev A contract that allows conditional version control of contract implementations.\n */\nabstract contract ConditionalImplementControl is IConditionalImplementControl, IdentityGuard, HasContracts {\n using ErrorHandler for bool;\n using AddressArrayUtils for address[];\n\n /**\n * @dev Storage slot with the address of the current implementation.\n * This is the keccak-256 hash of \"eip1967.proxy.implementation\" subtracted by 1, and is\n * validated in the constructor.\n */\n bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;\n\n /// @dev value is equal to keccak256(\"@ronin.extensions.version-control.ConditionalImplementControl.calldatas.slot\") - 1\n bytes32 internal constant CALLDATAS_SLOT = 0x330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633;\n\n /**\n * @dev address of the proxy that delegates to this contract.\n * @notice immutable variables are directly stored in contract code.\n * ensuring no storage writes are required.\n * The values of immutable variables remain fixed and cannot be modified,\n * regardless of any interactions, including delegations.\n */\n address public immutable PROXY_STORAGE;\n /**\n * @dev The address of the new implementation.\n */\n address public immutable NEW_IMPL;\n /**\n * @dev The address of the previous implementation.\n */\n address public immutable PREV_IMPL;\n\n /**\n * @dev Modifier that executes the function when conditions are met.\n */\n modifier whenConditionsAreMet() virtual {\n _;\n if (_isConditionMet()) {\n try this.selfUpgrade{ gas: _gasStipenedNoGrief() }() {} catch {}\n }\n }\n\n /**\n * @dev Modifier that only allows delegate calls from the admin proxy storage.\n */\n modifier onlyDelegateFromProxyStorage() virtual {\n _requireDelegateFromProxyStorage();\n _;\n }\n\n /**\n * @dev Constructs the ConditionalImplementControl contract.\n * @param proxyStorage The address of the proxy that is allowed to delegate to this contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(address proxyStorage, address prevImpl, address newImpl) {\n _requireHasCode(newImpl);\n _requireHasCode(prevImpl);\n _requireHasCode(proxyStorage);\n\n address[] memory addrs = new address[](3);\n addrs[0] = proxyStorage;\n addrs[1] = prevImpl;\n addrs[2] = newImpl;\n if (addrs.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n\n PROXY_STORAGE = proxyStorage;\n NEW_IMPL = newImpl;\n PREV_IMPL = prevImpl;\n }\n\n /**\n * @dev Fallback function that forwards the call to the current or new contract implementation based on a condition.\n */\n fallback() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev Receive function that forwards the call to the current or new contract implementation based on a condition.\n */\n receive() external payable virtual onlyDelegateFromProxyStorage {\n _fallback();\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external virtual onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n }\n\n /**\n * @dev See {IConditionalImplementControl-setCallDatas}.\n */\n function setCallDatas(bytes[] calldata args) external onlyAdmin onlyDelegateFromProxyStorage {\n bytes[] storage callDatas = _callDatas();\n uint256 length = args.length;\n for (uint256 i; i < length; ) {\n callDatas.push(args[i]);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to access the array of calldatas.\n * @return callDatas the storage array of calldatas.\n */\n function _callDatas() internal pure returns (bytes[] storage callDatas) {\n assembly (\"memory-safe\") {\n callDatas.slot := CALLDATAS_SLOT\n }\n }\n\n function _upgradeTo(address newImplementation) internal {\n assembly (\"memory-safe\") {\n sstore(_IMPLEMENTATION_SLOT, newImplementation)\n }\n emit Upgraded(newImplementation);\n\n bytes[] storage callDatas = _callDatas();\n uint256 length = callDatas.length;\n bool success;\n bytes memory returnOrRevertData;\n for (uint256 i; i < length; ) {\n (success, returnOrRevertData) = newImplementation.delegatecall(callDatas[i]);\n success.handleRevert(bytes4(callDatas[i]), returnOrRevertData);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @dev Internal function to get the current version of the contract implementation.\n * @return The address of the current version.\n */\n function _getConditionedImplementation() internal view virtual returns (address) {\n return _isConditionMet() ? NEW_IMPL : PREV_IMPL;\n }\n\n /**\n * @dev Internal function to check if the condition for switching implementation is met.\n * @return the boolean indicating if condition is met.\n */\n function _isConditionMet() internal view virtual returns (bool) {}\n\n /**\n * @dev Logic for fallback function.\n */\n function _fallback() internal virtual {\n bytes memory returnData = _dispatchCall(_getConditionedImplementation());\n assembly {\n return(add(returnData, 0x20), mload(returnData))\n }\n }\n\n /**\n * @dev Internal function to dispatch the call to the specified version.\n * @param impl The address of the version to call.\n * @return returnData The return data of the call.\n */\n function _dispatchCall(address impl) internal virtual whenConditionsAreMet returns (bytes memory returnData) {\n (bool success, bytes memory returnOrRevertData) = impl.delegatecall(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n returnData := returnOrRevertData\n }\n }\n\n /**\n * @dev Internal function to check if the caller is delegating from proxy storage.\n * Throws an error if the current implementation of the proxy storage is not this contract.\n */\n function _requireDelegateFromProxyStorage() private view {\n if (address(this) != PROXY_STORAGE) revert ErrDelegateFromUnknownOrigin(address(this));\n }\n\n /**\n * @dev Internal method to check method caller.\n *\n * Requirements:\n *\n * - The method caller must be this contract.\n *\n */\n function _requireSelfCall() internal view virtual override {\n if (msg.sender != PROXY_STORAGE) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Suggested gas stipend for contract to call {selfUpgrade} function.\n */\n function _gasStipenedNoGrief() internal pure virtual returns (uint256) {\n // Gas stipend for contract to perform a few read and write operations on storage, but\n // low enough to prevent comsuming gas exhaustively when function call are reverted.\n // Multiply by a small constant (e.g. 2), if needed.\n return 50_000;\n }\n}\n" + }, + "contracts/extensions/WithdrawalLimitation.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./GatewayV3.sol\";\n\nabstract contract WithdrawalLimitation is GatewayV3 {\n /// @dev Error of invalid percentage.\n error ErrInvalidPercentage();\n\n /// @dev Emitted when the high-tier vote weight threshold is updated\n event HighTierVoteWeightThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when the thresholds for high-tier withdrawals that requires high-tier vote weights are updated\n event HighTierThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the thresholds for locked withdrawals are updated\n event LockedThresholdsUpdated(address[] tokens, uint256[] thresholds);\n /// @dev Emitted when the fee percentages to unlock withdraw are updated\n event UnlockFeePercentagesUpdated(address[] tokens, uint256[] percentages);\n /// @dev Emitted when the daily limit thresholds are updated\n event DailyWithdrawalLimitsUpdated(address[] tokens, uint256[] limits);\n\n uint256 public constant _MAX_PERCENTAGE = 1_000_000;\n\n uint256 internal _highTierVWNum;\n uint256 internal _highTierVWDenom;\n\n /// @dev Mapping from mainchain token => the amount thresholds for high-tier withdrawals that requires high-tier vote weights\n mapping(address => uint256) public highTierThreshold;\n /// @dev Mapping from mainchain token => the amount thresholds to lock withdrawal\n mapping(address => uint256) public lockedThreshold;\n /// @dev Mapping from mainchain token => unlock fee percentages for unlocker\n /// @notice Values 0-1,000,000 map to 0%-100%\n mapping(address => uint256) public unlockFeePercentages;\n /// @dev Mapping from mainchain token => daily limit amount for withdrawal\n mapping(address => uint256) public dailyWithdrawalLimit;\n /// @dev Mapping from token address => today withdrawal amount\n mapping(address => uint256) public lastSyncedWithdrawal;\n /// @dev Mapping from token address => last date synced to record the `lastSyncedWithdrawal`\n mapping(address => uint256) public lastDateSynced;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @dev Override `GatewayV3-setThreshold`.\n *\n * Requirements:\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual override onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Returns the high-tier vote weight threshold.\n */\n function getHighTierVoteWeightThreshold() external view virtual returns (uint256, uint256) {\n return (_highTierVWNum, _highTierVWDenom);\n }\n\n /**\n * @dev Checks whether the `_voteWeight` passes the high-tier vote weight threshold.\n */\n function checkHighTierVoteWeightThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _highTierVWDenom >= _highTierVWNum * _getTotalWeight();\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Requirements:\n * - The method caller is admin.\n * - The high-tier vote weight threshold must equal to or larger than the normal threshold.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external virtual onlyAdmin returns (uint256 _previousNum, uint256 _previousDenom) {\n (_previousNum, _previousDenom) = _setHighTierVoteWeightThreshold(_numerator, _denominator);\n _verifyThresholds();\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function setHighTierThresholds(\n address[] calldata _tokens,\n uint256[] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setHighTierThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setLockedThresholds(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function setUnlockFeePercentages(\n address[] calldata _tokens,\n uint256[] calldata _percentages\n ) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setUnlockFeePercentages(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) external virtual onlyAdmin {\n if (_tokens.length == 0) revert ErrEmptyArray();\n _setDailyWithdrawalLimits(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the limitation.\n */\n function reachedWithdrawalLimit(address _token, uint256 _quantity) external view virtual returns (bool) {\n return _reachedWithdrawalLimit(_token, _quantity);\n }\n\n /**\n * @dev Sets high-tier vote weight threshold and returns the old one.\n *\n * Emits the `HighTierVoteWeightThresholdUpdated` event.\n *\n */\n function _setHighTierVoteWeightThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _highTierVWNum;\n _previousDenom = _highTierVWDenom;\n _highTierVWNum = _numerator;\n _highTierVWDenom = _denominator;\n\n unchecked {\n emit HighTierVoteWeightThresholdUpdated(nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Sets the thresholds for high-tier withdrawals that requires high-tier vote weights.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `HighTierThresholdsUpdated` event.\n *\n */\n function _setHighTierThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n highTierThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit HighTierThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets the amount thresholds to lock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `LockedThresholdsUpdated` event.\n *\n */\n function _setLockedThresholds(address[] calldata _tokens, uint256[] calldata _thresholds) internal virtual {\n if (_tokens.length != _thresholds.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n lockedThreshold[_tokens[_i]] = _thresholds[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit LockedThresholdsUpdated(_tokens, _thresholds);\n }\n\n /**\n * @dev Sets fee percentages to unlock withdrawal.\n *\n * Requirements:\n * - The array lengths are equal.\n * - The percentage is equal to or less than 100_000.\n *\n * Emits the `UnlockFeePercentagesUpdated` event.\n *\n */\n function _setUnlockFeePercentages(address[] calldata _tokens, uint256[] calldata _percentages) internal virtual {\n if (_tokens.length != _percentages.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n if (_percentages[_i] > _MAX_PERCENTAGE) revert ErrInvalidPercentage();\n\n unlockFeePercentages[_tokens[_i]] = _percentages[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit UnlockFeePercentagesUpdated(_tokens, _percentages);\n }\n\n /**\n * @dev Sets daily limit amounts for the withdrawals.\n *\n * Requirements:\n * - The array lengths are equal.\n *\n * Emits the `DailyWithdrawalLimitsUpdated` event.\n *\n */\n function _setDailyWithdrawalLimits(address[] calldata _tokens, uint256[] calldata _limits) internal virtual {\n if (_tokens.length != _limits.length) revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _tokens.length; ) {\n dailyWithdrawalLimit[_tokens[_i]] = _limits[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit DailyWithdrawalLimitsUpdated(_tokens, _limits);\n }\n\n /**\n * @dev Checks whether the withdrawal reaches the daily limitation.\n *\n * Requirements:\n * - The daily withdrawal threshold should not apply for locked withdrawals.\n *\n */\n function _reachedWithdrawalLimit(address _token, uint256 _quantity) internal view virtual returns (bool) {\n if (_lockedWithdrawalRequest(_token, _quantity)) {\n return false;\n }\n\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n return dailyWithdrawalLimit[_token] <= _quantity;\n } else {\n return dailyWithdrawalLimit[_token] <= lastSyncedWithdrawal[_token] + _quantity;\n }\n }\n\n /**\n * @dev Record withdrawal token.\n */\n function _recordWithdrawal(address _token, uint256 _quantity) internal virtual {\n uint256 _currentDate = block.timestamp / 1 days;\n if (_currentDate > lastDateSynced[_token]) {\n lastDateSynced[_token] = _currentDate;\n lastSyncedWithdrawal[_token] = _quantity;\n } else {\n lastSyncedWithdrawal[_token] += _quantity;\n }\n }\n\n /**\n * @dev Returns whether the withdrawal request is locked or not.\n */\n function _lockedWithdrawalRequest(address _token, uint256 _quantity) internal view virtual returns (bool) {\n return lockedThreshold[_token] <= _quantity;\n }\n\n /**\n * @dev Computes fee percentage.\n */\n function _computeFeePercentage(uint256 _amount, uint256 _percentage) internal view virtual returns (uint256) {\n return (_amount * _percentage) / _MAX_PERCENTAGE;\n }\n\n /**\n * @dev Returns high-tier vote weight.\n */\n function _highTierVoteWeight(uint256 _totalWeight) internal view virtual returns (uint256) {\n return (_highTierVWNum * _totalWeight + _highTierVWDenom - 1) / _highTierVWDenom;\n }\n\n /**\n * @dev Validates whether the high-tier vote weight threshold is larger than the normal threshold.\n */\n function _verifyThresholds() internal view {\n if (_num * _highTierVWDenom > _highTierVWNum * _denom) revert ErrInvalidThreshold(msg.sig);\n }\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeManagerEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerEvents {\n /**\n * @dev The structure representing information about a bridge operator.\n * @param addr The address of the bridge operator.\n * @param voteWeight The vote weight assigned to the bridge operator.\n */\n struct BridgeOperatorInfo {\n address addr;\n uint96 voteWeight;\n }\n\n /**\n * @dev Emitted when new bridge operators are added.\n * @param statuses The array of boolean values represents whether the corresponding bridge operator is added successfully.\n * @param voteWeights The array of vote weights assigned to the added bridge operators.\n * @param governors The array of addresses representing the governors associated with the added bridge operators.\n * @param bridgeOperators The array of addresses representing the added bridge operators.\n */\n event BridgeOperatorsAdded(bool[] statuses, uint96[] voteWeights, address[] governors, address[] bridgeOperators);\n\n /**\n * @dev Emitted when bridge operators are removed.\n * @param statuses The array of boolean values representing the statuses of the removed bridge operators.\n * @param bridgeOperators The array of addresses representing the removed bridge operators.\n */\n event BridgeOperatorsRemoved(bool[] statuses, address[] bridgeOperators);\n\n /**\n * @dev Emitted when a bridge operator is updated.\n * @param governor The address of the governor initiating the update.\n * @param fromBridgeOperator The address of the bridge operator being updated.\n * @param toBridgeOperator The updated address of the bridge operator.\n */\n event BridgeOperatorUpdated(\n address indexed governor,\n address indexed fromBridgeOperator,\n address indexed toBridgeOperator\n );\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeRewardEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeRewardEvents {\n /**\n * @dev Reward-related information for a bridge operator.\n * @param claimed The amount of rewards claimed by the bridge operator.\n * @param slashed The amount of rewards that have been slashed from the bridge operator.\n */\n struct BridgeRewardInfo {\n uint256 claimed;\n uint256 slashed;\n }\n\n /**\n * @dev Emitted when RON are safely received as rewards in the contract.\n * @param from The address of the sender who transferred RON tokens as rewards.\n * @param balanceBefore The balance of the contract before receiving the RON tokens.\n * @param amount The amount of RON received.\n */\n event SafeReceived(address indexed from, uint256 balanceBefore, uint256 amount);\n /// @dev Event emitted when the reward per period config is updated.\n event UpdatedRewardPerPeriod(uint256 newRewardPerPeriod);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount`.\n event BridgeRewardScattered(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is slashed with `amount`.\n event BridgeRewardSlashed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the reward of the `operator` is scattered with `amount` but failed to transfer.\n event BridgeRewardScatterFailed(uint256 indexed period, address operator, uint256 amount);\n /// @dev Event emitted when the requesting period to sync is too far.\n event BridgeRewardSyncTooFarPeriod(uint256 requestingPeriod, uint256 latestPeriod);\n}\n" + }, + "contracts/interfaces/bridge/events/IBridgeSlashEvents.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeSlashEvents {\n /**\n * @dev Enumeration representing the slashing tiers for bridge operators.\n */\n enum Tier {\n Tier0,\n Tier1,\n Tier2\n }\n\n /**\n * @dev Struct representing the status of a bridge operator.\n */\n struct BridgeSlashInfo {\n uint128 slashUntilPeriod;\n uint128 newlyAddedAtPeriod;\n }\n\n /**\n * @dev Event emitted when a bridge operator is slashed.\n * @param tier The slash tier of the operator.\n * @param bridgeOperator The address of the slashed bridge operator.\n * @param period The period in which the operator is slashed.\n * @param slashUntilPeriod The period until which the operator is penalized.\n */\n event Slashed(Tier indexed tier, address indexed bridgeOperator, uint256 indexed period, uint256 slashUntilPeriod);\n\n /**\n * @dev Emitted when a removal request is made for a bridge operator.\n * @param period The period for which the removal request is made.\n * @param bridgeOperator The address of the bridge operator being requested for removal.\n */\n event RemovalRequested(uint256 indexed period, address indexed bridgeOperator);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeManagerEvents } from \"./events/IBridgeManagerEvents.sol\";\n\n/**\n * @title IBridgeManager\n * @dev The interface for managing bridge operators.\n */\ninterface IBridgeManager is IBridgeManagerEvents {\n /**\n * @dev The domain separator used for computing hash digests in the contract.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns the total number of bridge operators.\n * @return The total number of bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Checks if the given address is a bridge operator.\n * @param addr The address to check.\n * @return A boolean indicating whether the address is a bridge operator.\n */\n function isBridgeOperator(address addr) external view returns (bool);\n\n /**\n * @dev Retrieves the full information of all registered bridge operators.\n *\n * This external function allows external callers to obtain the full information of all the registered bridge operators.\n * The returned arrays include the addresses of governors, bridge operators, and their corresponding vote weights.\n *\n * @return governors An array of addresses representing the governors of each bridge operator.\n * @return bridgeOperators An array of addresses representing the registered bridge operators.\n * @return weights An array of uint256 values representing the vote weights of each bridge operator.\n *\n * Note: The length of each array will be the same, and the order of elements corresponds to the same bridge operator.\n *\n * Example Usage:\n * ```\n * (address[] memory governors, address[] memory bridgeOperators, uint256[] memory weights) = getFullBridgeOperatorInfos();\n * for (uint256 i = 0; i < bridgeOperators.length; i++) {\n * // Access individual information for each bridge operator.\n * address governor = governors[i];\n * address bridgeOperator = bridgeOperators[i];\n * uint256 weight = weights[i];\n * // ... (Process or use the information as required) ...\n * }\n * ```\n *\n */\n function getFullBridgeOperatorInfos()\n external\n view\n returns (address[] memory governors, address[] memory bridgeOperators, uint96[] memory weights);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorsWeight(address[] calldata governors) external view returns (uint256 sum);\n\n /**\n * @dev Returns total weights.\n */\n function getTotalWeight() external view returns (uint256);\n\n /**\n * @dev Returns an array of all bridge operators.\n * @return An array containing the addresses of all bridge operators.\n */\n function getBridgeOperators() external view returns (address[] memory);\n\n /**\n * @dev Returns an array of bridge operators correspoding to governor addresses.\n * @return bridgeOperators_ An array containing the addresses of all bridge operators.\n */\n function getBridgeOperatorOf(address[] calldata gorvernors) external view returns (address[] memory bridgeOperators_);\n\n /**\n * @dev Retrieves the governors corresponding to a given array of bridge operators.\n * This external function allows external callers to obtain the governors associated with a given array of bridge operators.\n * The function takes an input array `bridgeOperators` containing bridge operator addresses and returns an array of corresponding governors.\n * @param bridgeOperators An array of bridge operator addresses for which governors are to be retrieved.\n * @return governors An array of addresses representing the governors corresponding to the provided bridge operators.\n */\n function getGovernorsOf(address[] calldata bridgeOperators) external view returns (address[] memory governors);\n\n /**\n * @dev External function to retrieve the vote weight of a specific governor.\n * @param governor The address of the governor to get the vote weight for.\n * @return voteWeight The vote weight of the specified governor.\n */\n function getGovernorWeight(address governor) external view returns (uint96);\n\n /**\n * @dev External function to retrieve the vote weight of a specific bridge operator.\n * @param bridgeOperator The address of the bridge operator to get the vote weight for.\n * @return weight The vote weight of the specified bridge operator.\n */\n function getBridgeOperatorWeight(address bridgeOperator) external view returns (uint96 weight);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata governors) external view returns (uint96[] memory weights);\n\n /**\n * @dev Returns an array of all governors.\n * @return An array containing the addresses of all governors.\n */\n function getGovernors() external view returns (address[] memory);\n\n /**\n * @dev Adds multiple bridge operators.\n * @param governors An array of addresses of hot/cold wallets for bridge operator to update their node address.\n * @param bridgeOperators An array of addresses representing the bridge operators to add.\n * @return addeds An array of booleans indicating whether each bridge operator was added successfully.\n *\n * Note: return boolean array `addeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {addeds} = await bridgeManagerContract.callStatic.addBridgeOperators(\n * voteWeights,\n * governors,\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => addeds[index]);\n * const filteredWeights = weights.filter((_, index) => addeds[index]);\n * const filteredGovernors = governors.filter((_, index) => addeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function addBridgeOperators(\n uint96[] calldata voteWeights,\n address[] calldata governors,\n address[] calldata bridgeOperators\n ) external returns (bool[] memory addeds);\n\n /**\n * @dev Removes multiple bridge operators.\n * @param bridgeOperators An array of addresses representing the bridge operators to remove.\n * @return removeds An array of booleans indicating whether each bridge operator was removed successfully.\n *\n * * Note: return boolean array `removeds` indicates whether a group (voteWeight, governor, operator) are recorded.\n * It is expected that FE/BE staticcall to the function first to get the return values and handle it correctly.\n * Governors are expected to see the outcome of this function and decide if they want to vote for the proposal or not.\n *\n * Example Usage:\n * Making an `eth_call` in ethers.js\n * ```\n * const {removeds} = await bridgeManagerContract.callStatic.removeBridgeOperators(\n * bridgeOperators,\n * // overriding the caller to the contract itself since we use `onlySelfCall` guard\n * {from: bridgeManagerContract.address}\n * )\n * const filteredOperators = bridgeOperators.filter((_, index) => removeds[index]);\n * // ... (Process or use the information as required) ...\n * ```\n */\n function removeBridgeOperators(address[] calldata bridgeOperators) external returns (bool[] memory removeds);\n\n /**\n * @dev Governor updates their corresponding governor and/or operator address.\n * Requirements:\n * - The caller must the governor of the operator that is requested changes.\n * @param bridgeOperator The address of the bridge operator to update.\n */\n function updateBridgeOperator(address bridgeOperator) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\n\n/**\n * @title IBridgeManagerCallback\n * @dev Interface for the callback functions to be implemented by the Bridge Manager contract.\n */\ninterface IBridgeManagerCallback is IERC165 {\n /**\n * @dev Handles the event when bridge operators are added.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param addeds The corresponding boolean values indicating whether the operators were added or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsAdded(\n address[] memory bridgeOperators,\n bool[] memory addeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when bridge operators are removed.\n * @param bridgeOperators The addresses of the bridge operators.\n * @param removeds The corresponding boolean values indicating whether the operators were removed or not.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorsRemoved(\n address[] memory bridgeOperators,\n bool[] memory removeds\n ) external returns (bytes4 selector);\n\n /**\n * @dev Handles the event when a bridge operator is updated.\n * @param currentBridgeOperator The address of the current bridge operator.\n * @param newbridgeOperator The new address of the bridge operator.\n * @return selector The selector of the function being called.\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newbridgeOperator\n ) external returns (bytes4 selector);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeManagerCallbackRegister.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeManagerCallbackRegister {\n /**\n * @dev Emitted when the contract notifies multiple registers with statuses and return data.\n */\n event Notified(bytes callData, address[] registers, bool[] statuses, bytes[] returnDatas);\n\n /**\n * @dev Retrieves the addresses of registered callbacks.\n * @return registers An array containing the addresses of registered callbacks.\n */\n function getCallbackRegisters() external view returns (address[] memory registers);\n\n /**\n * @dev Registers multiple callbacks with the bridge.\n * @param registers The array of callback addresses to register.\n * @return registereds An array indicating the success status of each registration.\n */\n function registerCallbacks(address[] calldata registers) external returns (bool[] memory registereds);\n\n /**\n * @dev Unregisters multiple callbacks from the bridge.\n * @param registers The array of callback addresses to unregister.\n * @return unregistereds An array indicating the success status of each unregistration.\n */\n function unregisterCallbacks(address[] calldata registers) external returns (bool[] memory unregistereds);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { IBridgeRewardEvents } from \"./events/IBridgeRewardEvents.sol\";\n\ninterface IBridgeReward is IBridgeRewardEvents {\n /**\n * @dev This function allows bridge operators to manually synchronize the reward for a given period length.\n * @param periodLength The length of the reward period for which synchronization is requested.\n */\n function syncReward(uint256 periodLength) external;\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Invoke calculate and transfer reward to operators based on their performance.\n *\n * Requirements:\n * - This method is only called once each period.\n * - The caller must be the bridge tracking contract or a bridge operator.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Retrieve the total amount of rewards that have been topped up in the contract.\n * @return totalRewardToppedUp The total rewards topped up value.\n */\n function getTotalRewardToppedUp() external view returns (uint256);\n\n /**\n * @dev Retrieve the total amount of rewards that have been scattered to bridge operators in the contract.\n * @return totalRewardScattered The total rewards scattered value.\n */\n function getTotalRewardScattered() external view returns (uint256);\n\n /**\n * @dev Getter for all bridge operators per period.\n */\n function getRewardPerPeriod() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the latest rewarded period in the contract.\n * @return latestRewardedPeriod The latest rewarded period value.\n */\n function getLatestRewardedPeriod() external view returns (uint256);\n\n /**\n * @dev Setter for all bridge operators per period.\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external;\n}\n" + }, + "contracts/interfaces/bridge/IBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlashEvents } from \"./events/IBridgeSlashEvents.sol\";\n\n/**\n * @title IBridgeSlash\n * @dev Interface for the BridgeSlash contract to manage slashing functionality for bridge operators.\n */\ninterface IBridgeSlash is IBridgeSlashEvents {\n /**\n * @dev Slashes the unavailability of bridge operators during a specific period.\n * @param period The period to slash the bridge operators for.\n */\n function execSlashBridgeOperators(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external;\n\n /**\n * @dev Returns the penalize durations for the specified bridge operators.\n * @param bridgeOperators The addresses of the bridge operators.\n * @return untilPeriods The penalized periods for the bridge operators.\n */\n function getSlashUntilPeriodOf(address[] calldata bridgeOperators) external returns (uint256[] memory untilPeriods);\n\n /**\n * @dev Retrieves the added periods of the specified bridge operators.\n * @param bridgeOperators An array of bridge operator addresses.\n * @return addedPeriods An array of uint256 values representing the added periods for each bridge operator.\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods);\n\n /**\n * @dev Gets the slash tier based on the given ballot and total ballots.\n * @param ballot The ballot count for a bridge operator.\n * @param totalVote The total vote count for the period.\n * @return tier The slash tier.\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier);\n\n /**\n * @dev Retrieve the penalty durations for different slash tiers.\n * @return penaltyDurations The array of penalty durations for each slash tier.\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations);\n\n /**\n * @dev Returns the penalty duration for Tier 1 slashing.\n * @return The duration in period number for Tier 1 slashing.\n */\n function TIER_1_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the penalty duration for Tier 2 slashing.\n * @return The duration in period number for Tier 2 slashing.\n */\n function TIER_2_PENALTY_DURATION() external view returns (uint256);\n\n /**\n * @dev Returns the threshold duration for removing bridge operators.\n * @return The duration in period number that exceeds which a bridge operator will be removed.\n */\n function REMOVE_DURATION_THRESHOLD() external view returns (uint256);\n\n /**\n * @dev External function to retrieve the value of the minimum vote threshold to execute slashing rule.\n * @return minimumVoteThreshold The minimum vote threshold value.\n */\n function MINIMUM_VOTE_THRESHOLD() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/bridge/IBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridgeTracking {\n struct Request {\n VoteKind kind;\n uint256 id;\n }\n\n enum VoteKind {\n Deposit,\n Withdrawal,\n MainchainWithdrawal\n }\n\n event ExternalCallFailed(address indexed to, bytes4 indexed msgSig, bytes reason);\n\n /**\n * @dev Returns the block that allow incomming mutable call.\n */\n function startedAtBlock() external view returns (uint256);\n\n /**\n * @dev Returns the total number of votes at the specific period `_period`.\n */\n function totalVote(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots at the specific period `_period`.\n */\n function totalBallot(uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the total number of ballots of bridge operators at the specific period `_period`.\n */\n function getManyTotalBallots(\n uint256 _period,\n address[] calldata _bridgeOperators\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total number of ballots of a bridge operator at the specific period `_period`.\n */\n function totalBallotOf(uint256 _period, address _bridgeOperator) external view returns (uint256);\n\n /**\n * @dev Handles the request once it is approved.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function handleVoteApproved(VoteKind _kind, uint256 _requestId) external;\n\n /**\n * @dev Records vote for a receipt and a operator.\n *\n * Requirements:\n * - The method caller is the bridge contract.\n *\n */\n function recordVote(VoteKind _kind, uint256 _requestId, address _operator) external;\n}\n" + }, + "contracts/interfaces/collections/IHasContracts.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { ContractType } from \"../../utils/ContractType.sol\";\n\ninterface IHasContracts {\n /// @dev Error of invalid role.\n error ErrContractTypeNotFound(ContractType contractType);\n\n /// @dev Emitted when a contract is updated.\n event ContractUpdated(ContractType indexed contractType, address indexed addr);\n\n /**\n * @dev Returns the address of a contract with a specific role.\n * Throws an error if no contract is set for the specified role.\n *\n * @param contractType The role of the contract to retrieve.\n * @return contract_ The address of the contract with the specified role.\n */\n function getContract(ContractType contractType) external view returns (address contract_);\n\n /**\n * @dev Sets the address of a contract with a specific role.\n * Emits the event {ContractUpdated}.\n * @param contractType The role of the contract to set.\n * @param addr The address of the contract to set.\n */\n function setContract(ContractType contractType, address addr) external;\n}\n" + }, + "contracts/interfaces/consumers/ChainTypeConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ChainTypeConsumer {\n enum ChainType {\n RoninChain,\n Mainchain\n }\n}\n" + }, + "contracts/interfaces/consumers/MappedTokenConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../libraries/Token.sol\";\n\ninterface MappedTokenConsumer {\n struct MappedToken {\n Token.Standard erc;\n address tokenAddr;\n }\n}\n" + }, + "contracts/interfaces/consumers/PeriodWrapperConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface PeriodWrapperConsumer {\n struct PeriodWrapper {\n // Inner value.\n uint256 inner;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n}\n" + }, + "contracts/interfaces/consumers/SignatureConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface SignatureConsumer {\n struct Signature {\n uint8 v;\n bytes32 r;\n bytes32 s;\n }\n}\n" + }, + "contracts/interfaces/consumers/VoteStatusConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface VoteStatusConsumer {\n enum VoteStatus {\n Pending,\n Approved,\n Executed,\n Rejected,\n Expired\n }\n}\n" + }, + "contracts/interfaces/consumers/WeightedAddressConsumer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface WeightedAddressConsumer {\n struct WeightedAddress {\n address addr;\n uint256 weight;\n }\n}\n" + }, + "contracts/interfaces/IBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IBridge {\n /**\n * @dev Replaces the old bridge operator list by the new one.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emitted the event `BridgeOperatorsReplaced`.\n *\n */\n function replaceBridgeOperators(address[] calldata) external;\n\n /**\n * @dev Returns the bridge operator list.\n */\n function getBridgeOperators() external view returns (address[] memory);\n}\n" + }, + "contracts/interfaces/IBridgeAdminProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { BridgeOperatorsBallot } from \"../libraries/BridgeOperatorsBallot.sol\";\n\ninterface IBridgeAdminProposal {\n /// @dev Emitted when the bridge operators are approved.\n event BridgeOperatorsApproved(uint256 period, uint256 epoch, address[] operators);\n\n /**\n * @dev Returns the last voted block of the bridge voter.\n */\n function lastVotedBlock(address bridgeVoter) external view returns (uint256);\n\n /**\n * @dev Returns the synced bridge operator set info.\n */\n function lastSyncedBridgeOperatorSetInfo()\n external\n view\n returns (BridgeOperatorsBallot.BridgeOperatorSet memory bridgeOperatorSetInfo);\n}\n" + }, + "contracts/interfaces/IERC20Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.2;\n\ninterface IERC20Mintable {\n function mint(address _to, uint256 _value) external returns (bool _success);\n}\n" + }, + "contracts/interfaces/IERC721Mintable.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IERC721Mintable {\n function mint(address _to, uint256 _tokenId) external returns (bool);\n}\n" + }, + "contracts/interfaces/IFastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IFastFinalityTracking {\n /**\n * @dev Submit list of `voters` who vote for fast finality in the current block.\n *\n * Requirements:\n * - Only called once per block\n * - Only coinbase can call this method\n */\n function recordFinality(address[] calldata voters) external;\n\n /**\n * @dev Returns vote count of `addrs` in the `period`.\n */\n function getManyFinalityVoteCounts(\n uint256 period,\n address[] calldata addrs\n ) external view returns (uint256[] memory voteCounts);\n}\n" + }, + "contracts/interfaces/IMainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./IWETH.sol\";\nimport \"./consumers/SignatureConsumer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\nimport \"../libraries/Transfer.sol\";\n\ninterface IMainchainGatewayV3 is SignatureConsumer, MappedTokenConsumer {\n /**\n * @dev Error indicating that a query was made for an approved withdrawal.\n */\n error ErrQueryForApprovedWithdrawal();\n\n /**\n * @dev Error indicating that the daily withdrawal limit has been reached.\n */\n error ErrReachedDailyWithdrawalLimit();\n\n /**\n * @dev Error indicating that a query was made for a processed withdrawal.\n */\n error ErrQueryForProcessedWithdrawal();\n\n /**\n * @dev Error indicating that a query was made for insufficient vote weight.\n */\n error ErrQueryForInsufficientVoteWeight();\n\n /// @dev Emitted when the deposit is requested\n event DepositRequested(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the assets are withdrawn\n event Withdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] mainchainTokens, address[] roninTokens, Token.Standard[] standards);\n /// @dev Emitted when the wrapped native token contract is updated\n event WrappedNativeTokenContractUpdated(IWETH weth);\n /// @dev Emitted when the withdrawal is locked\n event WithdrawalLocked(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is unlocked\n event WithdrawalUnlocked(bytes32 receiptHash, Transfer.Receipt receipt);\n\n /**\n * @dev Returns the domain seperator.\n */\n function DOMAIN_SEPARATOR() external view returns (bytes32);\n\n /**\n * @dev Returns deposit count.\n */\n function depositCount() external view returns (uint256);\n\n /**\n * @dev Sets the wrapped native token contract.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external;\n\n /**\n * @dev Returns whether the withdrawal is locked.\n */\n function withdrawalLocked(uint256 withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns the withdrawal hash.\n */\n function withdrawalHash(uint256 withdrawalId) external view returns (bytes32);\n\n /**\n * @dev Locks the assets and request deposit.\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable;\n\n /**\n * @dev Withdraws based on the receipt and the validator signatures.\n * Returns whether the withdrawal is locked.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function submitWithdrawal(\n Transfer.Receipt memory _receipt,\n Signature[] memory _signatures\n ) external returns (bool _locked);\n\n /**\n * @dev Approves a specific withdrawal.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Maps mainchain tokens to Ronin network and sets thresholds.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n uint256[][4] calldata _thresholds\n ) external;\n\n /**\n * @dev Returns token address on Ronin network.\n * Note: Reverts for unsupported token.\n */\n function getRoninToken(address _mainchainToken) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IMaintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IMaintenance {\n /**\n * @dev Error thrown when attempting to schedule an already scheduled event.\n */\n error ErrAlreadyScheduled();\n\n /**\n * @dev Error thrown when referring to a non-existent schedule.\n */\n error ErrUnexistedSchedule();\n\n /**\n * @dev Error thrown when the end block of a schedule is out of range.\n */\n error ErrEndBlockOutOfRange();\n\n /**\n * @dev Error thrown when the start block of a schedule is out of range.\n */\n error ErrStartBlockOutOfRange();\n\n /**\n * @dev Error thrown when attempting to initiate maintenance while already in maintenance mode.\n */\n error ErrAlreadyOnMaintenance();\n\n /**\n * @dev Error thrown when attempting an action before the cooldown period has ended.\n */\n error ErrCooldownTimeNotYetEnded();\n\n /**\n * @dev Error thrown when the total number of schedules exceeds the limit.\n */\n error ErrTotalOfSchedulesExceeded();\n\n /**\n * @dev Error thrown when an invalid maintenance duration is specified.\n */\n error ErrInvalidMaintenanceDuration();\n\n /**\n * @dev Error thrown when an invalid maintenance duration configuration is provided.\n */\n error ErrInvalidMaintenanceDurationConfig();\n\n /**\n * @dev Error thrown when an invalid offset is specified to start the schedule configurations.\n */\n error ErrInvalidOffsetToStartScheduleConfigs();\n\n struct Schedule {\n uint256 from;\n uint256 to;\n uint256 lastUpdatedBlock;\n uint256 requestTimestamp;\n }\n\n /// @dev Emitted when a maintenance is scheduled.\n event MaintenanceScheduled(address indexed consensusAddr, Schedule);\n /// @dev Emitted when a schedule of maintenance is cancelled.\n event MaintenanceScheduleCancelled(address indexed consensusAddr);\n /// @dev Emitted when the maintenance config is updated.\n event MaintenanceConfigUpdated(\n uint256 minMaintenanceDurationInBlock,\n uint256 maxMaintenanceDurationInBlock,\n uint256 minOffsetToStartSchedule,\n uint256 maxOffsetToStartSchedule,\n uint256 maxSchedules,\n uint256 cooldownSecsToMaintain\n );\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained at the block number `_block`.\n */\n function checkMaintained(address _consensusAddr, uint256 _block) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks.\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool);\n\n /**\n * @dev Returns the bool array indicating the validators maintained at block number `_block` or not.\n */\n function checkManyMaintained(address[] calldata _addrList, uint256 _block) external view returns (bool[] memory);\n\n /**\n * @dev Returns a bool array indicating the validators maintained in the inclusive range [`_fromBlock`, `_toBlock`] of blocks or not.\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the validator `_consensusAddr` has scheduled.\n */\n function checkScheduled(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns whether the validator `_consensusAddr`\n */\n function checkCooldownEnded(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns the detailed schedule of the validator `_consensusAddr`.\n */\n function getSchedule(address _consensusAddr) external view returns (Schedule memory);\n\n /**\n * @dev Returns the total of current schedules.\n */\n function totalSchedule() external view returns (uint256 _count);\n\n /**\n * @dev Sets the duration restriction, start time restriction, and max allowed for maintenance.\n *\n * Requirements:\n * - The method caller is admin.\n * - The max duration is larger than the min duration.\n * - The max offset is larger than the min offset.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external;\n\n /**\n * @dev Returns the min duration for maintenance in block.\n */\n function minMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev Returns the max duration for maintenance in block.\n */\n function maxMaintenanceDurationInBlock() external view returns (uint256);\n\n /**\n * @dev The offset to the min block number that the schedule can start\n */\n function minOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev The offset to the max block number that the schedule can start\n */\n function maxOffsetToStartSchedule() external view returns (uint256);\n\n /**\n * @dev Returns the max number of scheduled maintenances.\n */\n function maxSchedule() external view returns (uint256);\n\n /**\n * @dev Schedules for maintenance from `_startedAtBlock` to `_startedAtBlock`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - The candidate `_consensusAddr` has no schedule yet or the previous is done.\n * - The total number of schedules is not larger than `maxSchedules()`.\n * - The start block must be at least `minOffsetToStartSchedule()` and at most `maxOffsetToStartSchedule()` blocks from the current block.\n * - The end block is larger than the start block.\n * - The scheduled duration is larger than the `minMaintenanceDurationInBlock()` and less than the `maxMaintenanceDurationInBlock()`.\n * - The start block is at the start of an epoch.\n * - The end block is at the end of an epoch.\n *\n * Emits the event `MaintenanceScheduled`.\n *\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external;\n\n /**\n * @dev Cancel the schedule of maintenance for the `_consensusAddr`.\n *\n * Requirements:\n * - The candidate `_consensusAddr` is the block producer.\n * - The method caller is candidate admin of the candidate `_consensusAddr`.\n * - A schedule for the `_consensusAddr` must be existent and not executed yet.\n *\n * Emits the event `MaintenanceScheduleCancelled`.\n */\n function cancelSchedule(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/IPauseTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IPauseTarget {\n function pause() external;\n\n function unpause() external;\n\n function paused() external returns (bool);\n}\n" + }, + "contracts/interfaces/IProfile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../utils/RoleAccess.sol\";\n\ninterface IProfile {\n struct CandidateProfile {\n /**\n * @dev Primary key of the profile, use for backward querying.\n *\n * {Staking} Contract: index of pool\n * {RoninValidatorSet} Contract: index of almost all data related to a validator\n *\n */\n address id;\n /// @dev Consensus address.\n address consensus;\n /// @dev Pool admin address.\n address admin;\n /// @dev Treasury address.\n address payable treasury;\n /// @dev Address to voting proposal.\n address governor;\n /// @dev Public key for fast finality.\n bytes pubkey;\n }\n\n /// @dev Event emitted when a profile with `id` is added.\n event ProfileAdded(address indexed id);\n /// @dev Event emitted when a address in a profile is changed.\n event ProfileAddressChanged(address indexed id, RoleAccess indexed addressType);\n /// @dev Event emitted when the pubkey of the `id` is changed.\n event PubkeyChanged(address indexed id, bytes pubkey);\n\n /// @dev Error of already existed profile.\n error ErrExistentProfile();\n /// @dev Error of non existed profile.\n error ErrNonExistentProfile();\n /// @dev Error when create a new profile whose id and consensus are not identical.\n error ErrIdAndConsensusDiffer();\n /**\n * @dev Error when there is a duplicated info of `value`, which is uin256-padding value of any address or hash of public key,\n * and with value type of `infoType`.\n */\n error ErrDuplicatedInfo(RoleAccess infoType, uint256 value);\n error ErrDuplicatedPubkey(bytes pubkey);\n error ErrZeroAddress(RoleAccess infoType);\n error ErrZeroPubkey();\n\n /// @dev Getter to query full `profile` from `id` address.\n function getId2Profile(address id) external view returns (CandidateProfile memory profile);\n\n /**\n * @notice Add a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only contract admin can call this method.\n */\n function addNewProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin registers a new profile.\n *\n * @dev Requirements:\n * - The profile must not be existent before.\n * - Only user with candidate admin role can call this method.\n */\n\n function registerProfile(CandidateProfile memory profile) external;\n\n /**\n * @notice The candidate admin changes the public key.\n *\n * @dev Requirements:\n * - The profile must be existed.\n * - Only user with candidate admin role can call this method.\n * - New public key must not be duplicated.\n */\n\n function changePubkey(address id, bytes memory pubkey) external;\n}\n" + }, + "contracts/interfaces/IQuorum.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IQuorum {\n /// @dev Emitted when the threshold is updated\n event ThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n\n /**\n * @dev Returns the threshold.\n */\n function getThreshold() external view returns (uint256 _num, uint256 _denom);\n\n /**\n * @dev Checks whether the `_voteWeight` passes the threshold.\n */\n function checkThreshold(uint256 _voteWeight) external view returns (bool);\n\n /**\n * @dev Returns the minimum vote weight to pass the threshold.\n */\n function minimumVoteWeight() external view returns (uint256);\n\n /**\n * @dev Sets the threshold.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external returns (uint256 _previousNum, uint256 _previousDenom);\n}\n" + }, + "contracts/interfaces/IRoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../libraries/Transfer.sol\";\nimport \"./consumers/MappedTokenConsumer.sol\";\n\ninterface IRoninGatewayV3 is MappedTokenConsumer {\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been migrated.\n */\n error ErrWithdrawalsMigrated();\n\n /**\n * @dev Error thrown when an invalid trusted threshold is specified.\n */\n error ErrInvalidTrustedThreshold();\n\n /**\n * @dev Error thrown when attempting to withdraw funds that have already been withdrawn on the mainchain.\n */\n error ErrWithdrawnOnMainchainAlready();\n\n /// @dev Emitted when the assets are depositted\n event Deposited(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal is requested\n event WithdrawalRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the assets are withdrawn on mainchain\n event MainchainWithdrew(bytes32 receiptHash, Transfer.Receipt receipt);\n /// @dev Emitted when the withdrawal signatures is requested\n event WithdrawalSignaturesRequested(bytes32 receiptHash, Transfer.Receipt);\n /// @dev Emitted when the tokens are mapped\n event TokenMapped(address[] roninTokens, address[] mainchainTokens, uint256[] chainIds, Token.Standard[] standards);\n /// @dev Emitted when the threshold is updated\n event TrustedThresholdUpdated(\n uint256 indexed nonce,\n uint256 indexed numerator,\n uint256 indexed denominator,\n uint256 previousNumerator,\n uint256 previousDenominator\n );\n /// @dev Emitted when a deposit is voted\n event DepositVoted(address indexed bridgeOperator, uint256 indexed id, uint256 indexed chainId, bytes32 receiptHash);\n\n /**\n * @dev Returns withdrawal count.\n */\n function withdrawalCount() external view returns (uint256);\n\n /**\n * @dev Returns withdrawal signatures.\n */\n function getWithdrawalSignatures(\n uint256 _withdrawalId,\n address[] calldata _validators\n ) external view returns (bytes[] memory);\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call passes the quorum threshold.\n *\n */\n function depositFor(Transfer.Receipt calldata _receipt) external;\n\n /**\n * @dev Marks the withdrawals are done on mainchain and returns the boolean array indicating whether the withdrawal\n * vote is already done before.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `MainchainWithdrew` once the valid call passes the quorum threshold.\n *\n * @notice Not reverting to avoid unnecessary failed transactions because the validators can send transactions at the\n * same time.\n *\n */\n function tryBulkAcknowledgeMainchainWithdrew(uint256[] calldata _withdrawalIds) external returns (bool[] memory);\n\n /**\n * @dev Tries bulk deposits based on the receipts and returns the boolean array indicating whether the deposit vote\n * is already done before. Reverts if the deposit is invalid or is voted by the validator again.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n * Emits the `Deposited` once the assets are released.\n *\n * @notice The assets will be transferred whenever the valid call for the receipt passes the quorum threshold. Not\n * reverting to avoid unnecessary failed transactions because the validators can send transactions at the same time.\n *\n */\n function tryBulkDepositFor(Transfer.Receipt[] calldata _receipts) external returns (bool[] memory);\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external;\n\n /**\n * @dev Bulk requests withdrawals.\n *\n * Emits the `WithdrawalRequested` events.\n *\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external;\n\n /**\n * @dev Requests withdrawal signatures for a specific withdrawal.\n *\n * Emits the `WithdrawalSignaturesRequested` event.\n *\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external;\n\n /**\n * @dev Submits withdrawal signatures.\n *\n * Requirements:\n * - The method caller is a validator.\n *\n */\n function bulkSubmitWithdrawalSignatures(uint256[] calldata _withdrawals, bytes[] calldata _signatures) external;\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The method caller is admin.\n * - The arrays have the same length and its length larger than 0.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata chainIds,\n Token.Standard[] calldata _standards\n ) external;\n\n /**\n * @dev Returns whether the deposit is casted by the voter.\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the mainchain withdrew is casted by the voter.\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool);\n\n /**\n * @dev Returns whether the withdrawal is done on mainchain.\n */\n function mainchainWithdrew(uint256 _withdrawalId) external view returns (bool);\n\n /**\n * @dev Returns mainchain token address.\n * Reverts for unsupported token.\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) external view returns (MappedToken memory _token);\n}\n" + }, + "contracts/interfaces/IRoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../utils/CommonErrors.sol\";\n\ninterface IRoninGovernanceAdmin {\n /// @dev Emitted when an emergency exit poll is created.\n event EmergencyExitPollCreated(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n );\n /// @dev Emitted when an emergency exit poll is approved.\n event EmergencyExitPollApproved(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is expired.\n event EmergencyExitPollExpired(bytes32 _voteHash);\n /// @dev Emitted when an emergency exit poll is voted.\n event EmergencyExitPollVoted(bytes32 indexed _voteHash, address indexed _voter);\n\n /**\n * @dev Create a vote to agree that an emergency exit is valid and should return the locked funds back.a\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external;\n}\n" + }, + "contracts/interfaces/IRoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IQuorum.sol\";\n\ninterface IRoninTrustedOrganization is IQuorum {\n /**\n * @dev Error indicating that a query for a duplicate entry was made.\n */\n error ErrQueryForDupplicated();\n\n /**\n * @dev Error indicating that a query was made for a non-existent consensus address.\n */\n error ErrQueryForNonExistentConsensusAddress();\n\n /**\n * @dev Error indicating that a bridge voter has already been added.\n * @param voter The address of the bridge voter that is already added.\n */\n error ErrBridgeVoterIsAlreadyAdded(address voter);\n\n /**\n * @dev Error indicating that a governor address has already been added.\n * @param addr The address of the governor that is already added.\n */\n error ErrGovernorAddressIsAlreadyAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is not added.\n * @param addr The address of the consensus contract that is not added.\n */\n error ErrConsensusAddressIsNotAdded(address addr);\n\n /**\n * @dev Error indicating that a consensus address is already added.\n * @param addr The address of the consensus contract that is already added.\n */\n error ErrConsensusAddressIsAlreadyAdded(address addr);\n\n struct TrustedOrganization {\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address to voting proposal\n address governor;\n // Address to voting bridge operators\n address bridgeVoter;\n // Its Weight\n uint256 weight;\n // The block that the organization was added\n uint256 addedBlock;\n }\n\n /// @dev Emitted when the trusted organization is added.\n event TrustedOrganizationsAdded(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is updated.\n event TrustedOrganizationsUpdated(TrustedOrganization[] orgs);\n /// @dev Emitted when the trusted organization is removed.\n event TrustedOrganizationsRemoved(address[] orgs);\n\n /**\n * @dev Adds a list of addresses into the trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n * - The field `addedBlock` should be blank.\n *\n * Emits the event `TrustedOrganizationAdded` once an organization is added.\n *\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata) external;\n\n /**\n * @dev Updates weights for a list of existent trusted organization.\n *\n * Requirements:\n * - The weights should larger than 0.\n * - The method caller is admin.\n *\n * Emits the `TrustedOrganizationUpdated` event.\n *\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external;\n\n /**\n * @dev Removes a list of addresses from the trusted organization.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `TrustedOrganizationRemoved` once an organization is removed.\n *\n * @param _consensusAddrs The list of consensus addresses linked to corresponding trusted organization that to be removed.\n */\n function removeTrustedOrganizations(address[] calldata _consensusAddrs) external;\n\n /**\n * @dev Returns total weights.\n */\n function totalWeight() external view returns (uint256);\n\n /**\n * @dev Returns the weight of a consensus.\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a governor.\n */\n function getGovernorWeight(address _governor) external view returns (uint256);\n\n /**\n * @dev Returns the weight of a bridge voter.\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256);\n\n /**\n * @dev Returns the weights of a list of consensus addresses.\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of governor addresses.\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the weights of a list of bridge voter addresses.\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory);\n\n /**\n * @dev Returns total weights of the consensus list.\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the governor list.\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns total weights of the bridge voter list.\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res);\n\n /**\n * @dev Returns the trusted organization at `_index`.\n */\n function getTrustedOrganizationAt(uint256 _index) external view returns (TrustedOrganization memory);\n\n /**\n * @dev Returns the number of trusted organizations.\n */\n function countTrustedOrganization() external view returns (uint256);\n\n /**\n * @dev Returns all of the trusted organizations.\n */\n function getAllTrustedOrganizations() external view returns (TrustedOrganization[] memory);\n\n /**\n * @dev Returns the trusted organization by consensus address.\n *\n * Reverts once the consensus address is non-existent.\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory);\n}\n" + }, + "contracts/interfaces/IStakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IStakingVesting {\n /**\n * @dev Error thrown when attempting to send a bonus that has already been sent.\n */\n error ErrBonusAlreadySent();\n\n /// @dev Emitted when the block bonus for block producer is transferred.\n event BonusTransferred(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount\n );\n /// @dev Emitted when the transfer of block bonus for block producer is failed.\n event BonusTransferFailed(\n uint256 indexed blockNumber,\n address indexed recipient,\n uint256 blockProducerAmount,\n uint256 bridgeOperatorAmount,\n uint256 contractBalance\n );\n /// @dev Emitted when the block bonus for block producer is updated\n event BlockProducerBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the block bonus for bridge operator is updated\n event BridgeOperatorBonusPerBlockUpdated(uint256);\n /// @dev Emitted when the percent of fast finality reward is updated\n event FastFinalityRewardPercentageUpdated(uint256);\n\n /**\n * @dev Returns the bonus amount for the block producer at `_block`.\n */\n function blockProducerBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the bonus amount for the bridge validator at `_block`.\n */\n function bridgeOperatorBlockBonus(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns the percentage of fast finality reward.\n */\n function fastFinalityRewardPercentage() external view returns (uint256);\n\n /**\n * @dev Receives RON from any address.\n */\n function receiveRON() external payable;\n\n /**\n * @dev Returns the last block number that the staking vesting is sent.\n */\n function lastBlockSendingBonus() external view returns (uint256);\n\n /**\n * @dev Transfers the staking vesting for the block producer and the bridge operator whenever a new block is mined.\n *\n * Requirements:\n * - The method caller must be validator contract.\n * - The method must be called only once per block.\n *\n * Emits the event `BonusTransferred` or `BonusTransferFailed`.\n *\n * Notes:\n * - The method does not revert when the contract balance is insufficient to send bonus. This assure the submit reward method\n * will not be reverted, and the underlying nodes does not hang.\n *\n * @param forBlockProducer Indicates whether requesting the bonus for the block procucer, in case of being in jail or relevance.\n * @param forBridgeOperator Indicates whether requesting the bonus for the bridge operator.\n *\n * @return success Whether the transfer is successfully. This returns false mostly because this contract is out of balance.\n * @return blockProducerBonus The amount of bonus actually sent for the block producer, returns 0 when the transfer is failed.\n * @return bridgeOperatorBonus The amount of bonus actually sent for the bridge operator, returns 0 when the transfer is failed.\n * @return fastFinalityRewardPercentage The percent of fast finality reward, returns 0 when the transfer is failed.\n *\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n returns (\n bool success,\n uint256 blockProducerBonus,\n uint256 bridgeOperatorBonus,\n uint256 fastFinalityRewardPercentage\n );\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external;\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n * Requirements:\n * - The method caller is admin.\n *\n */\n function setFastFinalityRewardPercentage(uint256 _percent) external;\n}\n" + }, + "contracts/interfaces/IWETH.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IWETH {\n function deposit() external payable;\n\n function withdraw(uint256 _wad) external;\n\n function balanceOf(address) external view returns (uint256);\n}\n" + }, + "contracts/interfaces/slash-indicator/IBaseSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseSlash {\n enum SlashType {\n UNKNOWN,\n UNAVAILABILITY_TIER_1,\n UNAVAILABILITY_TIER_2,\n DOUBLE_SIGNING,\n BRIDGE_VOTING,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_1,\n BRIDGE_OPERATOR_MISSING_VOTE_TIER_2,\n UNAVAILABILITY_TIER_3,\n FAST_FINALITY\n }\n\n /// @dev Error thrown when evidence has already been submitted.\n error ErrEvidenceAlreadySubmitted();\n\n /// @dev Emitted when the validator is slashed.\n event Slashed(address indexed validator, SlashType slashType, uint256 period);\n}\n" + }, + "contracts/interfaces/slash-indicator/ICreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICreditScore {\n /**\n * @dev Error thrown when an invalid credit score configuration is provided.\n */\n error ErrInvalidCreditScoreConfig();\n\n /**\n * @dev Error thrown when an invalid cut-off percentage configuration is provided.\n */\n error ErrInvalidCutOffPercentageConfig();\n\n /**\n * @dev Error thrown when the caller's credit score is insufficient to bail out a situation.\n */\n error ErrInsufficientCreditScoreToBailOut();\n\n /**\n * @dev Error thrown when a validator has previously bailed out.\n */\n error ErrValidatorHasBailedOutPreviously();\n\n /**\n * @dev Error thrown when the caller must be jailed in the current period.\n */\n error ErrCallerMustBeJailedInTheCurrentPeriod();\n\n /// @dev Emitted when the configs to credit score is updated. See the method `setCreditScoreConfigs` for param details.\n event CreditScoreConfigsUpdated(\n uint256 gainCreditScore,\n uint256 maxCreditScore,\n uint256 bailOutCostMultiplier,\n uint256 cutOffPercentageAfterBailout\n );\n /// @dev Emitted the credit score of validators is updated.\n event CreditScoresUpdated(address[] validators, uint256[] creditScores);\n /// @dev Emitted when a validator bailed out of jail.\n event BailedOut(address indexed validator, uint256 period, uint256 usedCreditScore);\n\n /**\n * @dev Updates the credit score for the validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function updateCreditScores(address[] calldata _validators, uint256 _period) external;\n\n /**\n * @dev Resets the credit score for the revoked validators.\n *\n * Requirements:\n * - Only validator contract can call this method.\n * - This method is only called at the end of each period.\n *\n * Emits the event `CreditScoresUpdated`.\n *\n */\n function execResetCreditScores(address[] calldata _validators) external;\n\n /**\n * @dev A slashed validator use this method to get out of jail.\n *\n * Requirements:\n * - The `_consensusAddr` must be a validator.\n * - Only validator's admin can call this method.\n *\n * Emits the event `BailedOut`.\n *\n */\n function bailOut(address _consensusAddr) external;\n\n /**\n * @dev Sets the configs to credit score.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CreditScoreConfigsUpdated`.\n *\n * @param _gainScore The score to gain per period.\n * @param _maxScore The max number of credit score that a validator can hold.\n * @param _bailOutMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @param _cutOffPercentage The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external;\n\n /**\n * @dev Returns the configs related to credit score.\n *\n * @return _gainCreditScore The score to gain per period.\n * @return _maxCreditScore The max number of credit score that a validator can hold.\n * @return _bailOutCostMultiplier The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n * @return _cutOffPercentageAfterBailout The percentage of reward that the block producer will be cut off from until the end of the period after bailing out.\n *\n */\n function getCreditScoreConfigs()\n external\n view\n returns (\n uint256 _gainCreditScore,\n uint256 _maxCreditScore,\n uint256 _bailOutCostMultiplier,\n uint256 _cutOffPercentageAfterBailout\n );\n\n /**\n * @dev Returns the current credit score of the validator.\n */\n function getCreditScore(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the current credit score of a list of validators.\n */\n function getManyCreditScores(address[] calldata _validators) external view returns (uint256[] memory _resultList);\n\n /**\n * @dev Returns the whether the `_validator` has been bailed out at the `_period`.\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeOperator is IBaseSlash {\n /**\n * @dev Error thrown when invalid ratios are provided.\n */\n error ErrInvalidRatios();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method\n * `getBridgeOperatorSlashingConfigs` for param details.\n */\n event BridgeOperatorSlashingConfigsUpdated(\n uint256 missingVotesRatioTier1,\n uint256 missingVotesRatioTier2,\n uint256 jailDurationForMissingVotesRatioTier2,\n uint256 skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Acknowledges bridge operator slash and emit `Slashed` event correspondingly.\n * @param _tier The tier of the slash, in value of {1, 2}, corresponding to `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1`\n * and `SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2`\n *\n * Requirements:\n * - Only validator contract can invoke this method.\n * - Should be called only at the end of period.\n * - Should be called only when there is slash of bridge operator.\n *\n * Emits the event `Slashed`.\n */\n function execSlashBridgeOperator(address _consensusAddr, uint256 _tier, uint256 _period) external;\n\n /**\n * @dev Returns the configs related to bridge operator slashing.\n *\n * @return _missingVotesRatioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio.\n * @return _missingVotesRatioTier2 The bridge reward and mining reward will be deprecated and the corresponding\n * block producer will be put in jail if (s)he misses more than this ratio.\n * @return _jailDurationForMissingVotesRatioTier2 The number of blocks to jail the corresponding block producer when\n * its bridge operator is slashed tier-2.\n * @return _skipBridgeOperatorSlashingThreshold The threshold to skip slashing the bridge operator in case the total\n * number of votes in the bridge is too small.\n *\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n returns (\n uint256 _missingVotesRatioTier1,\n uint256 _missingVotesRatioTier2,\n uint256 _jailDurationForMissingVotesRatioTier2,\n uint256 _skipBridgeOperatorSlashingThreshold\n );\n\n /**\n * @dev Sets the configs to slash bridge operators.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _ratioTier1 The bridge reward will be deprecated if (s)he missed more than this ratio. Values 0-10,000 map\n * to 0%-100%.\n * @param _ratioTier2 The bridge reward and mining reward will be deprecated and the corresponding block producer will\n * be put in jail if (s)he misses more than this ratio. Values 0-10,000 map to 0%-100%.\n * @param _jailDurationTier2 The number of blocks to jail the corresponding block producer when its bridge operator is\n * slashed tier-2.\n * @param _skipSlashingThreshold The threshold to skip slashing the bridge operator in case the total number of votes\n * in the bridge is too small.\n *\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashBridgeVoting is IBaseSlash {\n /**\n * @dev Error thrown when an invalid slash is encountered.\n */\n error ErrInvalidSlash();\n\n /**\n * @dev Emitted when the configs to slash bridge voting is updated. See the method `getBridgeVotingSlashingConfigs` for param\n * details.\n */\n event BridgeVotingSlashingConfigsUpdated(uint256 bridgeVotingThreshold, uint256 bridgeVotingSlashAmount);\n\n /**\n * @dev Slashes for bridge voter governance.\n *\n * Emits the event `Slashed`.\n */\n function slashBridgeVoting(address _consensusAddr) external;\n\n /**\n * @dev Returns the configs related to bridge voting slashing.\n *\n * @return _bridgeVotingThreshold The threshold to slash when a trusted organization does not vote for bridge\n * operators.\n * @return _bridgeVotingSlashAmount The amount of RON to slash bridge voting.\n *\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n returns (uint256 _bridgeVotingThreshold, uint256 _bridgeVotingSlashAmount);\n\n /**\n * @dev Sets the configs to slash bridge voting.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeVotingSlashingConfigsUpdated`.\n *\n * @param _threshold The threshold to slash when a trusted organization does not vote for bridge operators.\n * @param _slashAmount The amount of RON to slash bridge voting.\n *\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashDoubleSign is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash double sign is updated. See the method `getDoubleSignSlashingConfigs`\n * for param details.\n */\n event DoubleSignSlashingConfigsUpdated(\n uint256 slashDoubleSignAmount,\n uint256 doubleSigningJailUntilBlock,\n uint256 doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Slashes for double signing.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` if the double signing evidence of the two headers valid.\n */\n function slashDoubleSign(address _validatorAddr, bytes calldata _header1, bytes calldata _header2) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _slashDoubleSignAmount The amount of RON to slash double sign.\n * @return _doubleSigningJailUntilBlock The block number that the punished validator will be jailed until, due to\n * double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n returns (\n uint256 _slashDoubleSignAmount,\n uint256 _doubleSigningJailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `DoubleSignSlashingConfigsUpdated`.\n *\n * @param _slashAmount The amount of RON to slash double sign.\n * @param _jailUntilBlock The block number that the punished validator will be jailed until, due to double signing.\n * @param _doubleSigningOffsetLimitBlock The number of block that the current block is at most far from the double\n * signing block.\n *\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _doubleSigningOffsetLimitBlock\n ) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashFastFinality is IBaseSlash {\n /**\n * @dev Emitted when the configs to slash fast finality is updated. See the method `getFastFinalitySlashingConfigs`\n * for param details.\n */\n event FastFinalitySlashingConfigsUpdated(uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Slashes for fast finality.\n *\n * Requirements:\n * - Only whitelisted addresses are allowed to call.\n *\n * Emits the event `Slashed` if the fast finality evidence of the two headers valid.\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external;\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return slashFastFinalityAmount The amount of RON to slash fast finality.\n * @return fastFinalityJailUntilBlock The block number that the punished validator will be jailed until, due to\n * malicious fast finality.\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n returns (uint256 slashFastFinalityAmount, uint256 fastFinalityJailUntilBlock);\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `FastFinalitySlashingConfigsUpdated`.\n *\n * @param slashAmount The amount of RON to slash fast finality.\n * @param jailUntilBlock The block number that the punished validator will be jailed until, due to fast finality.\n *\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external;\n}\n" + }, + "contracts/interfaces/slash-indicator/ISlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashDoubleSign.sol\";\nimport \"./ISlashBridgeVoting.sol\";\nimport \"./ISlashBridgeOperator.sol\";\nimport \"./ISlashUnavailability.sol\";\nimport \"./ICreditScore.sol\";\n\ninterface ISlashIndicator is\n ISlashDoubleSign,\n ISlashBridgeVoting,\n ISlashBridgeOperator,\n ISlashUnavailability,\n ICreditScore\n{}\n" + }, + "contracts/interfaces/slash-indicator/ISlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseSlash.sol\";\n\ninterface ISlashUnavailability is IBaseSlash {\n /**\n * @dev Error thrown when attempting to slash a validator twice or slash more than one validator in one block.\n */\n error ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n\n /**\n * @dev Emitted when the configs to slash bridge operator is updated. See the method `getUnavailabilitySlashingConfigs`\n * for param details.\n */\n event UnavailabilitySlashingConfigsUpdated(\n uint256 unavailabilityTier1Threshold,\n uint256 unavailabilityTier2Threshold,\n uint256 slashAmountForUnavailabilityTier2Threshold,\n uint256 jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Returns the last block that a block producer is slashed for unavailability.\n */\n function lastUnavailabilitySlashedBlock() external view returns (uint256);\n\n /**\n * @dev Slashes for unavailability by increasing the counter of block producer `_consensusAddr`.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `Slashed` when the threshold is reached.\n *\n */\n function slashUnavailability(address _consensusAddr) external;\n\n /**\n * @dev Returns the current unavailability indicator of a block producer.\n */\n function currentUnavailabilityIndicator(address _validator) external view returns (uint256);\n\n /**\n * @dev Returns the unavailability indicator in the period `_period` of a block producer.\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) external view returns (uint256);\n\n /**\n * @dev Returns the configs related to block producer slashing.\n *\n * @return _unavailabilityTier1Threshold The mining reward will be deprecated, if (s)he missed more than this\n * threshold. This threshold is applied for tier-1 and tier-3 slash.\n * @return _unavailabilityTier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will\n * be deducted self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n * @return _slashAmountForUnavailabilityTier2Threshold The amount of RON to deduct from self-staking of a block\n * producer when (s)he is slashed with tier-2 or tier-3.\n * @return _jailDurationForUnavailabilityTier2Threshold The number of blocks to jail a block producer when (s)he is\n * slashed with tier-2 or tier-3.\n *\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n returns (\n uint256 _unavailabilityTier1Threshold,\n uint256 _unavailabilityTier2Threshold,\n uint256 _slashAmountForUnavailabilityTier2Threshold,\n uint256 _jailDurationForUnavailabilityTier2Threshold\n );\n\n /**\n * @dev Sets the configs to slash block producers.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `BridgeOperatorSlashingConfigsUpdated`.\n *\n * @param _tier1Threshold The mining reward will be deprecated, if (s)he missed more than this threshold.\n * @param _tier2Threshold The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold.\n * @param _slashAmountForTier2Threshold The amount of RON to deduct from self-staking of a block producer when (s)he\n * is slashed tier-2.\n * @param _jailDurationForTier2Threshold The number of blocks to jail a block producer when (s)he is slashed tier-2.\n *\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external;\n}\n" + }, + "contracts/interfaces/staking/IBaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IBaseStaking {\n struct PoolDetail {\n // Address of the pool i.e. consensus address of the validator\n address addr;\n // Pool admin address\n address admin;\n // Self-staking amount\n uint256 stakingAmount;\n // Total number of RON staking for the pool\n uint256 stakingTotal;\n // Mapping from delegator => delegating amount\n mapping(address => uint256) delegatingAmount;\n // Mapping from delegator => the last timestamp that delegator staked\n mapping(address => uint256) lastDelegatingTimestamp;\n }\n\n /// @dev Emitted when the minium number of seconds to undelegate is updated.\n event CooldownSecsToUndelegateUpdated(uint256 minSecs);\n /// @dev Emitted when the number of seconds that a candidate must wait to be revoked.\n event WaitingSecsToRevokeUpdated(uint256 secs);\n\n /// @dev Error of cannot transfer RON.\n error ErrCannotTransferRON();\n /// @dev Error of receiving zero message value.\n error ErrZeroValue();\n /// @dev Error of pool admin is not allowed to call.\n error ErrPoolAdminForbidden();\n /// @dev Error of no one is allowed to call but the pool's admin.\n error ErrOnlyPoolAdminAllowed();\n /// @dev Error of admin of any active pool cannot delegate.\n error ErrAdminOfAnyActivePoolForbidden(address admin);\n /// @dev Error of querying inactive pool.\n error ErrInactivePool(address poolAddr);\n /// @dev Error of length of input arrays are not of the same.\n error ErrInvalidArrays();\n\n /**\n * @dev Returns whether the `_poolAdminAddr` is currently active.\n */\n function isAdminOfActivePool(address _poolAdminAddr) external view returns (bool);\n\n /**\n * @dev Returns the consensus address corresponding to the pool admin.\n */\n function getPoolAddressOf(address _poolAdminAddr) external view returns (address);\n\n /**\n * @dev Returns the staking pool detail.\n */\n function getPoolDetail(address) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal);\n\n /**\n * @dev Returns the self-staking amounts of the pools.\n */\n function getManySelfStakings(address[] calldata) external view returns (uint256[] memory);\n\n /**\n * @dev Returns The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n */\n function cooldownSecsToUndelegate() external view returns (uint256);\n\n /**\n * @dev Returns the number of seconds that a candidate must wait for the renounce request gets affected.\n */\n function waitingSecsToRevoke() external view returns (uint256);\n\n /**\n * @dev Sets the cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external;\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function setWaitingSecsToRevoke(uint256 _secs) external;\n}\n" + }, + "contracts/interfaces/staking/ICandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface ICandidateStaking is IRewardPool {\n /// @dev Emitted when the minimum staking amount for being a validator is updated.\n event MinValidatorStakingAmountUpdated(uint256 threshold);\n /// @dev Emitted when the commission rate range is updated.\n event CommissionRateRangeUpdated(uint256 minRate, uint256 maxRate);\n\n /// @dev Emitted when the pool admin staked for themself.\n event Staked(address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the pool admin unstaked the amount of RON from themself.\n event Unstaked(address indexed consensuAddr, uint256 amount);\n\n /// @dev Emitted when the validator pool is approved.\n event PoolApproved(address indexed validator, address indexed admin);\n /// @dev Emitted when the validator pool is deprecated.\n event PoolsDeprecated(address[] validator);\n /// @dev Emitted when the staking amount transfer failed.\n event StakingAmountTransferFailed(\n address indexed validator,\n address indexed admin,\n uint256 amount,\n uint256 contractBalance\n );\n /// @dev Emitted when the staking amount deducted failed, e.g. when the validator gets slashed.\n event StakingAmountDeductFailed(\n address indexed validator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Error of cannot transfer RON to specified target.\n error ErrCannotInitTransferRON(address addr, string extraInfo);\n /// @dev Error of three interaction addresses must be of the same in applying for validator candidate.\n error ErrThreeInteractionAddrsNotEqual();\n /// @dev Error of unstaking zero amount.\n error ErrUnstakeZeroAmount();\n /// @dev Error of invalid staking amount left after deducted.\n error ErrStakingAmountLeft();\n /// @dev Error of insufficient staking amount for unstaking.\n error ErrInsufficientStakingAmount();\n /// @dev Error of unstaking too early.\n error ErrUnstakeTooEarly();\n /// @dev Error of setting commission rate exceeds max allowed.\n error ErrInvalidCommissionRate();\n\n /**\n * @dev Returns the minimum threshold for being a validator candidate.\n */\n function minValidatorStakingAmount() external view returns (uint256);\n\n /**\n * @dev Returns the commission rate range that the candidate can set.\n */\n function getCommissionRateRange() external view returns (uint256 _minRange, uint256 _maxRange);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function setMinValidatorStakingAmount(uint256) external;\n\n /**\n * @dev Sets the commission rate range that a candidate can set.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `CommissionRateRangeUpdated` event.\n *\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external;\n\n /**\n * @dev Proposes a candidate to become a validator.\n *\n * Requirements:\n * - The method caller is able to receive RON.\n * - The treasury is able to receive RON.\n * - The amount is larger than or equal to the minimum validator staking amount `minValidatorStakingAmount()`.\n *\n * Emits the event `PoolApproved`.\n *\n * @param _candidateAdmin the candidate admin will be stored in the validator contract, used for calling function that affects\n * to its candidate, e.g. scheduling maintenance.\n *\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable;\n\n /**\n * @dev Deprecates the pool.\n * - Deduct self-staking amount of the pool admin to zero.\n * - Transfer the deducted amount to the pool admin.\n * - Deactivate the pool admin address in the mapping of active pool admins\n *\n * Requirements:\n * - The method caller is validator contract.\n *\n * Emits the event `PoolsDeprecated` and `Unstaked` events.\n * Emits the event `StakingAmountTransferFailed` if the contract cannot transfer RON back to the pool admin.\n *\n */\n function execDeprecatePools(address[] calldata _pools, uint256 _period) external;\n\n /**\n * @dev Self-delegates to the validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `msg.value` is larger than 0.\n *\n * Emits the event `Staked`.\n *\n */\n function stake(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from the validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n * Emits the event `Unstaked`.\n *\n */\n function unstake(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Pool admin requests update validator commission rate. The request will be forwarded to the candidate manager\n * contract, and the value is getting updated in {ICandidateManager-execRequestUpdateCommissionRate}.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n * - The `_effectiveDaysOnwards` must be equal to or larger than the {CandidateManager-_minEffectiveDaysOnwards}.\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdated`.\n *\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestRenounce(address _consensusAddr) external;\n\n /**\n * @dev Renounces being a validator candidate and takes back the delegating/staking amount.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is the pool admin.\n *\n */\n function requestEmergencyExit(address _consensusAddr) external;\n}\n" + }, + "contracts/interfaces/staking/IDelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IRewardPool.sol\";\n\ninterface IDelegatorStaking is IRewardPool {\n /// @dev Emitted when the delegator staked for a validator candidate.\n event Delegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n /// @dev Emitted when the delegator unstaked from a validator candidate.\n event Undelegated(address indexed delegator, address indexed consensuAddr, uint256 amount);\n\n /// @dev Error of undelegating zero amount.\n error ErrUndelegateZeroAmount();\n /// @dev Error of undelegating insufficient amount.\n error ErrInsufficientDelegatingAmount();\n /// @dev Error of undelegating too early.\n error ErrUndelegateTooEarly();\n\n /**\n * @dev Stakes for a validator candidate `_consensusAddr`.\n *\n * Requirements:\n * - The consensus address is a validator candidate.\n * - The method caller is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n */\n function delegate(address _consensusAddr) external payable;\n\n /**\n * @dev Unstakes from a validator candidate `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the `Undelegated` event.\n *\n */\n function undelegate(address _consensusAddr, uint256 _amount) external;\n\n /**\n * @dev Bulk unstakes from a list of candidates.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n *\n * Emits the events `Undelegated`.\n *\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external;\n\n /**\n * @dev Unstakes an amount of RON from the `_consensusAddrSrc` and stake for `_consensusAddrDst`.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `Undelegated` event and the `Delegated` event.\n *\n */\n function redelegate(address _consensusAddrSrc, address _consensusAddrDst, uint256 _amount) external;\n\n /**\n * @dev Returns the claimable reward of the user `_user`.\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards);\n\n /**\n * @dev Claims the reward of method caller.\n *\n * Emits the `RewardClaimed` event.\n *\n */\n function claimRewards(address[] calldata _consensusAddrList) external returns (uint256 _amount);\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n *\n * Requirements:\n * - The method caller is not the pool admin.\n * - The consensus address `_consensusAddrDst` is a validator candidate.\n *\n * Emits the `RewardClaimed` event and the `Delegated` event.\n *\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external returns (uint256 _amount);\n}\n" + }, + "contracts/interfaces/staking/IRewardPool.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/consumers/PeriodWrapperConsumer.sol\";\n\ninterface IRewardPool is PeriodWrapperConsumer {\n struct UserRewardFields {\n // Recorded reward amount.\n uint256 debited;\n // The last accumulated of the amount rewards per share (one unit staking) that the info updated.\n uint256 aRps;\n // Lowest staking amount in the period.\n uint256 lowestAmount;\n // Last period number that the info updated.\n uint256 lastPeriod;\n }\n\n struct PoolFields {\n // Accumulated of the amount rewards per share (one unit staking).\n uint256 aRps;\n // The staking total to share reward of the current period.\n PeriodWrapper shares;\n }\n\n /// @dev Emitted when the fields to calculate pending reward for the user is updated.\n event UserRewardUpdated(address indexed poolAddr, address indexed user, uint256 debited);\n /// @dev Emitted when the user claimed their reward\n event RewardClaimed(address indexed poolAddr, address indexed user, uint256 amount);\n\n /// @dev Emitted when the pool shares are updated\n event PoolSharesUpdated(uint256 indexed period, address indexed poolAddr, uint256 shares);\n /// @dev Emitted when the pools are updated\n event PoolsUpdated(uint256 indexed period, address[] poolAddrs, uint256[] aRps, uint256[] shares);\n /// @dev Emitted when the contract fails when updating the pools\n event PoolsUpdateFailed(uint256 indexed period, address[] poolAddrs, uint256[] rewards);\n /// @dev Emitted when the contract fails when updating the pools that already set\n event PoolsUpdateConflicted(uint256 indexed period, address[] poolAddrs);\n\n /// @dev Error of invalid pool share.\n error ErrInvalidPoolShare();\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amount of an user.\n */\n function getStakingAmount(address _poolAddr, address _user) external view returns (uint256);\n\n /**\n * @dev Returns the staking amounts of the users.\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view returns (uint256[] memory);\n\n /**\n * @dev Returns the total staking amount of all users for a pool.\n */\n function getStakingTotal(address _poolAddr) external view returns (uint256);\n\n /**\n * @dev Returns the total staking amounts of all users for the pools `_poolAddrs`.\n */\n function getManyStakingTotals(address[] calldata _poolAddrs) external view returns (uint256[] memory);\n}\n" + }, + "contracts/interfaces/staking/IStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IBaseStaking.sol\";\nimport \"./ICandidateStaking.sol\";\nimport \"./IDelegatorStaking.sol\";\n\ninterface IStaking is IRewardPool, IBaseStaking, ICandidateStaking, IDelegatorStaking {\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_consensusAddrs`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolsUpdateConflicted` when there are some pools which already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable;\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Requirements:\n * - The method caller must be validator contract.\n *\n * Emits the event `Unstaked`.\n *\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external returns (uint256 _actualDeductingAmount);\n}\n" + }, + "contracts/interfaces/validator/ICandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ICandidateManager {\n struct ValidatorCandidate {\n // Admin of the candidate\n address admin;\n // Address of the validator that produces block, e.g. block.coinbase. This is so-called validator address.\n address consensusAddr;\n // Address that receives mining reward of the validator\n address payable treasuryAddr;\n // Address of the bridge operator corresponding to the candidate\n address ______deprecatedbridgeOperatorAddr;\n // The percentage of reward that validators can be received, the rest goes to the delegators.\n // Values in range [0; 100_00] stands for 0-100%\n uint256 commissionRate;\n // The timestamp that scheduled to revoke the candidate (no schedule=0)\n uint256 revokingTimestamp;\n // The deadline that the candidate must top up staking amount to keep it larger than or equal to the threshold (no deadline=0)\n uint256 topupDeadline;\n }\n\n struct CommissionSchedule {\n // The timestamp that the commission schedule gets affected (no schedule=0).\n uint256 effectiveTimestamp;\n // The new commission rate. Value is in range [0; 100_00], stands for 0-100%\n uint256 commissionRate;\n }\n\n /// @dev Emitted when the maximum number of validator candidates is updated.\n event MaxValidatorCandidateUpdated(uint256 threshold);\n /// @dev Emitted when the min offset to the effective date of commission rate change is updated.\n event MinEffectiveDaysOnwardsUpdated(uint256 numOfDays);\n /// @dev Emitted when the validator candidate is granted.\n event CandidateGranted(address indexed consensusAddr, address indexed treasuryAddr, address indexed admin);\n /// @dev Emitted when the revoking timestamp of a candidate is updated.\n event CandidateRevokingTimestampUpdated(address indexed consensusAddr, uint256 revokingTimestamp);\n /// @dev Emitted when the topup deadline of a candidate is updated.\n event CandidateTopupDeadlineUpdated(address indexed consensusAddr, uint256 topupDeadline);\n /// @dev Emitted when the validator candidate is revoked.\n event CandidatesRevoked(address[] consensusAddrs);\n\n /// @dev Emitted when a schedule for updating commission rate is set.\n event CommissionRateUpdateScheduled(address indexed consensusAddr, uint256 effectiveTimestamp, uint256 rate);\n /// @dev Emitted when the commission rate of a validator is updated.\n event CommissionRateUpdated(address indexed consensusAddr, uint256 rate);\n\n /// @dev Error of exceeding maximum number of candidates.\n error ErrExceedsMaxNumberOfCandidate();\n /// @dev Error of querying for already existent candidate.\n error ErrExistentCandidate();\n /// @dev Error of querying for non-existent candidate.\n error ErrNonExistentCandidate();\n /// @dev Error of candidate admin already exists.\n error ErrExistentCandidateAdmin(address _candidateAdminAddr);\n /// @dev Error of treasury already exists.\n error ErrExistentTreasury(address _treasuryAddr);\n /// @dev Error of invalid commission rate.\n error ErrInvalidCommissionRate();\n /// @dev Error of invalid effective days onwards.\n error ErrInvalidEffectiveDaysOnwards();\n /// @dev Error of invalid min effective days onwards.\n error ErrInvalidMinEffectiveDaysOnwards();\n /// @dev Error of already requested revoking candidate before.\n error ErrAlreadyRequestedRevokingCandidate();\n /// @dev Error of commission change schedule exists.\n error ErrAlreadyRequestedUpdatingCommissionRate();\n /// @dev Error of trusted org cannot renounce.\n error ErrTrustedOrgCannotRenounce();\n\n /**\n * @dev Returns the maximum number of validator candidate.\n */\n function maxValidatorCandidate() external view returns (uint256);\n\n /**\n * @dev Returns the minimum number of days to the effective date of commission rate change.\n */\n function minEffectiveDaysOnward() external view returns (uint256);\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function setMaxValidatorCandidate(uint256) external;\n\n /**\n * @dev Sets the minimum number of days to the effective date of commision rate change.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external;\n\n /**\n * @dev Grants a validator candidate.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateGranted`.\n *\n */\n function execApplyValidatorCandidate(\n address _admin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external;\n\n /**\n * @dev Requests to revoke a validator candidate in next `_secsLeft` seconds.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n * Emits the event `CandidateRevokingTimestampUpdated`.\n *\n */\n function execRequestRenounceCandidate(address, uint256 _secsLeft) external;\n\n /**\n * @dev Fallback function of `CandidateStaking-requestUpdateCommissionRate`.\n *\n * Requirements:\n * - The method caller is the staking contract.\n * - The `_effectiveTimestamp` must be the beginning of a UTC day, and at least from 7 days onwards\n * - The `_rate` must be in range of [0_00; 100_00].\n *\n * Emits the event `CommissionRateUpdateScheduled`.\n *\n */\n function execRequestUpdateCommissionRate(address _consensusAddr, uint256 _effectiveTimestamp, uint256 _rate) external;\n\n /**\n * @dev Returns whether the address is a validator (candidate).\n */\n function isValidatorCandidate(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the validator candidate.\n */\n function getValidatorCandidates() external view returns (address[] memory);\n\n /**\n * @dev Returns all candidate info.\n */\n function getCandidateInfos() external view returns (ValidatorCandidate[] memory);\n\n /**\n * @dev Returns the info of a candidate.\n */\n function getCandidateInfo(address _candidate) external view returns (ValidatorCandidate memory);\n\n /**\n * @dev Returns whether the address is the candidate admin.\n */\n function isCandidateAdmin(address _candidate, address _admin) external view returns (bool);\n\n /**\n * @dev Returns the schedule of changing commission rate of a candidate address.\n */\n function getCommissionChangeSchedule(address _candidate) external view returns (CommissionSchedule memory);\n}\n" + }, + "contracts/interfaces/validator/ICoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ISlashingExecution.sol\";\n\ninterface ICoinbaseExecution is ISlashingExecution {\n enum BlockRewardDeprecatedType {\n UNKNOWN,\n UNAVAILABILITY,\n AFTER_BAILOUT\n }\n\n /// @dev Emitted when the validator set is updated\n event ValidatorSetUpdated(uint256 indexed period, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated, to mirror the in-jail and maintaining status of the validator.\n event BlockProducerSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] consensusAddrs);\n /// @dev Emitted when the bridge operator set is updated.\n event BridgeOperatorSetUpdated(uint256 indexed period, uint256 indexed epoch, address[] bridgeOperators);\n\n /// @dev Emitted when the reward of the block producer is deprecated.\n event BlockRewardDeprecated(\n address indexed coinbaseAddr,\n uint256 rewardAmount,\n BlockRewardDeprecatedType deprecatedType\n );\n /// @dev Emitted when the block reward is submitted.\n event BlockRewardSubmitted(address indexed coinbaseAddr, uint256 submittedAmount, uint256 bonusAmount);\n\n /// @dev Emitted when the block producer reward is distributed.\n event MiningRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the block producer reward.\n event MiningRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the bridge operator reward is distributed.\n event BridgeOperatorRewardDistributed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipientAddr,\n uint256 amount\n );\n /// @dev Emitted when the contract fails when distributing the bridge operator reward.\n event BridgeOperatorRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed bridgeOperator,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the fast finality reward is distributed.\n event FastFinalityRewardDistributed(address indexed consensusAddr, address indexed recipient, uint256 amount);\n /// @dev Emitted when the contract fails when distributing the fast finality reward.\n event FastFinalityRewardDistributionFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 amount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the amount of RON reward is distributed to staking contract.\n event StakingRewardDistributed(uint256 totalAmount, address[] consensusAddrs, uint256[] amounts);\n /// @dev Emitted when the contracts fails when distributing the amount of RON to the staking contract.\n event StakingRewardDistributionFailed(\n uint256 totalAmount,\n address[] consensusAddrs,\n uint256[] amounts,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the epoch is wrapped up.\n event WrappedUpEpoch(uint256 indexed periodNumber, uint256 indexed epochNumber, bool periodEnding);\n\n /// @dev Error of only allowed at the end of epoch\n error ErrAtEndOfEpochOnly();\n /// @dev Error of query for already wrapped up epoch\n error ErrAlreadyWrappedEpoch();\n\n /**\n * @dev Submits reward of the current block.\n *\n * Requirements:\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDeprecated` if the coinbase is slashed or no longer be a block producer.\n * Emits the event `BlockRewardSubmitted` for the valid call.\n *\n */\n function submitBlockReward() external payable;\n\n /**\n * @dev Wraps up the current epoch.\n *\n * Requirements:\n * - The method must be called when the current epoch is ending.\n * - The epoch is not wrapped yet.\n * - The method caller is coinbase.\n *\n * Emits the event `MiningRewardDistributed` when some validator has reward distributed.\n * Emits the event `StakingRewardDistributed` when some staking pool has reward distributed.\n * Emits the event `BlockProducerSetUpdated` when the epoch is wrapped up.\n * Emits the event `BridgeOperatorSetUpdated` when the epoch is wrapped up at period ending.\n * Emits the event `ValidatorSetUpdated` when the epoch is wrapped up at period ending, and the validator set gets updated.\n * Emits the event `WrappedUpEpoch`.\n *\n */\n function wrapUpEpoch() external payable;\n}\n" + }, + "contracts/interfaces/validator/IEmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IEmergencyExit {\n /// @dev Emitted when the fund is locked from an emergency exit request\n event EmergencyExitRequested(address indexed consensusAddr, uint256 lockedAmount);\n /// @dev Emitted when the fund that locked from an emergency exit request is transferred to the recipient.\n event EmergencyExitLockedFundReleased(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount\n );\n /// @dev Emitted when the fund that locked from an emergency exit request is failed to transferred back.\n event EmergencyExitLockedFundReleasingFailed(\n address indexed consensusAddr,\n address indexed recipient,\n uint256 unlockedAmount,\n uint256 contractBalance\n );\n\n /// @dev Emitted when the emergency exit locked amount is updated.\n event EmergencyExitLockedAmountUpdated(uint256 amount);\n /// @dev Emitted when the emergency expiry duration is updated.\n event EmergencyExpiryDurationUpdated(uint256 amount);\n\n /// @dev Error of already requested emergency exit before.\n error ErrAlreadyRequestedEmergencyExit();\n\n /**\n * @dev Returns the amount of RON to lock from a consensus address.\n */\n function emergencyExitLockedAmount() external returns (uint256);\n\n /**\n * @dev Returns the duration that an emergency request is expired and the fund will be recycled.\n */\n function emergencyExpiryDuration() external returns (uint256);\n\n /**\n * @dev Sets the amount of RON to lock from a consensus address.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedAmountUpdated`.\n *\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external;\n\n /**\n * @dev Sets the duration that an emergency request is expired and the fund will be recycled.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExpiryDurationUpdated`.\n *\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external;\n\n /**\n * @dev Unlocks fund for emergency exit request.\n *\n * Requirements:\n * - The method caller is admin.\n *\n * Emits the event `EmergencyExitLockedFundReleased` if the fund is successfully unlocked.\n * Emits the event `EmergencyExitLockedFundReleasingFailed` if the fund is failed to unlock.\n *\n */\n function execReleaseLockedFundForEmergencyExitRequest(address _consensusAddr, address payable _recipient) external;\n\n /**\n * @dev Fallback function of `IStaking-requestEmergencyExit`.\n *\n * Requirements:\n * - The method caller is staking contract.\n *\n */\n function execEmergencyExit(address _consensusAddr, uint256 _secLeftToRevoke) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ICommonInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./IJailingInfo.sol\";\nimport \"./ITimingInfo.sol\";\nimport \"./IValidatorInfoV2.sol\";\n\ninterface ICommonInfo is ITimingInfo, IJailingInfo, IValidatorInfoV2 {\n struct EmergencyExitInfo {\n uint256 lockedAmount;\n // The timestamp that this locked amount will be recycled to staking vesting contract\n uint256 recyclingAt;\n }\n\n /// @dev Emitted when the deprecated reward is withdrawn.\n event DeprecatedRewardRecycled(address indexed recipientAddr, uint256 amount);\n /// @dev Emitted when the deprecated reward withdrawal is failed\n event DeprecatedRewardRecycleFailed(address indexed recipientAddr, uint256 amount, uint256 balance);\n\n /// @dev Error thrown when receives RON from neither staking vesting contract nor staking contract\n error ErrUnauthorizedReceiveRON();\n /// @dev Error thrown when queries for a non existent info.\n error NonExistentRecyclingInfo();\n\n /**\n * @dev Returns the total deprecated reward, which includes reward that is not sent for slashed validators and unsastified bridge operators\n */\n function totalDeprecatedReward() external view returns (uint256);\n\n /**\n * @dev Returns the emergency exit request.\n */\n function getEmergencyExitInfo(address _consensusAddr) external view returns (EmergencyExitInfo memory);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IJailingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface IJailingInfo {\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) during the current period.\n */\n function checkJailed(address) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeft(\n address _addr\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validator are put in jail (cannot join the set of validators) at a specific block.\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view returns (bool);\n\n /**\n * @dev Returns whether the validator are put in jail at a specific block and the number of block and epoch that he still is in the jail.\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_);\n\n /**\n * @dev Returns whether the validators are put in jail (cannot join the set of validators) during the current period.\n */\n function checkManyJailed(address[] calldata) external view returns (bool[] memory);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during the current period.\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view returns (bool);\n\n /**\n * @dev Returns whether the incoming reward of the block producer is deprecated during a specific period.\n */\n function checkMiningRewardDeprecatedAtPeriod(address _blockProducer, uint256 _period) external view returns (bool);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/ITimingInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ITimingInfo {\n /**\n * @dev Returns the block that validator set was updated.\n */\n function getLastUpdatedBlock() external view returns (uint256);\n\n /**\n * @dev Returns the number of blocks in a epoch.\n */\n function numberOfBlocksInEpoch() external view returns (uint256 _numberOfBlocks);\n\n /**\n * @dev Returns the epoch index from the block number.\n */\n function epochOf(uint256 _block) external view returns (uint256);\n\n /**\n * @dev Returns whether the epoch ending is at the block number `_block`.\n */\n function epochEndingAt(uint256 _block) external view returns (bool);\n\n /**\n * @dev Tries to get the period index from the epoch number.\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber);\n\n /**\n * @dev Returns whether the period ending at the current block number.\n */\n function isPeriodEnding() external view returns (bool);\n\n /**\n * @dev Returns the period index from the current block.\n */\n function currentPeriod() external view returns (uint256);\n\n /**\n * @dev Returns the block number that the current period starts at.\n */\n function currentPeriodStartAtBlock() external view returns (uint256);\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfo.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfo {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators()\n external\n view\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n );\n\n /**\n * @dev Returns whether the address is either a bridge operator or a block producer.\n */\n function isValidator(address _addr) external view returns (bool);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Returns the current on-working bridge operator list.\n * @param bridgeOperatorList The list of working bridge operators.\n * @param validatorList The list of corresponding validators.\n */\n function getBridgeOperators()\n external\n view\n returns (address[] memory bridgeOperatorList, address[] memory validatorList);\n\n /**\n * @dev Returns the bridge operator list corresponding to validator address list.\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) external view returns (address[] memory bridgeOperatorList);\n\n /**\n * @dev Returns whether the address is bridge operator.\n */\n function isBridgeOperator(address _addr) external view returns (bool isOperator);\n\n /**\n * @dev Returns whether the consensus address is operating the bridge or not.\n */\n function isOperatingBridge(address _consensusAddr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the bridge operators.\n */\n function totalBridgeOperator() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/info-fragments/IValidatorInfoV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\n\ninterface IValidatorInfoV2 {\n /**\n * @dev Error thrown when an invalid maximum prioritized validator number is provided.\n */\n error ErrInvalidMaxPrioritizedValidatorNumber();\n\n /// @dev Emitted when the number of max validator is updated.\n event MaxValidatorNumberUpdated(uint256);\n /// @dev Emitted when the number of reserved slots for prioritized validators is updated.\n event MaxPrioritizedValidatorNumberUpdated(uint256);\n\n /**\n * @dev Returns the maximum number of validators in the epoch.\n */\n function maxValidatorNumber() external view returns (uint256 _maximumValidatorNumber);\n\n /**\n * @dev Returns the number of reserved slots for prioritized validators.\n */\n function maxPrioritizedValidatorNumber() external view returns (uint256 _maximumPrioritizedValidatorNumber);\n\n /**\n * @dev Returns the current validator list.\n */\n function getValidators() external view returns (address[] memory _validatorList);\n\n /**\n * @dev Returns the current block producer list.\n */\n function getBlockProducers() external view returns (address[] memory);\n\n /**\n * @dev Returns whether the address is block producer or not.\n */\n function isBlockProducer(address _addr) external view returns (bool);\n\n /**\n * @dev Returns total numbers of the block producers.\n */\n function totalBlockProducer() external view returns (uint256);\n\n /**\n * @dev Updates the max validator number\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxValidatorNumberUpdated`\n *\n */\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external;\n\n /**\n * @dev Updates the number of reserved slots for prioritized validators\n *\n * Requirements:\n * - The method caller is admin\n *\n * Emits the event `MaxPrioritizedValidatorNumberUpdated`\n *\n */\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external;\n}\n" + }, + "contracts/interfaces/validator/IRoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./ICandidateManager.sol\";\nimport \"./info-fragments/ICommonInfo.sol\";\nimport \"./ICoinbaseExecution.sol\";\nimport \"./ISlashingExecution.sol\";\nimport \"./IEmergencyExit.sol\";\n\ninterface IRoninValidatorSet is\n ICandidateManager,\n ICommonInfo,\n ISlashingExecution,\n ICoinbaseExecution,\n IEmergencyExit\n{}\n" + }, + "contracts/interfaces/validator/ISlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\ninterface ISlashingExecution {\n /// @dev Emitted when the validator is punished.\n event ValidatorPunished(\n address indexed consensusAddr,\n uint256 indexed period,\n uint256 jailedUntil,\n uint256 deductedStakingAmount,\n bool blockProducerRewardDeprecated,\n bool bridgeOperatorRewardDeprecated\n );\n /// @dev Emitted when the validator get out of jail by bailout.\n event ValidatorUnjailed(address indexed validator, uint256 period);\n\n /// @dev Error of cannot bailout due to high tier slash.\n error ErrCannotBailout(address validator);\n\n /**\n * @dev Finalize the slash request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorPunished`.\n *\n */\n function execSlash(address validatorAddr, uint256 newJailedUntil, uint256 slashAmount, bool cannotBailout) external;\n\n /**\n * @dev Finalize the bailout request from slash indicator contract.\n *\n * Requirements:\n * - The method caller is slash indicator contract.\n *\n * Emits the event `ValidatorUnjailed`.\n *\n */\n function execBailOut(address _validatorAddr, uint256 _period) external;\n}\n" + }, + "contracts/interfaces/version-control/IConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface IConditionalImplementControl {\n /// @dev Error when contract which delegate to this contract is not compatible with ERC1967\n error ErrDelegateFromUnknownOrigin(address addr);\n\n /**\n * @dev Emitted when the implementation is upgraded.\n */\n event Upgraded(address indexed implementation);\n\n /**\n * @dev Executes the selfUpgrade function, upgrading to the new contract implementation.\n */\n function selfUpgrade() external;\n\n /**\n * @dev Set additional calldata to call when upgrading via `selfUpgrade`.\n */\n function setCallDatas(bytes[] calldata args) external;\n}\n" + }, + "contracts/libraries/AddressArrayUtils.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary AddressArrayUtils {\n /**\n * @dev Error thrown when a duplicated element is detected in an array.\n * @param msgSig The function signature that invoke the error.\n */\n error ErrDuplicated(bytes4 msgSig);\n\n /**\n * @dev Returns whether or not there's a duplicate. Runs in O(n^2).\n * @param A Array to search\n * @return Returns true if duplicate, false otherwise\n */\n function hasDuplicate(address[] memory A) internal pure returns (bool) {\n if (A.length == 0) {\n return false;\n }\n unchecked {\n for (uint256 i = 0; i < A.length - 1; i++) {\n for (uint256 j = i + 1; j < A.length; j++) {\n if (A[i] == A[j]) {\n return true;\n }\n }\n }\n }\n return false;\n }\n\n /**\n * @dev Returns whether two arrays of addresses are equal or not.\n */\n function isEqual(address[] memory _this, address[] memory _other) internal pure returns (bool yes_) {\n // Hashing two arrays and compare their hash\n assembly {\n let _thisHash := keccak256(add(_this, 32), mul(mload(_this), 32))\n let _otherHash := keccak256(add(_other, 32), mul(mload(_other), 32))\n yes_ := eq(_thisHash, _otherHash)\n }\n }\n\n /**\n * @dev Return the concatenated array from a and b.\n */\n function extend(address[] memory a, address[] memory b) internal pure returns (address[] memory c) {\n uint256 lengthA = a.length;\n uint256 lengthB = b.length;\n unchecked {\n c = new address[](lengthA + lengthB);\n }\n uint256 i;\n for (; i < lengthA; ) {\n c[i] = a[i];\n unchecked {\n ++i;\n }\n }\n for (uint256 j; j < lengthB; ) {\n c[i] = b[j];\n unchecked {\n ++i;\n ++j;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Ballot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary Ballot {\n using ECDSA for bytes32;\n\n enum VoteType {\n For,\n Against\n }\n\n // keccak256(\"Ballot(bytes32 proposalHash,uint8 support)\");\n bytes32 private constant BALLOT_TYPEHASH = 0xd900570327c4c0df8dd6bdd522b7da7e39145dd049d2fd4602276adcd511e3c2;\n\n function hash(bytes32 _proposalHash, VoteType _support) internal pure returns (bytes32 digest) {\n // return keccak256(abi.encode(BALLOT_TYPEHASH, _proposalHash, _support));\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _proposalHash)\n mstore(add(ptr, 0x40), _support)\n digest := keccak256(ptr, 0x60)\n }\n }\n}\n" + }, + "contracts/libraries/BridgeOperatorsBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary BridgeOperatorsBallot {\n /**\n * @dev Error thrown when an invalid order of the bridge operator is detected.\n */\n error ErrInvalidOrderOfBridgeOperator();\n\n struct BridgeOperatorSet {\n uint256 period;\n uint256 epoch;\n address[] operators;\n }\n\n // keccak256(\"BridgeOperatorsBallot(uint256 period,uint256 epoch,address[] operators)\");\n bytes32 public constant BRIDGE_OPERATORS_BALLOT_TYPEHASH =\n 0xd679a49e9e099fa9ed83a5446aaec83e746b03ec6723d6f5efb29d37d7f0b78a;\n\n /**\n * @dev Verifies whether the ballot is valid or not.\n *\n * Requirements:\n * - The ballot is not for an empty operator set.\n * - The operator address list is in order.\n *\n */\n function verifyBallot(BridgeOperatorSet calldata _ballot) internal pure {\n if (_ballot.operators.length == 0) revert ErrEmptyArray();\n\n address _addr = _ballot.operators[0];\n for (uint _i = 1; _i < _ballot.operators.length; ) {\n if (_addr >= _ballot.operators[_i]) revert ErrInvalidOrderOfBridgeOperator();\n _addr = _ballot.operators[_i];\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(BridgeOperatorSet memory self) internal pure returns (bytes32 digest_) {\n bytes32 operatorsHash;\n address[] memory operators = self.operators;\n\n // return keccak256(abi.encode(BRIDGE_OPERATORS_BALLOT_TYPEHASH, _ballot.period, _ballot.epoch, _operatorsHash));\n assembly {\n operatorsHash := keccak256(add(operators, 32), mul(mload(operators), 32))\n let ptr := mload(0x40)\n mstore(ptr, BRIDGE_OPERATORS_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), mload(self)) // _ballot.period\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _ballot.epoch\n mstore(add(ptr, 0x60), operatorsHash)\n digest_ := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/EmergencyExitBallot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\n\nlibrary EmergencyExitBallot {\n // keccak256(\"EmergencyExitBallot(address consensusAddress,address recipientAfterUnlockedFund,uint256 requestedAt,uint256 expiredAt)\");\n bytes32 private constant EMERGENCY_EXIT_BALLOT_TYPEHASH =\n 0x697acba4deaf1a718d8c2d93e42860488cb7812696f28ca10eed17bac41e7027;\n\n /**\n * @dev Returns hash of the ballot.\n */\n function hash(\n address _consensusAddress,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) internal pure returns (bytes32 digest) {\n /*\n * return\n * keccak256(\n * abi.encode(\n * EMERGENCY_EXIT_BALLOT_TYPEHASH,\n * _consensusAddress,\n * _recipientAfterUnlockedFund,\n * _requestedAt,\n * _expiredAt\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, EMERGENCY_EXIT_BALLOT_TYPEHASH)\n mstore(add(ptr, 0x20), _consensusAddress)\n mstore(add(ptr, 0x40), _recipientAfterUnlockedFund)\n mstore(add(ptr, 0x60), _requestedAt)\n mstore(add(ptr, 0x80), _expiredAt)\n digest := keccak256(ptr, 0xa0)\n }\n }\n}\n" + }, + "contracts/libraries/EnumFlags.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\n/**\n * @dev This library implements checking flag of an enumerated value.\n * The originated idea is inherited from [Enum.HashFlag(Enum)](https://learn.microsoft.com/en-us/dotnet/api/system.enum.hasflag?view=net-6.0) method of C#.\n */\nlibrary EnumFlags {\n enum ValidatorFlag {\n None, // bit(00)\n BlockProducer, // bit(01)\n DeprecatedBridgeOperator, // bit(10)\n Both // bit(11)\n }\n\n function isNone(ValidatorFlag _value) internal pure returns (bool) {\n return uint8(_value) == 0;\n }\n\n /**\n * @dev Checks if `_value` has `_flag`.\n */\n function hasFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (bool) {\n return (uint8(_value) & uint8(_flag)) != 0;\n }\n\n /**\n * @dev Calculate new value of `_value` after adding `_flag`.\n */\n function addFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) | uint8(_flag));\n }\n\n /**\n * @dev Calculate new value of `_value` after remove `_flag`.\n */\n function removeFlag(ValidatorFlag _value, ValidatorFlag _flag) internal pure returns (ValidatorFlag) {\n return ValidatorFlag(uint8(_value) & ~uint8(_flag));\n }\n}\n" + }, + "contracts/libraries/ErrorHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrProxyCallFailed } from \"../utils/CommonErrors.sol\";\n\nlibrary ErrorHandler {\n /// @notice handle low level call revert if call failed,\n /// If extcall return empty bytes, reverts with custom error.\n /// @param status Status of external call\n /// @param callSig function signature of the calldata\n /// @param returnOrRevertData bytes result from external call\n function handleRevert(bool status, bytes4 callSig, bytes memory returnOrRevertData) internal pure {\n // Get the function signature of current context\n bytes4 msgSig = msg.sig;\n assembly {\n if iszero(status) {\n // Load the length of bytes array\n let revertLength := mload(returnOrRevertData)\n // Check if length != 0 => revert following reason from external call\n if iszero(iszero(revertLength)) {\n // Start of revert data bytes. The 0x20 offset is always the same.\n revert(add(returnOrRevertData, 0x20), revertLength)\n }\n\n // Load free memory pointer\n let ptr := mload(0x40)\n // Store 4 bytes the function selector of ErrProxyCallFailed(msg.sig, callSig)\n // Equivalent to revert ErrProxyCallFailed(bytes4,bytes4)\n mstore(ptr, 0x8e3eda2b)\n // Store 4 bytes of msgSig parameter in the next slot\n mstore(add(ptr, 0x20), msgSig)\n // Store 4 bytes of callSig parameter in the next slot\n mstore(add(ptr, 0x40), callSig)\n // Revert 68 bytes of error starting from 0x1c\n revert(add(ptr, 0x1c), 0x44)\n }\n }\n }\n}\n" + }, + "contracts/libraries/GlobalProposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"./Proposal.sol\";\n\nlibrary GlobalProposal {\n /**\n * @dev Error thrown when attempting to interact with an unsupported target.\n */\n error ErrUnsupportedTarget(bytes32 proposalHash, uint256 targetNumber);\n\n enum TargetOption {\n /* 0 */ BridgeManager,\n /* 1 */ GatewayContract,\n /* 2 */ BridgeReward,\n /* 3 */ BridgeSlash,\n /* 4 */ BridgeTracking\n }\n\n struct GlobalProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n uint256 expiryTimestamp;\n TargetOption[] targetOptions;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"GlobalProposalDetail(uint256 nonce,uint256 expiryTimestamp,uint8[] targetOptions,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0x1463f426c05aff2c1a7a0957a71c9898bc8b47142540538e79ee25ee91141350;\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(GlobalProposalDetail memory self) internal pure returns (bytes32 digest_) {\n uint256[] memory values = self.values;\n TargetOption[] memory targets = self.targetOptions;\n bytes32[] memory calldataHashList = new bytes32[](self.calldatas.length);\n uint256[] memory gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < calldataHashList.length; ) {\n calldataHashList[i] = keccak256(self.calldatas[i]);\n\n unchecked {\n ++i;\n }\n }\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _proposal.nonce,\n * _proposal.expiryTimestamp,\n * _targetsHash,\n * _valuesHash,\n * _calldatasHash,\n * _gasAmountsHash\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(self)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(self, 0x20))) // _proposal.expiryTimestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(targets, 32), mul(mload(targets), 32)) // targetsHash\n mstore(add(ptr, 0x60), arrayHashed)\n arrayHashed := keccak256(add(values, 32), mul(mload(values), 32)) // _valuesHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(calldataHashList, 32), mul(mload(calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(gasAmounts, 32), mul(mload(gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xc0), arrayHashed)\n digest_ := keccak256(ptr, 0xe0)\n }\n }\n\n /**\n * @dev Converts into the normal proposal.\n */\n function intoProposalDetail(\n GlobalProposalDetail memory self,\n address[] memory targets\n ) internal pure returns (Proposal.ProposalDetail memory detail_) {\n detail_.nonce = self.nonce;\n detail_.expiryTimestamp = self.expiryTimestamp;\n detail_.chainId = 0;\n detail_.targets = new address[](self.targetOptions.length);\n detail_.values = self.values;\n detail_.calldatas = self.calldatas;\n detail_.gasAmounts = self.gasAmounts;\n\n for (uint256 i; i < self.targetOptions.length; ) {\n detail_.targets[i] = targets[i];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/IsolatedGovernance.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../utils/CommonErrors.sol\";\n\nlibrary IsolatedGovernance {\n struct Vote {\n VoteStatusConsumer.VoteStatus status;\n bytes32 finalHash;\n /// @dev Mapping from voter => receipt hash\n mapping(address => bytes32) voteHashOf;\n /// @dev The timestamp that voting is expired (no expiration=0)\n uint256 expiredAt;\n /// @dev The timestamp that voting is created\n uint256 createdAt;\n /// @dev The list of voters\n address[] voters;\n }\n\n /**\n * @dev Casts vote for the receipt with the receipt hash `_hash`.\n *\n * Requirements:\n * - The voter has not voted for the round.\n *\n */\n function castVote(Vote storage _v, address _voter, bytes32 _hash) internal {\n if (_v.expiredAt > 0 && _v.expiredAt <= block.timestamp) {\n _v.status = VoteStatusConsumer.VoteStatus.Expired;\n }\n\n if (voted(_v, _voter)) revert ErrAlreadyVoted(_voter);\n\n _v.voteHashOf[_voter] = _hash;\n _v.voters.push(_voter);\n }\n\n /**\n * @dev Updates vote with the requirement of minimum vote weight.\n */\n function syncVoteStatus(\n Vote storage _v,\n uint256 _minimumVoteWeight,\n uint256 _votedWeightForHash,\n bytes32 _hash\n ) internal returns (VoteStatusConsumer.VoteStatus _status) {\n if (_votedWeightForHash >= _minimumVoteWeight && _v.status == VoteStatusConsumer.VoteStatus.Pending) {\n _v.status = VoteStatusConsumer.VoteStatus.Approved;\n _v.finalHash = _hash;\n }\n\n return _v.status;\n }\n\n /**\n * @dev Returns the list of vote's addresses that voted for the hash `_hash`.\n */\n function filterByHash(Vote storage _v, bytes32 _hash) internal view returns (address[] memory _voters) {\n uint256 _count;\n _voters = new address[](_v.voters.length);\n\n unchecked {\n for (uint _i; _i < _voters.length; ++_i) {\n address _voter = _v.voters[_i];\n if (_v.voteHashOf[_voter] == _hash) {\n _voters[_count++] = _voter;\n }\n }\n }\n\n assembly {\n mstore(_voters, _count)\n }\n }\n\n /**\n * @dev Returns whether the voter casted for the proposal.\n */\n function voted(Vote storage _v, address _voter) internal view returns (bool) {\n return _v.voteHashOf[_voter] != bytes32(0);\n }\n}\n" + }, + "contracts/libraries/Math.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Math {\n /**\n * @dev Returns the largest of two numbers.\n */\n function max(uint256 a, uint256 b) internal pure returns (uint256) {\n return a >= b ? a : b;\n }\n\n /**\n * @dev Returns the smallest of two numbers.\n */\n function min(uint256 a, uint256 b) internal pure returns (uint256) {\n return a < b ? a : b;\n }\n\n /**\n * @dev Returns whether the number `c` is in range of [a; b].\n */\n function inRange(uint256 c, uint256 a, uint256 b) internal pure returns (bool) {\n return a <= c && c <= b;\n }\n\n /**\n * @dev Returns whether two inclusive ranges [x1;x2] and [y1;y2] overlap.\n */\n function twoRangeOverlap(uint256 x1, uint256 x2, uint256 y1, uint256 y2) internal pure returns (bool) {\n return x1 <= y2 && y1 <= x2;\n }\n\n /**\n * @dev Returns value of a + b; in case result is larger than upperbound, upperbound is returned.\n */\n function addWithUpperbound(uint256 a, uint256 b, uint256 upperbound) internal pure returns (uint256) {\n return min(a + b, upperbound);\n }\n\n /**\n * @dev Returns value of a - b; in case of negative result, 0 is returned.\n */\n function subNonNegative(uint256 a, uint256 b) internal pure returns (uint256) {\n return a > b ? a - b : 0;\n }\n\n /**\n * @dev Returns value of `a + zeroable` if zerobale is not 0; otherwise, return 0.\n */\n function addIfNonZero(uint256 a, uint256 zeroable) internal pure returns (uint256) {\n return zeroable != 0 ? a + zeroable : 0;\n }\n}\n" + }, + "contracts/libraries/Proposal.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrInvalidChainId, ErrLengthMismatch } from \"../utils/CommonErrors.sol\";\n\nlibrary Proposal {\n /**\n * @dev Error thrown when there is insufficient gas to execute a function.\n */\n error ErrInsufficientGas(bytes32 proposalHash);\n\n /**\n * @dev Error thrown when an invalid expiry timestamp is provided.\n */\n error ErrInvalidExpiryTimestamp();\n\n struct ProposalDetail {\n // Nonce to make sure proposals are executed in order\n uint256 nonce;\n // Value 0: all chain should run this proposal\n // Other values: only specifc chain has to execute\n uint256 chainId;\n uint256 expiryTimestamp;\n address[] targets;\n uint256[] values;\n bytes[] calldatas;\n uint256[] gasAmounts;\n }\n\n // keccak256(\"ProposalDetail(uint256 nonce,uint256 chainId,uint256 expiryTimestamp,address[] targets,uint256[] values,bytes[] calldatas,uint256[] gasAmounts)\");\n bytes32 public constant TYPE_HASH = 0xd051578048e6ff0bbc9fca3b65a42088dbde10f36ca841de566711087ad9b08a;\n\n /**\n * @dev Validates the proposal.\n */\n function validate(ProposalDetail memory _proposal, uint256 _maxExpiryDuration) internal view {\n if (\n !(_proposal.targets.length > 0 &&\n _proposal.targets.length == _proposal.values.length &&\n _proposal.targets.length == _proposal.calldatas.length &&\n _proposal.targets.length == _proposal.gasAmounts.length)\n ) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n if (_proposal.expiryTimestamp > block.timestamp + _maxExpiryDuration) {\n revert ErrInvalidExpiryTimestamp();\n }\n }\n\n /**\n * @dev Returns struct hash of the proposal.\n */\n function hash(ProposalDetail memory _proposal) internal pure returns (bytes32 digest_) {\n uint256[] memory _values = _proposal.values;\n address[] memory _targets = _proposal.targets;\n bytes32[] memory _calldataHashList = new bytes32[](_proposal.calldatas.length);\n uint256[] memory _gasAmounts = _proposal.gasAmounts;\n\n for (uint256 _i; _i < _calldataHashList.length; ) {\n _calldataHashList[_i] = keccak256(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n // return\n // keccak256(\n // abi.encode(\n // TYPE_HASH,\n // _proposal.nonce,\n // _proposal.chainId,\n // _targetsHash,\n // _valuesHash,\n // _calldatasHash,\n // _gasAmountsHash\n // )\n // );\n // /\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_proposal)) // _proposal.nonce\n mstore(add(ptr, 0x40), mload(add(_proposal, 0x20))) // _proposal.chainId\n mstore(add(ptr, 0x60), mload(add(_proposal, 0x40))) // expiry timestamp\n\n let arrayHashed\n arrayHashed := keccak256(add(_targets, 32), mul(mload(_targets), 32)) // targetsHash\n mstore(add(ptr, 0x80), arrayHashed)\n arrayHashed := keccak256(add(_values, 32), mul(mload(_values), 32)) // _valuesHash\n mstore(add(ptr, 0xa0), arrayHashed)\n arrayHashed := keccak256(add(_calldataHashList, 32), mul(mload(_calldataHashList), 32)) // _calldatasHash\n mstore(add(ptr, 0xc0), arrayHashed)\n arrayHashed := keccak256(add(_gasAmounts, 32), mul(mload(_gasAmounts), 32)) // _gasAmountsHash\n mstore(add(ptr, 0xe0), arrayHashed)\n digest_ := keccak256(ptr, 0x100)\n }\n }\n\n /**\n * @dev Returns whether the proposal is executable for the current chain.\n *\n * @notice Does not check whether the call result is successful or not. Please use `execute` instead.\n *\n */\n function executable(ProposalDetail memory _proposal) internal view returns (bool _result) {\n return _proposal.chainId == 0 || _proposal.chainId == block.chainid;\n }\n\n /**\n * @dev Executes the proposal.\n */\n function execute(\n ProposalDetail memory _proposal\n ) internal returns (bool[] memory _successCalls, bytes[] memory _returnDatas) {\n if (!executable(_proposal)) revert ErrInvalidChainId(msg.sig, _proposal.chainId, block.chainid);\n\n _successCalls = new bool[](_proposal.targets.length);\n _returnDatas = new bytes[](_proposal.targets.length);\n for (uint256 _i = 0; _i < _proposal.targets.length; ) {\n if (gasleft() <= _proposal.gasAmounts[_i]) revert ErrInsufficientGas(hash(_proposal));\n\n (_successCalls[_i], _returnDatas[_i]) = _proposal.targets[_i].call{\n value: _proposal.values[_i],\n gas: _proposal.gasAmounts[_i]\n }(_proposal.calldatas[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n}\n" + }, + "contracts/libraries/Token.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"@openzeppelin/contracts/token/ERC721/IERC721.sol\";\nimport \"../interfaces/IWETH.sol\";\n\nlibrary Token {\n /// @dev Error indicating that the provided information is invalid.\n error ErrInvalidInfo();\n\n /// @dev Error indicating that the minting of ERC20 tokens has failed.\n error ErrERC20MintingFailed();\n\n /// @dev Error indicating that the minting of ERC721 tokens has failed.\n error ErrERC721MintingFailed();\n\n /// @dev Error indicating that an unsupported standard is encountered.\n error ErrUnsupportedStandard();\n\n /**\n * @dev Error indicating that the `transfer` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransfer(Info tokenInfo, address to, address token);\n\n /**\n * @dev Error indicating that the `transferFrom` has failed.\n * @param tokenInfo Info of the token including ERC standard, id or quantity.\n * @param from Owner of the token value.\n * @param to Receiver of the token value.\n * @param token Address of the token.\n */\n error ErrTokenCouldNotTransferFrom(Info tokenInfo, address from, address to, address token);\n\n enum Standard {\n ERC20,\n ERC721\n }\n\n struct Info {\n Standard erc;\n // For ERC20: the id must be 0 and the quantity is larger than 0.\n // For ERC721: the quantity must be 0.\n uint256 id;\n uint256 quantity;\n }\n\n // keccak256(\"TokenInfo(uint8 erc,uint256 id,uint256 quantity)\");\n bytes32 public constant INFO_TYPE_HASH = 0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Info memory _info) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(INFO_TYPE_HASH, _info.erc, _info.id, _info.quantity))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, INFO_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_info)) // _info.erc\n mstore(add(ptr, 0x40), mload(add(_info, 0x20))) // _info.id\n mstore(add(ptr, 0x60), mload(add(_info, 0x40))) // _info.quantity\n digest := keccak256(ptr, 0x80)\n }\n }\n\n /**\n * @dev Validates the token info.\n */\n function validate(Info memory _info) internal pure {\n if (\n !((_info.erc == Standard.ERC20 && _info.quantity > 0 && _info.id == 0) ||\n (_info.erc == Standard.ERC721 && _info.quantity == 0))\n ) revert ErrInvalidInfo();\n }\n\n /**\n * @dev Transfer asset from.\n *\n * Requirements:\n * - The `_from` address must approve for the contract using this library.\n *\n */\n function transferFrom(Info memory _info, address _from, address _to, address _token) internal {\n bool _success;\n bytes memory _data;\n if (_info.erc == Standard.ERC20) {\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transferFrom.selector, _from, _to, _info.quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n } else if (_info.erc == Standard.ERC721) {\n // bytes4(keccak256(\"transferFrom(address,address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x23b872dd, _from, _to, _info.id));\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransferFrom(_info, _from, _to, _token);\n }\n\n /**\n * @dev Transfers ERC721 token and returns the result.\n */\n function tryTransferERC721(address _token, address _to, uint256 _id) internal returns (bool _success) {\n (_success, ) = _token.call(abi.encodeWithSelector(IERC721.transferFrom.selector, address(this), _to, _id));\n }\n\n /**\n * @dev Transfers ERC20 token and returns the result.\n */\n function tryTransferERC20(address _token, address _to, uint256 _quantity) internal returns (bool _success) {\n bytes memory _data;\n (_success, _data) = _token.call(abi.encodeWithSelector(IERC20.transfer.selector, _to, _quantity));\n _success = _success && (_data.length == 0 || abi.decode(_data, (bool)));\n }\n\n /**\n * @dev Transfer assets from current address to `_to` address.\n */\n function transfer(Info memory _info, address _to, address _token) internal {\n bool _success;\n if (_info.erc == Standard.ERC20) {\n _success = tryTransferERC20(_token, _to, _info.quantity);\n } else if (_info.erc == Standard.ERC721) {\n _success = tryTransferERC721(_token, _to, _info.id);\n } else revert ErrUnsupportedStandard();\n\n if (!_success) revert ErrTokenCouldNotTransfer(_info, _to, _token);\n }\n\n /**\n * @dev Tries minting and transfering assets.\n *\n * @notice Prioritizes transfer native token if the token is wrapped.\n *\n */\n function handleAssetTransfer(\n Info memory _info,\n address payable _to,\n address _token,\n IWETH _wrappedNativeToken\n ) internal {\n bool _success;\n if (_token == address(_wrappedNativeToken)) {\n // Try sending the native token before transferring the wrapped token\n if (!_to.send(_info.quantity)) {\n _wrappedNativeToken.deposit{ value: _info.quantity }();\n transfer(_info, _to, _token);\n }\n } else if (_info.erc == Token.Standard.ERC20) {\n uint256 _balance = IERC20(_token).balanceOf(address(this));\n\n if (_balance < _info.quantity) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, address(this), _info.quantity - _balance));\n if (!_success) revert ErrERC20MintingFailed();\n }\n\n transfer(_info, _to, _token);\n } else if (_info.erc == Token.Standard.ERC721) {\n if (!tryTransferERC721(_token, _to, _info.id)) {\n // bytes4(keccak256(\"mint(address,uint256)\"))\n (_success, ) = _token.call(abi.encodeWithSelector(0x40c10f19, _to, _info.id));\n if (!_success) revert ErrERC721MintingFailed();\n }\n } else revert ErrUnsupportedStandard();\n }\n\n struct Owner {\n address addr;\n address tokenAddr;\n uint256 chainId;\n }\n\n // keccak256(\"TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant OWNER_TYPE_HASH = 0x353bdd8d69b9e3185b3972e08b03845c0c14a21a390215302776a7a34b0e8764;\n\n /**\n * @dev Returns ownership struct hash.\n */\n function hash(Owner memory _owner) internal pure returns (bytes32 digest) {\n // keccak256(abi.encode(OWNER_TYPE_HASH, _owner.addr, _owner.tokenAddr, _owner.chainId))\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, OWNER_TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_owner)) // _owner.addr\n mstore(add(ptr, 0x40), mload(add(_owner, 0x20))) // _owner.tokenAddr\n mstore(add(ptr, 0x60), mload(add(_owner, 0x40))) // _owner.chainId\n digest := keccak256(ptr, 0x80)\n }\n }\n}\n" + }, + "contracts/libraries/Transfer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/utils/cryptography/ECDSA.sol\";\nimport \"@openzeppelin/contracts/token/ERC20/IERC20.sol\";\nimport \"./Token.sol\";\n\nlibrary Transfer {\n using ECDSA for bytes32;\n\n enum Kind {\n Deposit,\n Withdrawal\n }\n\n struct Request {\n // For deposit request: Recipient address on Ronin network\n // For withdrawal request: Recipient address on mainchain network\n address recipientAddr;\n // Token address to deposit/withdraw\n // Value 0: native token\n address tokenAddr;\n Token.Info info;\n }\n\n /**\n * @dev Converts the transfer request into the deposit receipt.\n */\n function into_deposit_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _roninTokenAddr,\n uint256 _roninChainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Deposit;\n _receipt.mainchain.addr = _requester;\n _receipt.mainchain.tokenAddr = _request.tokenAddr;\n _receipt.mainchain.chainId = block.chainid;\n _receipt.ronin.addr = _request.recipientAddr;\n _receipt.ronin.tokenAddr = _roninTokenAddr;\n _receipt.ronin.chainId = _roninChainId;\n _receipt.info = _request.info;\n }\n\n /**\n * @dev Converts the transfer request into the withdrawal receipt.\n */\n function into_withdrawal_receipt(\n Request memory _request,\n address _requester,\n uint256 _id,\n address _mainchainTokenAddr,\n uint256 _mainchainId\n ) internal view returns (Receipt memory _receipt) {\n _receipt.id = _id;\n _receipt.kind = Kind.Withdrawal;\n _receipt.ronin.addr = _requester;\n _receipt.ronin.tokenAddr = _request.tokenAddr;\n _receipt.ronin.chainId = block.chainid;\n _receipt.mainchain.addr = _request.recipientAddr;\n _receipt.mainchain.tokenAddr = _mainchainTokenAddr;\n _receipt.mainchain.chainId = _mainchainId;\n _receipt.info = _request.info;\n }\n\n struct Receipt {\n uint256 id;\n Kind kind;\n Token.Owner mainchain;\n Token.Owner ronin;\n Token.Info info;\n }\n\n // keccak256(\"Receipt(uint256 id,uint8 kind,TokenOwner mainchain,TokenOwner ronin,TokenInfo info)TokenInfo(uint8 erc,uint256 id,uint256 quantity)TokenOwner(address addr,address tokenAddr,uint256 chainId)\");\n bytes32 public constant TYPE_HASH = 0xb9d1fe7c9deeec5dc90a2f47ff1684239519f2545b2228d3d91fb27df3189eea;\n\n /**\n * @dev Returns token info struct hash.\n */\n function hash(Receipt memory _receipt) internal pure returns (bytes32 digest) {\n bytes32 hashedReceiptMainchain = Token.hash(_receipt.mainchain);\n bytes32 hashedReceiptRonin = Token.hash(_receipt.ronin);\n bytes32 hashedReceiptInfo = Token.hash(_receipt.info);\n\n /*\n * return\n * keccak256(\n * abi.encode(\n * TYPE_HASH,\n * _receipt.id,\n * _receipt.kind,\n * Token.hash(_receipt.mainchain),\n * Token.hash(_receipt.ronin),\n * Token.hash(_receipt.info)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n mstore(ptr, TYPE_HASH)\n mstore(add(ptr, 0x20), mload(_receipt)) // _receipt.id\n mstore(add(ptr, 0x40), mload(add(_receipt, 0x20))) // _receipt.kind\n mstore(add(ptr, 0x60), hashedReceiptMainchain)\n mstore(add(ptr, 0x80), hashedReceiptRonin)\n mstore(add(ptr, 0xa0), hashedReceiptInfo)\n digest := keccak256(ptr, 0xc0)\n }\n }\n\n /**\n * @dev Returns the receipt digest.\n */\n function receiptDigest(bytes32 _domainSeparator, bytes32 _receiptHash) internal pure returns (bytes32) {\n return _domainSeparator.toTypedDataHash(_receiptHash);\n }\n}\n" + }, + "contracts/mainchain/MainchainBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { CoreGovernance } from \"../extensions/sequential-governance/CoreGovernance.sol\";\nimport { GlobalCoreGovernance, GlobalGovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GlobalGovernanceRelay.sol\";\nimport { GovernanceRelay } from \"../extensions/sequential-governance/governance-relay/GovernanceRelay.sol\";\nimport { ContractType, BridgeManager } from \"../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot } from \"../libraries/Ballot.sol\";\nimport { Proposal } from \"../libraries/Proposal.sol\";\nimport { GlobalProposal } from \"../libraries/GlobalProposal.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract MainchainBridgeManager is BridgeManager, GovernanceRelay, GlobalGovernanceRelay {\n uint256 private constant DEFAULT_EXPIRY_DURATION = 1 << 255;\n\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(DEFAULT_EXPIRY_DURATION)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * @dev See `GovernanceRelay-_relayProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayProposal(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayProposal(proposal, supports_, signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev See `GovernanceRelay-_relayGlobalProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n */\n function relayGlobalProposal(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _relayGlobalProposal({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev Internal function to retrieve the minimum vote weight required for governance actions.\n * @return minimumVoteWeight The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to retrieve the total weights of all governors.\n * @return totalWeights The total weights of all governors combined.\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to calculate the sum of weights for a given array of governors.\n * @param governors An array containing the addresses of governors to calculate the sum of weights.\n * @return sumWeights The sum of weights for the provided governors.\n */\n function _sumWeight(address[] memory governors) internal view override returns (uint256) {\n return _sumGovernorsWeight(governors);\n }\n\n /**\n * @dev Internal function to retrieve the chain type of the contract.\n * @return chainType The chain type, indicating the type of the chain the contract operates on (e.g., Mainchain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.Mainchain;\n }\n}\n" + }, + "contracts/mainchain/MainchainGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IBridgeManager } from \"../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeManagerCallback } from \"../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { HasContracts, ContractType } from \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/WithdrawalLimitation.sol\";\nimport \"../libraries/Transfer.sol\";\nimport \"../interfaces/IMainchainGatewayV3.sol\";\n\ncontract MainchainGatewayV3 is\n WithdrawalLimitation,\n Initializable,\n AccessControlEnumerable,\n IMainchainGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n\n /// @dev Withdrawal unlocker role hash\n bytes32 public constant WITHDRAWAL_UNLOCKER_ROLE = keccak256(\"WITHDRAWAL_UNLOCKER_ROLE\");\n\n /// @dev Wrapped native token address\n IWETH public wrappedNativeToken;\n /// @dev Ronin network id\n uint256 public roninChainId;\n /// @dev Total deposit\n uint256 public depositCount;\n /// @dev Domain seperator\n bytes32 internal _domainSeparator;\n /// @dev Mapping from mainchain token => token address on Ronin network\n mapping(address => MappedToken) internal _roninToken;\n /// @dev Mapping from withdrawal id => withdrawal hash\n mapping(uint256 => bytes32) public withdrawalHash;\n /// @dev Mapping from withdrawal id => locked\n mapping(uint256 => bool) public withdrawalLocked;\n\n /// @custom:deprecated Previously `_bridgeOperatorAddedBlock` (mapping(address => uint256))\n uint256 private ______deprecatedBridgeOperatorAddedBlock;\n /// @custom:deprecated Previously `_bridgeOperators` (uint256[])\n uint256 private ______deprecatedBridgeOperators;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n IWETH _wrappedToken,\n uint256 _roninChainId,\n uint256 _numerator,\n uint256 _highTierVWNumerator,\n uint256 _denominator,\n // _addresses[0]: mainchainTokens\n // _addresses[1]: roninTokens\n // _addresses[2]: withdrawalUnlockers\n address[][3] calldata _addresses,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds,\n Token.Standard[] calldata _standards\n ) external payable virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n roninChainId = _roninChainId;\n\n _setWrappedNativeTokenContract(_wrappedToken);\n _updateDomainSeparator();\n _setThreshold(_numerator, _denominator);\n _setHighTierVoteWeightThreshold(_highTierVWNumerator, _denominator);\n _verifyThresholds();\n\n if (_addresses[0].length > 0) {\n // Map mainchain tokens to ronin tokens\n _mapTokens(_addresses[0], _addresses[1], _standards);\n // Sets thresholds based on the mainchain tokens\n _setHighTierThresholds(_addresses[0], _thresholds[0]);\n _setLockedThresholds(_addresses[0], _thresholds[1]);\n _setUnlockFeePercentages(_addresses[0], _thresholds[2]);\n _setDailyWithdrawalLimits(_addresses[0], _thresholds[3]);\n }\n\n // Grant role for withdrawal unlocker\n for (uint256 _i; _i < _addresses[2].length; ) {\n _grantRole(WITHDRAWAL_UNLOCKER_ROLE, _addresses[2][_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n function initializeV2(address bridgeManagerContract) external reinitializer(2) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n }\n\n /**\n * @dev Receives ether without doing anything. Use this function to topup native token.\n */\n function receiveEther() external payable {}\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function DOMAIN_SEPARATOR() external view virtual returns (bytes32) {\n return _domainSeparator;\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function setWrappedNativeTokenContract(IWETH _wrappedToken) external virtual onlyAdmin {\n _setWrappedNativeTokenContract(_wrappedToken);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function requestDepositFor(Transfer.Request calldata _request) external payable virtual whenNotPaused {\n _requestDepositFor(_request, msg.sender);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] calldata _signatures\n ) external virtual whenNotPaused returns (bool _locked) {\n return _submitWithdrawal(_receipt, _signatures);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function unlockWithdrawal(Transfer.Receipt calldata _receipt) external onlyRole(WITHDRAWAL_UNLOCKER_ROLE) {\n bytes32 _receiptHash = _receipt.hash();\n if (withdrawalHash[_receipt.id] != _receipt.hash()) {\n revert ErrInvalidReceipt();\n }\n if (!withdrawalLocked[_receipt.id]) {\n revert ErrQueryForApprovedWithdrawal();\n }\n delete withdrawalLocked[_receipt.id];\n emit WithdrawalUnlocked(_receiptHash, _receipt);\n\n address _token = _receipt.mainchain.tokenAddr;\n if (_receipt.info.erc == Token.Standard.ERC20) {\n Token.Info memory _feeInfo = _receipt.info;\n _feeInfo.quantity = _computeFeePercentage(_receipt.info.quantity, unlockFeePercentages[_token]);\n Token.Info memory _withdrawInfo = _receipt.info;\n _withdrawInfo.quantity = _receipt.info.quantity - _feeInfo.quantity;\n\n _feeInfo.handleAssetTransfer(payable(msg.sender), _token, wrappedNativeToken);\n _withdrawInfo.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n } else {\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _token, wrappedNativeToken);\n }\n\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function mapTokensAndThresholds(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards,\n // _thresholds[0]: highTierThreshold\n // _thresholds[1]: lockedThreshold\n // _thresholds[2]: unlockFeePercentages\n // _thresholds[3]: dailyWithdrawalLimit\n uint256[][4] calldata _thresholds\n ) external virtual onlyAdmin {\n if (_mainchainTokens.length == 0) revert ErrEmptyArray();\n _mapTokens(_mainchainTokens, _roninTokens, _standards);\n _setHighTierThresholds(_mainchainTokens, _thresholds[0]);\n _setLockedThresholds(_mainchainTokens, _thresholds[1]);\n _setUnlockFeePercentages(_mainchainTokens, _thresholds[2]);\n _setDailyWithdrawalLimits(_mainchainTokens, _thresholds[3]);\n }\n\n /**\n * @inheritdoc IMainchainGatewayV3\n */\n function getRoninToken(address _mainchainToken) public view returns (MappedToken memory _token) {\n _token = _roninToken[_mainchainToken];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps mainchain tokens to Ronin network.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _mainchainTokens,\n address[] calldata _roninTokens,\n Token.Standard[] calldata _standards\n ) internal virtual {\n if (!(_mainchainTokens.length == _roninTokens.length && _mainchainTokens.length == _standards.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _mainchainTokens.length; ) {\n _roninToken[_mainchainTokens[_i]].tokenAddr = _roninTokens[_i];\n _roninToken[_mainchainTokens[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_mainchainTokens, _roninTokens, _standards);\n }\n\n /**\n * @dev Submits withdrawal receipt.\n *\n * Requirements:\n * - The receipt kind is withdrawal.\n * - The receipt is to withdraw on this chain.\n * - The receipt is not used to withdraw before.\n * - The withdrawal is not reached the limit threshold.\n * - The signer weight total is larger than or equal to the minimum threshold.\n * - The signature signers are in order.\n *\n * Emits the `Withdrew` once the assets are released.\n *\n */\n function _submitWithdrawal(\n Transfer.Receipt calldata _receipt,\n Signature[] memory _signatures\n ) internal virtual returns (bool _locked) {\n uint256 _id = _receipt.id;\n uint256 _quantity = _receipt.info.quantity;\n address _tokenAddr = _receipt.mainchain.tokenAddr;\n\n _receipt.info.validate();\n if (_receipt.kind != Transfer.Kind.Withdrawal) revert ErrInvalidReceiptKind();\n\n if (_receipt.mainchain.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.mainchain.chainId, block.chainid);\n }\n\n MappedToken memory _token = getRoninToken(_receipt.mainchain.tokenAddr);\n\n if (!(_token.erc == _receipt.info.erc && _token.tokenAddr == _receipt.ronin.tokenAddr)) revert ErrInvalidReceipt();\n\n if (withdrawalHash[_id] != 0) revert ErrQueryForProcessedWithdrawal();\n\n if (!(_receipt.info.erc == Token.Standard.ERC721 || !_reachedWithdrawalLimit(_tokenAddr, _quantity))) {\n revert ErrReachedDailyWithdrawalLimit();\n }\n\n bytes32 _receiptHash = _receipt.hash();\n bytes32 _receiptDigest = Transfer.receiptDigest(_domainSeparator, _receiptHash);\n\n uint256 _minimumVoteWeight;\n (_minimumVoteWeight, _locked) = _computeMinVoteWeight(_receipt.info.erc, _tokenAddr, _quantity);\n\n {\n bool _passed;\n address _signer;\n address _lastSigner;\n Signature memory _sig;\n uint256 _weight;\n for (uint256 _i; _i < _signatures.length; ) {\n _sig = _signatures[_i];\n _signer = ecrecover(_receiptDigest, _sig.v, _sig.r, _sig.s);\n if (_lastSigner >= _signer) revert ErrInvalidOrder(msg.sig);\n\n _lastSigner = _signer;\n\n _weight += _getWeight(_signer);\n if (_weight >= _minimumVoteWeight) {\n _passed = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_passed) revert ErrQueryForInsufficientVoteWeight();\n withdrawalHash[_id] = _receiptHash;\n }\n\n if (_locked) {\n withdrawalLocked[_id] = true;\n emit WithdrawalLocked(_receiptHash, _receipt);\n return _locked;\n }\n\n _recordWithdrawal(_tokenAddr, _quantity);\n _receipt.info.handleAssetTransfer(payable(_receipt.mainchain.addr), _tokenAddr, wrappedNativeToken);\n emit Withdrew(_receiptHash, _receipt);\n }\n\n /**\n * @dev Requests deposit made by `_requester` address.\n *\n * Requirements:\n * - The token info is valid.\n * - The `msg.value` is 0 while depositing ERC20 token.\n * - The `msg.value` is equal to deposit quantity while depositing native token.\n *\n * Emits the `DepositRequested` event.\n *\n */\n function _requestDepositFor(Transfer.Request memory _request, address _requester) internal virtual {\n MappedToken memory _token;\n address _weth = address(wrappedNativeToken);\n\n _request.info.validate();\n if (_request.tokenAddr == address(0)) {\n if (_request.info.quantity != msg.value) revert ErrInvalidRequest();\n\n _token = getRoninToken(_weth);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.tokenAddr = _weth;\n } else {\n if (msg.value != 0) revert ErrInvalidRequest();\n\n _token = getRoninToken(_request.tokenAddr);\n if (_token.erc != _request.info.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n // Withdraw if token is WETH\n if (_weth == _request.tokenAddr) {\n IWETH(_weth).withdraw(_request.info.quantity);\n }\n }\n\n uint256 _depositId = depositCount++;\n Transfer.Receipt memory _receipt = _request.into_deposit_receipt(\n _requester,\n _depositId,\n _token.tokenAddr,\n roninChainId\n );\n\n emit DepositRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Returns the minimum vote weight for the token.\n */\n function _computeMinVoteWeight(\n Token.Standard _erc,\n address _token,\n uint256 _quantity\n ) internal virtual returns (uint256 _weight, bool _locked) {\n uint256 _totalWeight = _getTotalWeight();\n _weight = _minimumVoteWeight(_totalWeight);\n if (_erc == Token.Standard.ERC20) {\n if (highTierThreshold[_token] <= _quantity) {\n _weight = _highTierVoteWeight(_totalWeight);\n }\n _locked = _lockedWithdrawalRequest(_token, _quantity);\n }\n }\n\n /**\n * @dev Update domain seperator.\n */\n function _updateDomainSeparator() internal {\n /*\n * _domainSeparator = keccak256(\n * abi.encode(\n * keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\"),\n * keccak256(\"MainchainGatewayV2\"),\n * keccak256(\"2\"),\n * block.chainid,\n * address(this)\n * )\n * );\n */\n assembly {\n let ptr := mload(0x40)\n // keccak256(\"EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)\")\n mstore(ptr, 0x8b73c3c69bb8fe3d512ecc4cf759cc79239f7b179b0ffacaa9a75d522b39400f)\n // keccak256(\"MainchainGatewayV2\")\n mstore(add(ptr, 0x20), 0x159f52c1e3a2b6a6aad3950adf713516211484e0516dad685ea662a094b7c43b)\n // keccak256(\"2\")\n mstore(add(ptr, 0x40), 0xad7c5bef027816a800da1736444fb58a807ef4c9603b7848673f7e3a68eb14a5)\n mstore(add(ptr, 0x60), chainid())\n mstore(add(ptr, 0x80), address())\n sstore(_domainSeparator.slot, keccak256(ptr, 0xa0))\n }\n }\n\n /**\n * @dev Sets the WETH contract.\n *\n * Emits the `WrappedNativeTokenContractUpdated` event.\n *\n */\n function _setWrappedNativeTokenContract(IWETH _wrapedToken) internal {\n wrappedNativeToken = _wrapedToken;\n emit WrappedNativeTokenContractUpdated(_wrapedToken);\n }\n\n /**\n * @dev Receives ETH from WETH or creates deposit request.\n */\n function _fallback() internal virtual whenNotPaused {\n if (msg.sender != address(wrappedNativeToken)) {\n Transfer.Request memory _request;\n _request.recipientAddr = msg.sender;\n _request.info.quantity = msg.value;\n _requestDepositFor(_request, _request.recipientAddr);\n }\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Returns the weight of an address.\n */\n function _getWeight(address _addr) internal view returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperatorWeight(_addr);\n }\n}\n" + }, + "contracts/mocks/forwarder/MockForwarderTarget.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\n\nimport \"../../utils/CommonErrors.sol\";\n\ncontract MockForwarderTarget is RONTransferHelper {\n address public owner;\n uint256 public data;\n\n event TargetWithdrawn(address indexed _origin, address indexed _caller, address indexed _recipient);\n\n /**\n * @dev Error thrown intentionally for a specific purpose.\n */\n error ErrIntentionally();\n\n modifier onlyOwner() {\n if (msg.sender != owner) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _;\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n constructor(address _owner, uint256 _data) payable {\n owner = _owner;\n data = _data;\n }\n\n function foo(uint256 _data) external onlyOwner {\n data = _data;\n }\n\n function fooPayable(uint256 _data) external payable onlyOwner {\n data = _data;\n }\n\n function fooSilentRevert() external view onlyOwner {\n revert();\n }\n\n function fooCustomErrorRevert() external view onlyOwner {\n revert ErrIntentionally();\n }\n\n function fooRevert() external view onlyOwner {\n revert(\"MockForwarderContract: revert intentionally\");\n }\n\n function getBalance() external view returns (uint256) {\n return address(this).balance;\n }\n\n function withdrawAll() external onlyOwner {\n emit TargetWithdrawn(tx.origin, msg.sender, msg.sender);\n _transferRON(payable(msg.sender), address(this).balance);\n }\n\n function _fallback() private pure {\n revert(\"MockForwardTarget: hello from fallback\");\n }\n}\n" + }, + "contracts/mocks/libraries/Sorting.sol": { + "content": "// SPDX-License-Identifier: UNLICENSED\n\npragma solidity ^0.8.0;\n\nlibrary Sorting {\n struct Node {\n uint key;\n uint value;\n }\n\n struct Node3 {\n uint key;\n uint value;\n uint otherKey;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // VALUE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(uint[] memory data) internal pure returns (uint[] memory) {\n return _quickSort(data, int(0), int(data.length - 1));\n }\n\n function _quickSort(uint[] memory arr, int left, int right) private pure returns (uint[] memory) {\n int i = left;\n int j = right;\n if (i == j) return arr;\n uint pivot = arr[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (arr[uint(i)] > pivot) i++;\n while (pivot > arr[uint(j)]) j--;\n if (i <= j) {\n (arr[uint(i)], arr[uint(j)]) = (arr[uint(j)], arr[uint(i)]);\n i++;\n j--;\n }\n }\n if (left < j) arr = _quickSort(arr, left, j);\n if (i < right) arr = _quickSort(arr, i, right);\n\n return arr;\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sort(address[] memory _keys, uint256[] memory _values) internal pure returns (address[] memory) {\n require(_values.length == _keys.length, \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return _keys;\n }\n\n Node[] memory _nodes = new Node[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(uint256(uint160(_keys[_i])), _values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return _keys;\n }\n\n function sort(uint256[] memory keys, uint256[] memory values) internal pure returns (uint256[] memory) {\n require(values.length == keys.length, \"Sorting: invalid array length\");\n if (keys.length == 0) {\n return keys;\n }\n\n Node[] memory _nodes = new Node[](keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node(keys[_i], values[_i]);\n }\n _quickSortNodes(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n keys[_i] = _nodes[_i].key; // Casting?\n }\n\n return keys;\n }\n\n function sortNodes(Node[] memory nodes) internal pure returns (Node[] memory) {\n return _quickSortNodes(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNodes(Node[] memory nodes, int left, int right) private pure returns (Node[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNodes(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNodes(nodes, left, j);\n if (i < right) nodes = _quickSortNodes(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNodes(Node[] memory nodes) private pure returns (Node[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNodes(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNodes(Node memory x, Node memory y) private pure returns (Node memory, Node memory) {\n Node memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n\n ///////////////////////////////////////////////////////////////////////////////////////\n // NODE3 SORTING //\n ///////////////////////////////////////////////////////////////////////////////////////\n\n function sortWithExternalKeys(\n address[] memory _keys,\n uint256[] memory _values,\n uint256[] memory _otherKeys\n ) internal pure returns (address[] memory keys_, uint256[] memory otherKeys_) {\n require((_values.length == _keys.length) && (_otherKeys.length == _keys.length), \"Sorting: invalid array length\");\n if (_keys.length == 0) {\n return (_keys, _otherKeys);\n }\n\n Node3[] memory _nodes = new Node3[](_keys.length);\n for (uint256 _i; _i < _nodes.length; _i++) {\n _nodes[_i] = Node3(uint256(uint160(_keys[_i])), _values[_i], _otherKeys[_i]);\n }\n _quickSortNode3s(_nodes, int(0), int(_nodes.length - 1));\n\n for (uint256 _i; _i < _nodes.length; _i++) {\n _keys[_i] = address(uint160(_nodes[_i].key)); // Casting?\n }\n\n return (_keys, _otherKeys);\n }\n\n function sortNode3s(Node3[] memory nodes) internal pure returns (Node3[] memory) {\n return _quickSortNode3s(nodes, int(0), int(nodes.length - 1));\n }\n\n function _quickSortNode3s(Node3[] memory nodes, int left, int right) private pure returns (Node3[] memory) {\n int i = left;\n int j = right;\n if (i == j) return nodes;\n Node3 memory pivot = nodes[uint(left + (right - left) / 2)];\n while (i <= j) {\n while (nodes[uint(i)].value > pivot.value) i++;\n while (pivot.value > nodes[uint(j)].value) j--;\n if (i <= j) {\n (nodes[uint(i)], nodes[uint(j)]) = __swapNode3s(nodes[uint(i)], nodes[uint(j)]);\n i++;\n j--;\n }\n }\n if (left < j) nodes = _quickSortNode3s(nodes, left, j);\n if (i < right) nodes = _quickSortNode3s(nodes, i, right);\n\n return nodes;\n }\n\n function _bubbleSortNode3s(Node3[] memory nodes) private pure returns (Node3[] memory) {\n uint length = nodes.length;\n for (uint i = 0; i < length - 1; i++) {\n for (uint j = i + 1; j < length; j++) {\n if (nodes[j].value > nodes[i].value) {\n (nodes[i], nodes[j]) = __swapNode3s(nodes[i], nodes[j]);\n }\n }\n }\n return nodes;\n }\n\n function __swapNode3s(Node3 memory x, Node3 memory y) private pure returns (Node3 memory, Node3 memory) {\n Node3 memory tmp = x;\n (x, y) = (y, tmp);\n return (x, y);\n }\n}\n" + }, + "contracts/mocks/MockBridge.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol\";\nimport \"../interfaces/IBridge.sol\";\n\ncontract MockBridge is IBridge {\n /// @dev Mapping from validator address => last block that the bridge operator is added\n mapping(address => uint256) public bridgeOperatorAddedBlock;\n /// @dev Bridge operators array\n address[] public bridgeOperators;\n\n function replaceBridgeOperators(address[] calldata _list) external {\n address _addr;\n for (uint256 _i = 0; _i < _list.length; _i++) {\n _addr = _list[_i];\n if (bridgeOperatorAddedBlock[_addr] == 0) {\n bridgeOperators.push(_addr);\n }\n bridgeOperatorAddedBlock[_addr] = block.number;\n }\n\n {\n uint256 _i;\n while (_i < bridgeOperators.length) {\n _addr = bridgeOperators[_i];\n if (bridgeOperatorAddedBlock[_addr] < block.number) {\n delete bridgeOperatorAddedBlock[_addr];\n bridgeOperators[_i] = bridgeOperators[bridgeOperators.length - 1];\n bridgeOperators.pop();\n continue;\n }\n _i++;\n }\n }\n }\n\n function getBridgeOperators() external view override returns (address[] memory) {\n return bridgeOperators;\n }\n}\n" + }, + "contracts/mocks/MockGatewayForTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport { HasBridgeTrackingDeprecated } from \"../utils/DeprecatedSlots.sol\";\n\ncontract MockGatewayForTracking is HasContracts, HasBridgeTrackingDeprecated {\n constructor(address bridgeTrackingContract) {\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n }\n\n function sendBallot(IBridgeTracking.VoteKind kind, uint256 id, address[] memory voters) external {\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 i; i < voters.length; i++) {\n bridgeTrackingContract.recordVote(kind, id, voters[i]);\n }\n }\n\n function sendApprovedVote(IBridgeTracking.VoteKind kind, uint256 id) external {\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(kind, id);\n }\n}\n" + }, + "contracts/mocks/MockPrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./libraries/Sorting.sol\";\nimport \"../libraries/Math.sol\";\n\ncontract MockPrecompile {\n function sortValidators(\n address[] memory _validators,\n uint256[] memory _weights\n ) public pure returns (address[] memory) {\n return Sorting.sort(_validators, _weights);\n }\n\n function validatingDoubleSignProof(\n address /*consensusAddr*/,\n bytes calldata /*_header1*/,\n bytes calldata /*_header2*/\n ) public pure returns (bool _validEvidence) {\n return true;\n }\n\n function validateFinalityVoteProof(\n bytes calldata,\n uint256,\n bytes32[2] calldata,\n bytes[][2] calldata,\n bytes[2] calldata\n ) public pure returns (bool) {\n return true;\n }\n\n function pickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public pure returns (address[] memory _result) {\n (_result, _trustedWeights) = Sorting.sortWithExternalKeys(_candidates, _weights, _trustedWeights);\n uint256 _newValidatorCount = Math.min(_maxValidatorNumber, _result.length);\n _arrangeValidatorCandidates(_result, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n }\n\n /**\n * @dev Arranges the sorted candidates to list of validators, by asserting prioritized and non-prioritized candidates\n *\n * @param _candidates A sorted list of candidates\n */\n function _arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) internal pure {\n address[] memory _waitingCandidates = new address[](_candidates.length);\n uint _waitingCounter;\n uint _prioritySlotCounter;\n\n for (uint _i = 0; _i < _candidates.length; _i++) {\n if (_trustedWeights[_i] > 0 && _prioritySlotCounter < _maxPrioritizedValidatorNumber) {\n _candidates[_prioritySlotCounter++] = _candidates[_i];\n continue;\n }\n _waitingCandidates[_waitingCounter++] = _candidates[_i];\n }\n\n _waitingCounter = 0;\n for (uint _i = _prioritySlotCounter; _i < _newValidatorCount; _i++) {\n _candidates[_i] = _waitingCandidates[_waitingCounter++];\n }\n\n assembly {\n mstore(_candidates, _newValidatorCount)\n }\n }\n}\n" + }, + "contracts/mocks/MockSlashIndicatorExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockPrecompile.sol\";\nimport \"../ronin/slash-indicator/SlashIndicator.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\n\ncontract MockSlashIndicatorExtended is SlashIndicator, MockPrecompile {\n function slashFelony(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function slashMisdemeanor(address _validatorAddr) external {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execSlash(_validatorAddr, 0, 0, false);\n }\n\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal pure override returns (bool _validEvidence) {\n return validatingDoubleSignProof(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/MockStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../ronin/staking/RewardCalculation.sol\";\n\ncontract MockStaking is RewardCalculation, GlobalConfigConsumer {\n /// @dev Mapping from user => staking balance\n mapping(address => uint256) internal _stakingAmount;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n uint256 internal _stakingTotal;\n\n uint256 public lastUpdatedPeriod;\n uint256 public pendingReward;\n address public poolAddr;\n\n constructor(address _poolAddr) {\n poolAddr = _poolAddr;\n }\n\n function firstEverWrapup() external {\n delete pendingReward;\n lastUpdatedPeriod = block.timestamp / PERIOD_DURATION + 1;\n }\n\n function endPeriod() external {\n address[] memory _addrs = new address[](1);\n uint256[] memory _rewards = new uint256[](1);\n _addrs[0] = poolAddr;\n _rewards[0] = pendingReward;\n this.execRecordRewards(_addrs, _rewards);\n\n pendingReward = 0;\n lastUpdatedPeriod++;\n }\n\n function increasePeriod() external {\n lastUpdatedPeriod++;\n }\n\n function stake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount + _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal += _amount;\n }\n\n function unstake(address _user, uint256 _amount) external {\n uint256 _lastStakingAmount = _stakingAmount[_user];\n uint256 _newStakingAmount = _lastStakingAmount - _amount;\n _syncUserReward(poolAddr, _user, _newStakingAmount);\n _stakingAmount[_user] = _newStakingAmount;\n _stakingTotal -= _amount;\n }\n\n function increaseReward(uint256 _amount) external {\n pendingReward += _amount;\n }\n\n function decreaseReward(uint256 _amount) external {\n pendingReward -= _amount;\n }\n\n function execRecordRewards(address[] calldata _addrList, uint256[] calldata _rewards) external {\n _recordRewards(_addrList, _rewards, _currentPeriod());\n }\n\n function getPeriod() public view returns (uint256) {\n return _currentPeriod();\n }\n\n function claimReward(address _user) external returns (uint256 _amount) {\n _amount = _claimReward(poolAddr, _user, getPeriod());\n }\n\n function getStakingAmount(address, address _user) public view override returns (uint256) {\n return _stakingAmount[_user];\n }\n\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory) {}\n\n function getStakingTotal(address _addr) public view virtual override returns (uint256) {\n return _addr == poolAddr ? _stakingTotal : 0;\n }\n\n function _currentPeriod() internal view override returns (uint256 _period) {\n return lastUpdatedPeriod;\n }\n\n function getManyStakingTotals(address[] calldata _poolAddr) external view override returns (uint256[] memory) {}\n}\n" + }, + "contracts/mocks/MockTransferFallback.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.9;\n\nimport \"../extensions/RONTransferHelper.sol\";\n\ncontract MockPaymentFallback {\n event SafeReceived(address indexed sender, uint256 value);\n\n /// @dev Fallback function accepts ether transactions.\n receive() external payable {\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockPaymentFallbackExpensive {\n uint[] public array;\n event SafeReceived(address indexed sender, uint256 value);\n\n constructor() {\n array.push(0);\n }\n\n /// @dev Fallback function accepts ether transactions and set non-zero value to a zero value slot.\n receive() external payable {\n array.push(block.number);\n emit SafeReceived(msg.sender, msg.value);\n }\n}\n\ncontract MockTransfer is RONTransferHelper {\n uint256 public track;\n\n constructor() payable {}\n\n function fooTransfer(address payable _recipient, uint256 _amount, uint256 _gas) external {\n if (_unsafeSendRONLimitGas(_recipient, _amount, _gas)) {\n track++;\n }\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\n\ncontract MockPCUPickValidatorSet is PCUPickValidatorSet {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompilePickValidatorSetAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) public view returns (address[] memory _result) {\n (_result, ) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUSortValidators.sol\";\n\ncontract MockPCUSortValidators is PCUSortValidators {\n address internal _precompileSortValidatorAddress;\n\n constructor(address _precompile) {\n setPrecompileSortValidatorAddress(_precompile);\n }\n\n function setPrecompileSortValidatorAddress(address _addr) public {\n _precompileSortValidatorAddress = _addr;\n }\n\n function precompileSortValidatorsAddress() public view override returns (address) {\n return _precompileSortValidatorAddress;\n }\n\n function callPrecompile(\n address[] calldata _validators,\n uint256[] calldata _weights\n ) public view returns (address[] memory _result) {\n return _pcSortCandidates(_validators, _weights);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\n\ncontract MockPCUValidateDoubleSign is PCUValidateDoubleSign {\n address internal _precompileValidateDoubleSignAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateDoubleSignAddress(_precompile);\n }\n\n function setPrecompileValidateDoubleSignAddress(address _addr) public {\n _precompileValidateDoubleSignAddress = _addr;\n }\n\n function precompileValidateDoubleSignAddress() public view override returns (address) {\n return _precompileValidateDoubleSignAddress;\n }\n\n function callPrecompile(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) public view returns (bool) {\n return _pcValidateEvidence(_consensusAddr, _header1, _header2);\n }\n}\n" + }, + "contracts/mocks/precompile-usages/MockPCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\n\ncontract MockPCUValidateFastFinality is PCUValidateFastFinality {\n address internal _precompileValidateFastFinalityAddress;\n\n constructor(address _precompile) {\n setPrecompileValidateFastFinalityAddress(_precompile);\n }\n\n function setPrecompileValidateFastFinalityAddress(address _addr) public {\n _precompileValidateFastFinalityAddress = _addr;\n }\n\n function precompileValidateFastFinalityAddress() public view override returns (address) {\n return _precompileValidateFastFinalityAddress;\n }\n\n function callPrecompile(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) public view returns (bool) {\n return\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoleAccess, ContractType, AddressArrayUtils, IBridgeManager, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\n\ncontract MockBridgeManager is BridgeManager {\n constructor(\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights\n ) payable BridgeManager(0, 0, 0, address(0), _getEmptyAddressArray(), bridgeOperators, governors, voteWeights) {}\n\n function _getEmptyAddressArray() internal pure returns (address[] memory arr) {}\n}\n" + }, + "contracts/mocks/ronin/MockBridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeReward, BridgeReward } from \"../../ronin/gateway/BridgeReward.sol\";\n\ncontract MockBridgeReward is BridgeReward {\n function calcRewardAndCheckSlashedStatus(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 reward, bool isSlashed) {\n return\n _calcRewardAndCheckSlashedStatus(\n isValidTrackingResponse,\n numBridgeOperators,\n rewardPerPeriod,\n ballot,\n totalBallot,\n period,\n slashUntilPeriod\n );\n }\n\n function calcReward(\n bool isValidTrackingResponse,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) external pure returns (uint256 reward) {\n reward = _calcReward(isValidTrackingResponse, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n function isValidBridgeTrackingResponse(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external pure returns (bool valid) {\n return _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n }\n\n function shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) external returns (bool shareEqually) {\n return _shouldShareEqually(totalBallot, totalVote, ballots);\n }\n\n function shouldSlashedThisPeriod(uint256 period, uint256 slashUntilDuration) external pure returns (bool) {\n return _shouldSlashedThisPeriod(period, slashUntilDuration);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IBridgeSlash, BridgeSlash } from \"../../ronin/gateway/BridgeSlash.sol\";\n\ncontract MockBridgeSlash is BridgeSlash {\n function calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod\n ) external pure returns (uint256 newSlashUntilPeriod) {\n newSlashUntilPeriod = _calcSlashUntilPeriod(tier, period, slashUntilPeriod, _getPenaltyDurations());\n }\n\n function isSlashDurationMetRemovalThreshold(uint256 slashUntilPeriod, uint256 period) external pure returns (bool) {\n return _isSlashDurationMetRemovalThreshold(slashUntilPeriod, period);\n }\n}\n" + }, + "contracts/mocks/ronin/MockBridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n" + }, + "contracts/mocks/ronin/MockRoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { RoninBridgeManager } from \"../../ronin/gateway/RoninBridgeManager.sol\";\nimport { GlobalProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\n\ncontract MockRoninBridgeManager is RoninBridgeManager {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n RoninBridgeManager(\n num,\n denom,\n roninChainId,\n expiryDuration,\n bridgeContract,\n callbackRegisters,\n bridgeOperators,\n governors,\n voteWeights,\n targetOptions,\n targets\n )\n {}\n}\n" + }, + "contracts/mocks/ronin/MockRoninGatewayV3Extended.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../../ronin/gateway/RoninGatewayV3.sol\";\n\ncontract MockRoninGatewayV3Extended is RoninGatewayV3 {\n /*\n * @dev Returns the vote weight for a deposit based on its corressponding hash.\n */\n function getDepositVoteWeight(\n uint256 _chainId,\n uint256 _depositId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(depositVote[_chainId][_depositId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a mainchain withdrew acknowledgement based on its corressponding hash.\n */\n function getMainchainWithdrewVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(mainchainWithdrewVote[_withdrawalId], _hash);\n }\n\n /**\n * @dev Returns the vote weight for a withdraw stats based on its corressponding hash.\n */\n function getWithdrawalStatVoteWeight(\n uint256 _withdrawalId,\n bytes32 _hash\n ) external view returns (uint256 totalWeight) {\n totalWeight = _getVoteWeight(withdrawalStatVote[_withdrawalId], _hash);\n }\n}\n" + }, + "contracts/mocks/ronin/MockValidatorContract.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ncontract MockValidatorContract {\n uint256 private _currentPeriod;\n\n function currentPeriod() external view returns (uint256) {\n return _currentPeriod;\n }\n\n function setCurrentPeriod(uint256 period) external {\n _currentPeriod = period;\n }\n}\n" + }, + "contracts/mocks/sorting/MockSorting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/transparent/ProxyAdmin.sol\";\nimport \"../libraries/Sorting.sol\";\n\ncontract MockSorting {\n uint256[] public data;\n\n function addData(uint256[] memory _data) public {\n for (uint256 i; i < _data.length; i++) {\n data.push(_data[i]);\n }\n }\n\n function sort(uint256[] memory _data) public pure returns (uint256[] memory) {\n return Sorting.sort(_data);\n }\n\n function sortOnStorage() public returns (uint256[] memory, uint256) {\n uint256[] memory _tmpData = data;\n data = Sorting.sort(_tmpData);\n\n return (data, data.length);\n }\n\n function sortAddressesAndValues(\n address[] calldata _addrs,\n uint256[] calldata _values\n ) public pure returns (address[] memory) {\n return Sorting.sort(_addrs, _values);\n }\n}\n" + }, + "contracts/mocks/types/MockTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { TUint256Slot } from \"../../types/Types.sol\";\n\ncontract MockTUint256Slot {\n TUint256Slot private constant CUSTOM_SLOT_UINT256 =\n TUint256Slot.wrap(keccak256(abi.encode(type(MockTUint256Slot).name)));\n\n uint256 private _primitiveUint256;\n\n function subPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 - val;\n }\n\n function subCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.sub(val);\n }\n\n function divCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.div(val);\n }\n\n function divPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 / val;\n }\n\n function mulCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.mul(val);\n }\n\n function mulPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 * val;\n }\n\n function addPrimitive(uint256 val) external view returns (uint256 res) {\n res = _primitiveUint256 + val;\n }\n\n function addCustomSlot(uint256 val) external view returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.add(val);\n }\n\n function preIncrementPrimitive() external returns (uint256 res) {\n res = ++_primitiveUint256;\n }\n\n function preIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preIncrement();\n }\n\n function postIncrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256++;\n }\n\n function postIncrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postIncrement();\n }\n\n function preDecrementPrimitive() external returns (uint256 res) {\n res = --_primitiveUint256;\n }\n\n function preDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.preDecrement();\n }\n\n function postDecrementPrimitive() external returns (uint256 res) {\n res = _primitiveUint256--;\n }\n\n function postDecrementCustomSlot() external returns (uint256 res) {\n res = CUSTOM_SLOT_UINT256.postDecrement();\n }\n\n function setCustomSlot(uint256 val) external returns (uint256 stored) {\n CUSTOM_SLOT_UINT256.store(val);\n stored = CUSTOM_SLOT_UINT256.load();\n }\n\n function setPrimitive(uint256 val) external returns (uint256 stored) {\n _primitiveUint256 = val;\n stored = _primitiveUint256;\n }\n\n function subAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.subAssign(val);\n }\n\n function subAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 -= val;\n }\n\n function addAssignCustomSlot(uint256 val) external returns (uint256 stored) {\n stored = CUSTOM_SLOT_UINT256.addAssign(val);\n }\n\n function addAssignPrimitive(uint256 val) external returns (uint256 stored) {\n stored = _primitiveUint256 += val;\n }\n\n function getPrimitive() external view returns (uint256) {\n return _primitiveUint256;\n }\n\n function getCustomSlot() external view returns (uint256) {\n return CUSTOM_SLOT_UINT256.load();\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockActor.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ErrorHandler } from \"../../../libraries/ErrorHandler.sol\";\n\ncontract MockActor {\n using ErrorHandler for bool;\n\n address private _target;\n\n constructor(address target) {\n _target = target;\n }\n\n fallback() external payable {\n (bool success, bytes memory returnOrRevertData) = _target.call{ value: msg.value }(msg.data);\n success.handleRevert(msg.sig, returnOrRevertData);\n assembly {\n return(add(returnOrRevertData, 0x20), mload(returnOrRevertData))\n }\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockConditionalImplementControl.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\n\ncontract MockConditionalImplementControl is ConditionalImplementControl {\n uint256 public immutable UPGRADED_AT_BLOCK;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n uint256 upgradedAtBlock\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n UPGRADED_AT_BLOCK = upgradedAtBlock;\n }\n\n function _isConditionMet() internal view override returns (bool) {\n return block.number >= UPGRADED_AT_BLOCK;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogic.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogic {\n event Received(uint256 version);\n\n function name() external pure returns (string memory);\n\n function magicNumber() external view returns (uint256);\n\n function get() external view returns (uint256);\n\n function set() external;\n\n function setAndGet() external returns (uint256);\n}\n\nabstract contract MockLogicBase is ILogic {\n uint256 internal _value;\n\n function magicNumber() public view virtual override returns (uint256) {}\n\n receive() external payable virtual {\n emit Received(0);\n }\n\n function get() public view returns (uint256) {\n return _value;\n }\n\n function set() public override {\n _value = magicNumber();\n }\n\n function setAndGet() public returns (uint256) {\n set();\n return get();\n }\n}\n\ncontract MockLogicV1 is MockLogicBase {\n receive() external payable override {\n emit Received(1);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV1\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 1;\n }\n}\n\ncontract MockLogicV2 is MockLogicBase {\n receive() external payable override {\n emit Received(2);\n }\n\n function name() external pure returns (string memory) {\n return \"LogicV2\";\n }\n\n function magicNumber() public pure override returns (uint256) {\n return 2;\n }\n}\n" + }, + "contracts/mocks/utils/version-control/MockLogicValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\ninterface ILogicValidatorSet {\n event Received(string version);\n\n function wrapUpEpoch() external payable;\n\n function version() external view returns (string memory);\n\n function currentPeriod() external view returns (uint256);\n}\n\nabstract contract MockLogicValidatorSetCore is ILogicValidatorSet {\n uint256 private _lastUpdatedPeriod;\n\n receive() external payable virtual {\n emit Received(\"0\");\n }\n\n function wrapUpEpoch() external payable {\n if (block.number % 100 == 0) {\n _lastUpdatedPeriod += 1;\n }\n }\n\n function currentPeriod() external view returns (uint256) {\n return _lastUpdatedPeriod;\n }\n}\n\ncontract MockLogicValidatorSetV1 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V1\";\n }\n}\n\ncontract MockLogicValidatorSetV2 is MockLogicValidatorSetCore {\n receive() external payable override {\n emit Received(version());\n }\n\n function version() public pure returns (string memory) {\n return \"V2\";\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetExtended.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./MockRoninValidatorSetOverridePrecompile.sol\";\nimport \"../../libraries/EnumFlags.sol\";\n\ncontract MockRoninValidatorSetExtended is MockRoninValidatorSetOverridePrecompile {\n bool private _initialized;\n uint256[] internal _epochs;\n\n constructor() {}\n\n function initEpoch() public {\n if (!_initialized) {\n _epochs.push(0);\n _initialized = true;\n }\n }\n\n function endEpoch() external {\n _epochs.push(block.number);\n }\n\n function epochOf(uint256 _block) public view override returns (uint256 _epoch) {\n for (uint256 _i = _epochs.length; _i > 0; _i--) {\n if (_block > _epochs[_i - 1]) {\n return _i;\n }\n }\n }\n\n function epochEndingAt(uint256 _block) public view override(ITimingInfo, TimingStorage) returns (bool) {\n for (uint _i = 0; _i < _epochs.length; _i++) {\n if (_block == _epochs[_i]) {\n return true;\n }\n }\n return false;\n }\n\n function getJailUntils(address[] calldata _addrs) public view returns (uint256[] memory jailUntils_) {\n jailUntils_ = new uint256[](_addrs.length);\n for (uint _i = 0; _i < _addrs.length; _i++) {\n jailUntils_[_i] = _blockProducerJailedBlock[_addrs[_i]];\n }\n }\n\n function addValidators(address[] calldata _addrs) public {\n for (uint _i = 0; _i < _addrs.length; _i++) {\n _validators[_i] = _addrs[_i];\n _validatorMap[_addrs[_i]] = EnumFlags.ValidatorFlag.Both;\n }\n }\n}\n" + }, + "contracts/mocks/validator/MockRoninValidatorSetOverridePrecompile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../MockPrecompile.sol\";\nimport \"../../ronin/validator/RoninValidatorSet.sol\";\n\ncontract MockRoninValidatorSetOverridePrecompile is RoninValidatorSet, MockPrecompile {\n constructor() {}\n\n function arrangeValidatorCandidates(\n address[] memory _candidates,\n uint256[] memory _trustedWeights,\n uint _newValidatorCount,\n uint _maxPrioritizedValidatorNumber\n ) external pure returns (address[] memory) {\n _arrangeValidatorCandidates(_candidates, _trustedWeights, _newValidatorCount, _maxPrioritizedValidatorNumber);\n return _candidates;\n }\n\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal pure override returns (address[] memory _result) {\n return sortValidators(_candidates, _weights);\n }\n\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal pure override returns (address[] memory _result, uint256 _newValidatorCount) {\n _result = pickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/mocks/validator/MockValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../ronin/validator/CandidateManager.sol\";\nimport { HasStakingVestingDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract MockValidatorSet is\n IRoninValidatorSet,\n CandidateManager,\n HasStakingVestingDeprecated,\n HasSlashIndicatorDeprecated\n{\n uint256 internal _lastUpdatedPeriod;\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev Mapping from period number => slashed\n mapping(uint256 => bool) internal _periodSlashed;\n\n constructor(\n address __stakingContract,\n address _slashIndicatorContract,\n address _stakingVestingContract,\n uint256 __maxValidatorCandidate,\n uint256 __numberOfBlocksInEpoch,\n uint256 __minEffectiveDaysOnwards\n ) {\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.SLASH_INDICATOR, _slashIndicatorContract);\n _setContract(ContractType.STAKING_VESTING, _stakingVestingContract);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n _minEffectiveDaysOnwards = __minEffectiveDaysOnwards;\n }\n\n function submitBlockReward() external payable override {}\n\n function wrapUpEpoch() external payable override {\n _syncCandidateSet(_lastUpdatedPeriod + 1);\n _lastUpdatedPeriod = currentPeriod();\n }\n\n function getLastUpdatedBlock() external view override returns (uint256) {}\n\n function checkManyJailed(address[] calldata) external view override returns (bool[] memory) {}\n\n function checkMiningRewardDeprecatedAtPeriod(address, uint256 _period) external view override returns (bool) {}\n\n function checkMiningRewardDeprecated(address) external view override returns (bool) {}\n\n function checkBridgeRewardDeprecatedAtPeriod(\n address _consensusAddr,\n uint256 _period\n ) external view returns (bool _result) {}\n\n function epochOf(uint256 _block) external view override returns (uint256) {}\n\n function getValidators() external view override returns (address[] memory) {}\n\n function epochEndingAt(uint256 _block) external view override returns (bool) {}\n\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override {}\n\n function execBailOut(address, uint256) external override {}\n\n function setMaxValidatorNumber(uint256 _maxValidatorNumber) external override {}\n\n function setMaxPrioritizedValidatorNumber(uint256 _maxPrioritizedValidatorNumber) external override {}\n\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {}\n\n function maxPrioritizedValidatorNumber()\n external\n view\n override\n returns (uint256 _maximumPrioritizedValidatorNumber)\n {}\n\n function numberOfBlocksInEpoch() public view override returns (uint256) {\n return _numberOfBlocksInEpoch;\n }\n\n function getBlockProducers() external view override returns (address[] memory) {}\n\n function isBlockProducer(address) external pure override returns (bool) {\n return true;\n }\n\n function totalBlockProducer() external view override returns (uint256) {}\n\n function tryGetPeriodOfEpoch(uint256) external view returns (bool, uint256) {}\n\n function isPeriodEnding() public view virtual returns (bool) {\n return currentPeriod() > _lastUpdatedPeriod;\n }\n\n function currentPeriod() public view override returns (uint256) {\n return block.timestamp / 86400;\n }\n\n function checkJailed(address) external view override returns (bool) {}\n\n function getJailedTimeLeft(address) external view override returns (bool, uint256, uint256) {}\n\n function currentPeriodStartAtBlock() external view override returns (uint256) {}\n\n function checkJailedAtBlock(address _addr, uint256 _blockNum) external view override returns (bool) {}\n\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {}\n\n function totalDeprecatedReward() external view override returns (uint256) {}\n\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external override {}\n\n function emergencyExitLockedAmount() external override returns (uint256) {}\n\n function emergencyExpiryDuration() external override returns (uint256) {}\n\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external override {}\n\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external override {}\n\n function getEmergencyExitInfo(address _consensusAddr) external view override returns (EmergencyExitInfo memory) {}\n\n function execEmergencyExit(address, uint256) external {}\n\n function isOperatingBridge(address) external view returns (bool) {}\n\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {}\n\n function _isTrustedOrg(address _consensusAddr) internal virtual override returns (bool) {}\n}\n" + }, + "contracts/multi-chains/RoninTrustedOrganization.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../libraries/AddressArrayUtils.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../extensions/collections/HasProxyAdmin.sol\";\n\ncontract RoninTrustedOrganization is IRoninTrustedOrganization, HasProxyAdmin, Initializable {\n uint256 internal _num;\n uint256 internal _denom;\n uint256 internal _totalWeight;\n uint256 internal _nonce;\n\n /// @dev Mapping from consensus address => weight\n mapping(address => uint256) internal _consensusWeight;\n /// @dev Mapping from governor address => weight\n mapping(address => uint256) internal _governorWeight;\n /// @dev Mapping from bridge voter address => weight\n mapping(address => uint256) internal _bridgeVoterWeight;\n\n /// @dev Mapping from consensus address => added block\n mapping(address => uint256) internal _addedBlock;\n\n /// @dev Consensus array\n address[] internal _consensusList;\n /// @dev Governors array\n address[] internal _governorList;\n /// @dev Bridge voters array\n address[] internal _bridgeVoterList;\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n TrustedOrganization[] calldata _trustedOrgs,\n uint256 __num,\n uint256 __denom\n ) external initializer {\n if (_trustedOrgs.length > 0) {\n _addTrustedOrganizations(_trustedOrgs);\n }\n _setThreshold(__num, __denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function getThreshold() external view virtual returns (uint256 num_, uint256 denom_) {\n return (_num, _denom);\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function checkThreshold(uint256 _voteWeight) external view virtual returns (bool) {\n return _voteWeight * _denom >= _num * _totalWeight;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function minimumVoteWeight() external view virtual returns (uint256) {\n return (_num * _totalWeight + _denom - 1) / _denom;\n }\n\n /**\n * @inheritdoc IQuorum\n */\n function setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) external override onlyAdmin returns (uint256, uint256) {\n return _setThreshold(_numerator, _denominator);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function addTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n _addTrustedOrganizations(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function updateTrustedOrganizations(TrustedOrganization[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n for (uint256 _i; _i < _list.length; ) {\n _updateTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsUpdated(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function removeTrustedOrganizations(address[] calldata _list) external override onlyAdmin {\n if (_list.length == 0) revert ErrEmptyArray();\n\n for (uint _i = 0; _i < _list.length; ) {\n _removeTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsRemoved(_list);\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function totalWeight() external view virtual returns (uint256) {\n return _totalWeight;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeight(address _consensusAddr) external view returns (uint256) {\n return _consensusWeight[_consensusAddr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeight(address _governor) external view returns (uint256) {\n return _governorWeight[_governor];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeight(address _addr) external view returns (uint256) {\n return _bridgeVoterWeight[_addr];\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getConsensusWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getGovernorWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getBridgeVoterWeights(address[] calldata _list) external view returns (uint256[] memory _res) {\n _res = new uint256[](_list.length);\n for (uint _i = 0; _i < _res.length; ) {\n _res[_i] = _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumConsensusWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _consensusWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumGovernorWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _governorWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function sumBridgeVoterWeight(address[] calldata _list) external view returns (uint256 _res) {\n for (uint _i = 0; _i < _list.length; ) {\n _res += _bridgeVoterWeight[_list[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function countTrustedOrganization() external view override returns (uint256) {\n return _consensusList.length;\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getAllTrustedOrganizations() external view override returns (TrustedOrganization[] memory _list) {\n _list = new TrustedOrganization[](_consensusList.length);\n address _addr;\n for (uint256 _i; _i < _list.length; ) {\n _addr = _consensusList[_i];\n _list[_i].consensusAddr = _addr;\n _list[_i].governor = _governorList[_i];\n _list[_i].bridgeVoter = _bridgeVoterList[_i];\n _list[_i].weight = _consensusWeight[_addr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganization(address _consensusAddr) external view returns (TrustedOrganization memory) {\n for (uint _i = 0; _i < _consensusList.length; ) {\n if (_consensusList[_i] == _consensusAddr) {\n return getTrustedOrganizationAt(_i);\n }\n\n unchecked {\n ++_i;\n }\n }\n revert ErrQueryForNonExistentConsensusAddress();\n }\n\n /**\n * @inheritdoc IRoninTrustedOrganization\n */\n function getTrustedOrganizationAt(uint256 _idx) public view override returns (TrustedOrganization memory) {\n address _addr = _consensusList[_idx];\n return\n TrustedOrganization(\n _addr,\n _governorList[_idx],\n _bridgeVoterList[_idx],\n _consensusWeight[_addr],\n _addedBlock[_addr]\n );\n }\n\n /**\n * @dev Adds a list of trusted organizations.\n */\n function _addTrustedOrganizations(TrustedOrganization[] calldata _list) internal virtual {\n for (uint256 _i; _i < _list.length; ) {\n _addTrustedOrganization(_list[_i]);\n\n unchecked {\n ++_i;\n }\n }\n emit TrustedOrganizationsAdded(_list);\n }\n\n /**\n * @dev Adds a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is not added.\n * - The govenor address is not added.\n * - The bridge voter address is not added.\n *\n */\n function _addTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n if (_v.addedBlock != 0) revert ErrInvalidRequest();\n _sanityCheckTrustedOrganizationData(_v);\n\n if (_consensusWeight[_v.consensusAddr] > 0) revert ErrConsensusAddressIsAlreadyAdded(_v.consensusAddr);\n\n if (_governorWeight[_v.governor] > 0) revert ErrGovernorAddressIsAlreadyAdded(_v.governor);\n\n if (_bridgeVoterWeight[_v.bridgeVoter] > 0) revert ErrBridgeVoterIsAlreadyAdded(_v.bridgeVoter);\n\n _consensusList.push(_v.consensusAddr);\n _consensusWeight[_v.consensusAddr] = _v.weight;\n\n _governorList.push(_v.governor);\n _governorWeight[_v.governor] = _v.weight;\n\n _bridgeVoterList.push(_v.bridgeVoter);\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n\n _addedBlock[_v.consensusAddr] = block.number;\n\n _totalWeight += _v.weight;\n }\n\n /**\n * @dev Updates a trusted organization.\n *\n * Requirements:\n * - The weight is larger than 0.\n * - The consensus address is already added.\n *\n */\n function _updateTrustedOrganization(TrustedOrganization memory _v) internal virtual {\n _sanityCheckTrustedOrganizationData(_v);\n\n uint256 _weight = _consensusWeight[_v.consensusAddr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_v.consensusAddr);\n\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _v.consensusAddr) {\n _totalWeight -= _weight;\n _totalWeight += _v.weight;\n\n if (_governorList[_i] != _v.governor) {\n if (_governorWeight[_v.governor] != 0) revert ErrQueryForDupplicated();\n\n delete _governorWeight[_governorList[_i]];\n _governorList[_i] = _v.governor;\n }\n\n if (_bridgeVoterList[_i] != _v.bridgeVoter) {\n if (_bridgeVoterWeight[_v.bridgeVoter] != 0) revert ErrQueryForDupplicated();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_i]];\n _bridgeVoterList[_i] = _v.bridgeVoter;\n }\n\n _consensusWeight[_v.consensusAddr] = _v.weight;\n _governorWeight[_v.governor] = _v.weight;\n _bridgeVoterWeight[_v.bridgeVoter] = _v.weight;\n return;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Removes a trusted organization.\n *\n * Requirements:\n * - The consensus address is added.\n *\n */\n function _removeTrustedOrganization(address _addr) internal virtual {\n uint256 _weight = _consensusWeight[_addr];\n if (_weight == 0) revert ErrConsensusAddressIsNotAdded(_addr);\n\n uint256 _index;\n uint256 _count = _consensusList.length;\n for (uint256 _i = 0; _i < _count; ) {\n if (_consensusList[_i] == _addr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n _totalWeight -= _weight;\n\n delete _addedBlock[_addr];\n delete _consensusWeight[_addr];\n _consensusList[_index] = _consensusList[_count - 1];\n _consensusList.pop();\n\n delete _governorWeight[_governorList[_index]];\n _governorList[_index] = _governorList[_count - 1];\n _governorList.pop();\n\n delete _bridgeVoterWeight[_bridgeVoterList[_index]];\n _bridgeVoterList[_index] = _bridgeVoterList[_count - 1];\n _bridgeVoterList.pop();\n }\n\n /**\n * @dev Sets threshold and returns the old one.\n *\n * Emits the `ThresholdUpdated` event.\n *\n */\n function _setThreshold(\n uint256 _numerator,\n uint256 _denominator\n ) internal virtual returns (uint256 _previousNum, uint256 _previousDenom) {\n if (_numerator > _denominator) revert ErrInvalidThreshold(msg.sig);\n\n _previousNum = _num;\n _previousDenom = _denom;\n _num = _numerator;\n _denom = _denominator;\n unchecked {\n emit ThresholdUpdated(_nonce++, _numerator, _denominator, _previousNum, _previousDenom);\n }\n }\n\n /**\n * @dev Hook that checks trusted organization's data. Reverts if the requirements are not met.\n *\n * Requirements:\n * - The weight must be larger than 0.\n * - The consensus address, governor address, and bridge voter address are different.\n */\n function _sanityCheckTrustedOrganizationData(TrustedOrganization memory _v) private pure {\n if (_v.weight == 0) revert ErrInvalidVoteWeight(msg.sig);\n\n address[] memory _addresses = new address[](3);\n _addresses[0] = _v.consensusAddr;\n _addresses[1] = _v.governor;\n _addresses[2] = _v.bridgeVoter;\n\n if (AddressArrayUtils.hasDuplicate(_addresses)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n}\n" + }, + "contracts/precompile-usages/PCUPickValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUPickValidatorSet is PrecompiledUsage {\n /// @dev Gets the address of the precompile of picking validator set\n function precompilePickValidatorSetAddress() public view virtual returns (address) {\n return address(0x68);\n }\n\n /**\n * @dev Sorts and arranges to return a new validator set.\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcPickValidatorSet(\n address[] memory _candidates,\n uint256[] memory _weights,\n uint256[] memory _trustedWeights,\n uint256 _maxValidatorNumber,\n uint256 _maxPrioritizedValidatorNumber\n ) internal view virtual returns (address[] memory _result, uint256 _newValidatorCount) {\n address _smc = precompilePickValidatorSetAddress();\n bytes memory _payload = abi.encodeWithSignature(\n \"pickValidatorSet(address[],uint256[],uint256[],uint256,uint256)\",\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n bool _success = true;\n\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n\n _newValidatorCount = _result.length;\n }\n}\n" + }, + "contracts/precompile-usages/PCUSortValidators.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUSortValidators is PrecompiledUsage {\n /// @dev Gets the address of the precompile of sorting validators\n function precompileSortValidatorsAddress() public view virtual returns (address) {\n return address(0x66);\n }\n\n /**\n * @dev Sorts candidates descending by their weights by calling precompile contract.\n *\n * Note: This function is marked as virtual for being wrapping in mock contract for testing purpose.\n */\n function _pcSortCandidates(\n address[] memory _candidates,\n uint256[] memory _weights\n ) internal view virtual returns (address[] memory _result) {\n address _smc = precompileSortValidatorsAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\"sortValidators(address[],uint256[])\", _candidates, _weights);\n uint256 _payloadLength = _payload.length;\n uint256 _resultLength = 0x20 * _candidates.length + 0x40;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _result, _resultLength)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n\n _result := add(_result, 0x20)\n }\n\n if (!_success) revert ErrCallPrecompiled();\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateDoubleSign is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateDoubleSignAddress() public view virtual returns (address) {\n return address(0x67);\n }\n\n /**\n * @dev Validates the two submitted block header if they are produced by the same address\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateEvidence(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) internal view virtual returns (bool _validEvidence) {\n address _smc = precompileValidateDoubleSignAddress();\n bool _success = true;\n\n bytes memory _payload = abi.encodeWithSignature(\n \"validatingDoubleSignProof(address,bytes,bytes)\",\n _consensusAddr,\n _header1,\n _header2\n );\n uint _payloadLength = _payload.length;\n uint[1] memory _output;\n\n assembly {\n let _payloadStart := add(_payload, 0x20)\n if iszero(staticcall(gas(), _smc, _payloadStart, _payloadLength, _output, 0x20)) {\n _success := 0\n }\n\n if iszero(returndatasize()) {\n _success := 0\n }\n }\n\n if (!_success) revert ErrCallPrecompiled();\n return (_output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PCUValidateFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PCUValidateFastFinality is PrecompiledUsage {\n /// @dev Gets the address of the precompile of validating double sign evidence\n function precompileValidateFastFinalityAddress() public view virtual returns (address) {\n return address(0x69);\n }\n\n /**\n * @dev Validates the proof of malicious voting on fast finality\n *\n * Note: The recover process is done by pre-compiled contract. This function is marked as\n * virtual for implementing mocking contract for testing purpose.\n */\n function _pcValidateFastFinalityEvidence(\n bytes memory voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] memory targetBlockHash,\n bytes[][2] memory listOfPublicKey,\n bytes[2] memory aggregatedSignature\n ) internal view virtual returns (bool validEvidence) {\n address smc = precompileValidateFastFinalityAddress();\n bool success = true;\n\n bytes memory payload = abi.encodeWithSignature(\n \"validateFinalityVoteProof(bytes,uint256,bytes32[2],bytes[][2],bytes[2])\",\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n );\n uint payloadLength = payload.length;\n uint[1] memory output;\n\n assembly {\n let payloadStart := add(payload, 0x20)\n if iszero(staticcall(gas(), smc, payloadStart, payloadLength, output, 0x20)) {\n success := 0\n }\n\n if iszero(returndatasize()) {\n success := 0\n }\n }\n\n if (!success) revert ErrCallPrecompiled();\n return (output[0] != 0);\n }\n}\n" + }, + "contracts/precompile-usages/PrecompiledUsage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./PrecompiledUsage.sol\";\n\nabstract contract PrecompiledUsage {\n /// @dev Error of call to precompile fails.\n error ErrCallPrecompiled();\n}\n" + }, + "contracts/ronin/fast-finality/FastFinalityTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IFastFinalityTracking } from \"../..//interfaces/IFastFinalityTracking.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\ncontract FastFinalityTracking is IFastFinalityTracking, Initializable, HasContracts {\n /// @dev Mapping from epoch number => consensus address => number of QC vote\n mapping(uint256 => mapping(address => uint256)) internal _tracker;\n /// @dev The latest block that tracked the QC vote\n uint256 internal _latestTrackingBlock;\n\n modifier oncePerBlock() {\n if (block.number <= _latestTrackingBlock) {\n revert ErrOncePerBlock();\n }\n\n _latestTrackingBlock = block.number;\n _;\n }\n\n modifier onlyCoinbase() {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function recordFinality(address[] calldata voters) external override oncePerBlock onlyCoinbase {\n uint256 currentEpoch = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).epochOf(block.number);\n\n for (uint i; i < voters.length; ) {\n unchecked {\n ++_tracker[currentEpoch][voters[i]];\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IFastFinalityTracking\n */\n function getManyFinalityVoteCounts(\n uint256 epoch,\n address[] calldata addrs\n ) external view override returns (uint256[] memory voteCounts) {\n uint256 length = addrs.length;\n voteCounts = new uint256[](length);\n for (uint i; i < length; ) {\n voteCounts[i] = _tracker[epoch][addrs[i]];\n unchecked {\n ++i;\n }\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeReward.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { ContractType, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { RONTransferHelper } from \"../../extensions/RONTransferHelper.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { TUint256Slot } from \"../../types/Types.sol\";\nimport { ErrSyncTooFarPeriod, ErrInvalidArguments, ErrLengthMismatch, ErrUnauthorizedCall } from \"../../utils/CommonErrors.sol\";\n\ncontract BridgeReward is IBridgeReward, BridgeTrackingHelper, HasContracts, RONTransferHelper, Initializable {\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardInfo.slot\") - 1\n bytes32 private constant REWARD_INFO_SLOT = 0x518cfd198acbffe95e740cfce1af28a3f7de51f0d784893d3d72c5cc59d7062a;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.rewardPerPeriod.slot\") - 1\n TUint256Slot private constant REWARD_PER_PERIOD_SLOT =\n TUint256Slot.wrap(0x90f7d557245e5dd9485f463e58974fa7cdc93c0abbd0a1afebb8f9640ec73910);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.latestRewardedPeriod.slot\") - 1\n TUint256Slot private constant LATEST_REWARDED_PERIOD_SLOT =\n TUint256Slot.wrap(0x2417f25874c1cdc139a787dd21df976d40d767090442b3a2496917ecfc93b619);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardToppedUp.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_TOPPED_UP_SLOT =\n TUint256Slot.wrap(0x9a8c9f129792436c37b7bd2d79c56132fc05bf26cc8070794648517c2a0c6c64);\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeReward.totalRewardScattered.slot\") - 1\n TUint256Slot private constant TOTAL_REWARDS_SCATTERED_SLOT =\n TUint256Slot.wrap(0x3663384f6436b31a97d9c9a02f64ab8b73ead575c5b6224fa0800a6bd57f62f4);\n\n address private immutable _self;\n\n constructor() payable {\n _self = address(this);\n _disableInitializers();\n }\n\n function initialize(\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address bridgeSlashContract,\n address validatorSetContract,\n address dposGA,\n uint256 rewardPerPeriod\n ) external payable initializer {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlashContract);\n _setContract(ContractType.VALIDATOR, validatorSetContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n LATEST_REWARDED_PERIOD_SLOT.store(type(uint256).max);\n _setRewardPerPeriod(rewardPerPeriod);\n _receiveRON();\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2: `_lastSyncPeriod` == `{BridgeReward}.latestRewardedPeriod` == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(getLatestRewardedPeriod() == type(uint256).max, \"already init rep 2\");\n LATEST_REWARDED_PERIOD_SLOT.store(IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() - 1);\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function receiveRON() external payable {\n _receiveRON();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function syncReward(uint256 periodLength) external {\n if (!_isBridgeOperator(msg.sender)) revert ErrUnauthorizedCall(msg.sig);\n\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n if (currentPeriod <= latestRewardedPeriod) revert ErrInvalidArguments(msg.sig);\n if (latestRewardedPeriod + periodLength > currentPeriod) revert ErrInvalidArguments(msg.sig);\n\n LATEST_REWARDED_PERIOD_SLOT.addAssign(periodLength);\n\n address[] memory operators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n IBridgeTracking bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n\n for (uint256 i = 1; i <= periodLength; ) {\n unchecked {\n _syncReward({\n operators: operators,\n ballots: bridgeTrackingContract.getManyTotalBallots(latestRewardedPeriod, operators),\n totalBallot: bridgeTrackingContract.totalBallot(latestRewardedPeriod),\n totalVote: bridgeTrackingContract.totalVote(latestRewardedPeriod),\n period: latestRewardedPeriod += i\n });\n\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n *\n * @dev The `period` a.k.a. `latestSyncedPeriod` must equal to `latestRewardedPeriod` + 1.\n */\n function execSyncReward(\n address[] calldata operators,\n uint256[] calldata ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n\n // Only sync the period that is after the latest rewarded period, i.e. `latestSyncedPeriod == latestRewardedPeriod + 1`.\n unchecked {\n uint256 latestRewardedPeriod = getLatestRewardedPeriod();\n if (period < latestRewardedPeriod + 1) revert ErrInvalidArguments(msg.sig);\n else if (period > latestRewardedPeriod + 1) revert ErrSyncTooFarPeriod(period, latestRewardedPeriod);\n }\n LATEST_REWARDED_PERIOD_SLOT.store(period);\n\n _syncReward({\n operators: operators,\n ballots: ballots,\n totalBallot: totalBallot,\n totalVote: totalVote,\n period: period\n });\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardToppedUp() external view returns (uint256) {\n return TOTAL_REWARDS_TOPPED_UP_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getTotalRewardScattered() external view returns (uint256) {\n return TOTAL_REWARDS_SCATTERED_SLOT.load();\n }\n\n /**\n * @dev Internal function to receive RON tokens as rewards and update the total topped-up rewards amount.\n */\n function _receiveRON() internal {\n // prevent transfer RON directly to logic contract\n if (address(this) == _self) revert ErrUnauthorizedCall(msg.sig);\n\n emit SafeReceived(msg.sender, TOTAL_REWARDS_TOPPED_UP_SLOT.load(), msg.value);\n TOTAL_REWARDS_TOPPED_UP_SLOT.addAssign(msg.value);\n }\n\n /**\n * @dev Internal function to synchronize and distribute rewards to bridge operators for a given period.\n * @param operators An array containing the addresses of bridge operators to receive rewards.\n * @param ballots An array containing the individual ballot counts for each bridge operator.\n * @param totalBallot The total number of available ballots for the period.\n * @param totalVote The total number of votes recorded for the period.\n * @param period The period for which the rewards are being synchronized.\n */\n function _syncReward(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) internal {\n uint256 numBridgeOperators = operators.length;\n uint256 rewardPerPeriod = getRewardPerPeriod();\n uint256[] memory slashedDurationList = _getSlashInfo(operators);\n // Validate should share the reward equally\n bool shouldShareEqually = _shouldShareEqually(totalBallot, totalVote, ballots);\n\n uint256 reward;\n bool shouldSlash;\n uint256 sumRewards;\n\n for (uint256 i; i < numBridgeOperators; ) {\n (reward, shouldSlash) = _calcRewardAndCheckSlashedStatus({\n shouldShareEqually: shouldShareEqually,\n numBridgeOperators: numBridgeOperators,\n rewardPerPeriod: rewardPerPeriod,\n ballot: ballots[i],\n totalBallot: totalBallot,\n period: period,\n slashUntilPeriod: slashedDurationList[i]\n });\n\n sumRewards += shouldSlash ? 0 : reward;\n _updateRewardAndTransfer({ period: period, operator: operators[i], reward: reward, shouldSlash: shouldSlash });\n\n unchecked {\n ++i;\n }\n }\n\n TOTAL_REWARDS_SCATTERED_SLOT.addAssign(sumRewards);\n }\n\n /**\n * @dev Returns whether should share the reward equally, in case of bridge tracking returns\n * informed data or there is no ballot in a day.\n *\n * Emit a {BridgeTrackingIncorrectlyResponded} event when in case of incorrect data.\n */\n function _shouldShareEqually(\n uint256 totalBallot,\n uint256 totalVote,\n uint256[] memory ballots\n ) internal returns (bool shareEqually) {\n bool valid = _isValidBridgeTrackingResponse(totalBallot, totalVote, ballots);\n if (!valid) {\n emit BridgeTrackingIncorrectlyResponded();\n }\n\n return !valid || totalBallot == 0;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator and check its slashing status.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @param period The period for which the reward is being calculated.\n * @param slashUntilPeriod The period until which slashing is effective for the bridge operator.\n * @return reward The calculated reward for the bridge operator.\n * @return shouldSlash A boolean indicating whether the bridge operator should be slashed for the current period.\n */\n function _calcRewardAndCheckSlashedStatus(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot,\n uint256 period,\n uint256 slashUntilPeriod\n ) internal pure returns (uint256 reward, bool shouldSlash) {\n shouldSlash = _shouldSlashedThisPeriod(period, slashUntilPeriod);\n reward = _calcReward(shouldShareEqually, numBridgeOperators, rewardPerPeriod, ballot, totalBallot);\n }\n\n /**\n * @dev Internal function to check if a specific period should be considered as slashed based on the slash duration.\n * @param period The period to check if it should be slashed.\n * @param slashDuration The duration until which periods should be considered as slashed.\n * @return shouldSlashed A boolean indicating whether the specified period should be slashed.\n * @notice This function is used internally to determine if a particular period should be marked as slashed based on the slash duration.\n */\n function _shouldSlashedThisPeriod(uint256 period, uint256 slashDuration) internal pure returns (bool) {\n return period <= slashDuration;\n }\n\n /**\n * @dev Internal function to calculate the reward for a bridge operator based on the provided parameters.\n * @param shouldShareEqually A boolean indicating whether the reward should be shared equally among bridge operators.\n * @param numBridgeOperators The total number of bridge operators for proportional reward calculation.\n * @param rewardPerPeriod The total reward available for the period.\n * @param ballot The individual ballot count of the bridge operator for the period.\n * @param totalBallot The total number of available ballots for the period.\n * @return reward The calculated reward for the bridge operator.\n */\n function _calcReward(\n bool shouldShareEqually,\n uint256 numBridgeOperators,\n uint256 rewardPerPeriod,\n uint256 ballot,\n uint256 totalBallot\n ) internal pure returns (uint256 reward) {\n // Shares equally in case the bridge has nothing to vote or bridge tracking response is incorrect\n // Else shares the bridge operators reward proportionally\n reward = shouldShareEqually ? rewardPerPeriod / numBridgeOperators : (rewardPerPeriod * ballot) / totalBallot;\n }\n\n /**\n * @dev Transfer `reward` to a `operator` or only emit event based on the operator `slashed` status.\n */\n function _updateRewardAndTransfer(uint256 period, address operator, uint256 reward, bool shouldSlash) private {\n BridgeRewardInfo storage _iRewardInfo = _getRewardInfo()[operator];\n\n if (shouldSlash) {\n _iRewardInfo.slashed += reward;\n emit BridgeRewardSlashed(period, operator, reward);\n } else {\n _iRewardInfo.claimed += reward;\n if (_unsafeSendRONLimitGas({ recipient: payable(operator), amount: reward, gas: 0 })) {\n emit BridgeRewardScattered(period, operator, reward);\n } else {\n emit BridgeRewardScatterFailed(period, operator, reward);\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getRewardPerPeriod() public view returns (uint256) {\n return REWARD_PER_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function getLatestRewardedPeriod() public view returns (uint256) {\n return LATEST_REWARDED_PERIOD_SLOT.load();\n }\n\n /**\n * @inheritdoc IBridgeReward\n */\n function setRewardPerPeriod(uint256 rewardPerPeriod) external onlyContract(ContractType.BRIDGE_MANAGER) {\n _setRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal function for setting the total reward per period.\n * Emit an {UpdatedRewardPerPeriod} event after set.\n */\n function _setRewardPerPeriod(uint256 rewardPerPeriod) internal {\n REWARD_PER_PERIOD_SLOT.store(rewardPerPeriod);\n emit UpdatedRewardPerPeriod(rewardPerPeriod);\n }\n\n /**\n * @dev Internal helper for querying slash info of a list of operators.\n */\n function _getSlashInfo(address[] memory operatorList) internal returns (uint256[] memory _slashedDuration) {\n return IBridgeSlash(getContract(ContractType.BRIDGE_SLASH)).getSlashUntilPeriodOf(operatorList);\n }\n\n /**\n * @dev Internal helper for querying whether an address is an operator.\n */\n function _isBridgeOperator(address operator) internal view returns (bool) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(operator);\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeRewardInfo.\n * @return rewardInfo the mapping from bridge operator => BridgeRewardInfo.\n */\n function _getRewardInfo() internal pure returns (mapping(address => BridgeRewardInfo) storage rewardInfo) {\n assembly (\"memory-safe\") {\n rewardInfo.slot := REWARD_INFO_SLOT\n }\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeSlash.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { Initializable } from \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport { BridgeTrackingHelper } from \"../../extensions/bridge-operator-governance/BridgeTrackingHelper.sol\";\nimport { IHasContracts, HasContracts } from \"../../extensions/collections/HasContracts.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IERC165, IBridgeManagerCallback } from \"../../interfaces/bridge/IBridgeManagerCallback.sol\";\nimport { IBridgeTracking } from \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { Math } from \"../../libraries/Math.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport { IdentityGuard } from \"../../utils/IdentityGuard.sol\";\nimport { ErrLengthMismatch } from \"../../utils/CommonErrors.sol\";\n\n/**\n * @title BridgeSlash\n * @dev A contract that implements slashing functionality for bridge operators based on their availability.\n */\ncontract BridgeSlash is\n IBridgeSlash,\n IBridgeManagerCallback,\n BridgeTrackingHelper,\n IdentityGuard,\n Initializable,\n HasContracts\n{\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_1_PENALTY_DURATION = 1;\n /// @inheritdoc IBridgeSlash\n uint256 public constant TIER_2_PENALTY_DURATION = 5;\n /// @inheritdoc IBridgeSlash\n uint256 public constant MINIMUM_VOTE_THRESHOLD = 50;\n /// @inheritdoc IBridgeSlash\n uint256 public constant REMOVE_DURATION_THRESHOLD = 30;\n\n /// @dev Tier 1 slashing threshold ratio is 10%\n uint256 private constant TIER_1_THRESHOLD = 10_00;\n /// @dev Tier 2 slashing threshold ratio is 30%\n uint256 private constant TIER_2_THRESHOLD = 30_00;\n /// @dev Max percentage 100%. Values [0; 100_00] reflexes [0; 100%]\n uint256 private constant PERCENTAGE_FRACTION = 100_00;\n /// @dev This value is set to the maximum value of uint128 to indicate a permanent slash duration.\n uint256 private constant SLASH_PERMANENT_DURATION = type(uint128).max;\n /// @dev value is equal to keccak256(\"@ronin.dpos.gateway.BridgeSlash.bridgeSlashInfos.slot\") - 1\n bytes32 private constant BRIDGE_SLASH_INFOS_SLOT = 0xd08d185790a07c7b9b721e2713c8580010a57f31c72c16f6e80b831d0ee45bfe;\n\n /// @dev The period that the contract allows slashing.\n uint256 internal _startedAtPeriod;\n\n /**\n * @dev The modifier verifies if the `totalVote` is non-zero, indicating the presence of ballots for the period.\n * @param totalVote The total number of ballots for the period.\n */\n modifier onlyPeriodHasEnoughVotes(uint256 totalVote) {\n if (totalVote <= MINIMUM_VOTE_THRESHOLD) return;\n _;\n }\n\n modifier skipOnNotStarted(uint256 period) {\n if (period < _startedAtPeriod) return;\n _;\n }\n\n constructor() payable {\n _disableInitializers();\n }\n\n function initialize(\n address validatorContract,\n address bridgeManagerContract,\n address bridgeTrackingContract,\n address dposGA\n ) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManagerContract);\n _setContract(ContractType.BRIDGE_TRACKING, bridgeTrackingContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _startedAtPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_startedAtPeriod == type(uint256).max, \"already init rep 2\");\n _startedAtPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod() + 1;\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsAdded(\n address[] calldata bridgeOperators,\n bool[] memory addeds\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n uint256 length = bridgeOperators.length;\n if (length != addeds.length) revert ErrLengthMismatch(msg.sig);\n if (length == 0) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n\n for (uint256 i; i < length; ) {\n unchecked {\n if (addeds[i]) {\n _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod = uint128(currentPeriod);\n }\n\n ++i;\n }\n }\n\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorUpdated(\n address currentBridgeOperator,\n address newBridgeOperator\n ) external onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n _bridgeSlashInfos[newBridgeOperator] = _bridgeSlashInfos[currentBridgeOperator];\n delete _bridgeSlashInfos[currentBridgeOperator];\n\n return IBridgeManagerCallback.onBridgeOperatorUpdated.selector;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function execSlashBridgeOperators(\n address[] memory operators,\n uint256[] memory ballots,\n uint256 totalBallot,\n uint256 totalVote,\n uint256 period\n ) external onlyContract(ContractType.BRIDGE_TRACKING) skipOnNotStarted(period) onlyPeriodHasEnoughVotes(totalVote) {\n if (operators.length != ballots.length) revert ErrLengthMismatch(msg.sig);\n if (operators.length == 0) return;\n if (!_isValidBridgeTrackingResponse(totalBallot, totalVote, ballots)) {\n emit BridgeTrackingIncorrectlyResponded();\n return;\n }\n\n // Get penalty durations for each slash tier.\n uint256[] memory penaltyDurations = _getPenaltyDurations();\n // Get the storage mapping for bridge slash information.\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n // Declare variables for iteration.\n BridgeSlashInfo memory status;\n uint256 slashUntilPeriod;\n address bridgeOperator;\n Tier tier;\n\n for (uint256 i; i < operators.length; ) {\n bridgeOperator = operators[i];\n status = _bridgeSlashInfos[bridgeOperator];\n\n // Check if the bridge operator was added before the current period.\n // Bridge operators added in current period will not be slashed.\n if (status.newlyAddedAtPeriod < period) {\n // Determine the slash tier for the bridge operator based on their ballots.\n tier = _getSlashTier(ballots[i], totalVote);\n\n slashUntilPeriod = _calcSlashUntilPeriod(tier, period, status.slashUntilPeriod, penaltyDurations);\n\n // Check if the slash duration exceeds the threshold for removal.\n if (_isSlashDurationMetRemovalThreshold(slashUntilPeriod, period)) {\n slashUntilPeriod = SLASH_PERMANENT_DURATION;\n emit RemovalRequested(period, bridgeOperator);\n }\n\n // Emit the Slashed event if the tier is not Tier 0 and bridge operator will not be removed.\n // Update the slash until period number for the bridge operator if the tier is not Tier 0.\n if (tier != Tier.Tier0) {\n if (slashUntilPeriod != SLASH_PERMANENT_DURATION) {\n emit Slashed(tier, bridgeOperator, period, slashUntilPeriod);\n }\n\n // Store updated slash until period\n _bridgeSlashInfos[bridgeOperator].slashUntilPeriod = uint128(slashUntilPeriod);\n }\n }\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeManagerCallback\n */\n function onBridgeOperatorsRemoved(\n address[] calldata,\n bool[] calldata\n ) external view onlyContract(ContractType.BRIDGE_MANAGER) returns (bytes4) {\n return IBridgeManagerCallback.onBridgeOperatorsAdded.selector;\n }\n\n /**\n * @inheritdoc IERC165\n */\n function supportsInterface(bytes4 interfaceId) external pure returns (bool) {\n return interfaceId == type(IBridgeManagerCallback).interfaceId || interfaceId == type(IERC165).interfaceId;\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashUntilPeriodOf(\n address[] calldata bridgeOperators\n ) external view returns (uint256[] memory untilPeriods) {\n uint256 length = bridgeOperators.length;\n untilPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n untilPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].slashUntilPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {\n uint256 length = bridgeOperators.length;\n addedPeriods = new uint256[](length);\n mapping(address => BridgeSlashInfo) storage _bridgeSlashInfos = _getBridgeSlashInfos();\n\n for (uint256 i; i < length; ) {\n addedPeriods[i] = _bridgeSlashInfos[bridgeOperators[i]].newlyAddedAtPeriod;\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getPenaltyDurations() external pure returns (uint256[] memory penaltyDurations) {\n penaltyDurations = _getPenaltyDurations();\n }\n\n /**\n * @inheritdoc IBridgeSlash\n */\n function getSlashTier(uint256 ballot, uint256 totalVote) external pure returns (Tier tier) {\n tier = _getSlashTier(ballot, totalVote);\n }\n\n /**\n * @dev Checks if the slash duration exceeds the threshold for removal and handles it accordingly.\n * @param slashUntilPeriod The slash until period number.\n * @param period The current period.\n * @return met A boolean indicates that the threshold for removal is met.\n */\n function _isSlashDurationMetRemovalThreshold(\n uint256 slashUntilPeriod,\n uint256 period\n ) internal pure returns (bool met) {\n met = slashUntilPeriod - (period - 1) >= REMOVE_DURATION_THRESHOLD;\n }\n\n /**\n * @dev Calculates the slash until period based on the specified tier, current period, and slash until period.\n * @param tier The slash tier representing the severity of the slash.\n * @param period The current period in which the calculation is performed.\n * @param slashUntilPeriod The existing slash until period.\n * @param penaltyDurations An array of penalty durations for each slash tier.\n * @return newSlashUntilPeriod The newly calculated slash until period.\n */\n function _calcSlashUntilPeriod(\n Tier tier,\n uint256 period,\n uint256 slashUntilPeriod,\n uint256[] memory penaltyDurations\n ) internal pure returns (uint256 newSlashUntilPeriod) {\n // Calculate the slash until period number.\n newSlashUntilPeriod = penaltyDurations[uint8(tier)] + Math.max(period - 1, slashUntilPeriod);\n }\n\n /**\n * @dev Internal function to determine the slashing tier based on the given ballot count and total votes.\n * @param ballot The individual ballot count of a bridge operator.\n * @param totalVote The total number of votes recorded for the bridge operator.\n * @return tier The calculated slashing tier for the bridge operator.\n * @notice The `ratio` is calculated as the percentage of uncast votes (totalVote - ballot) relative to the total votes.\n */\n function _getSlashTier(uint256 ballot, uint256 totalVote) internal pure virtual returns (Tier tier) {\n uint256 ratio = ((totalVote - ballot) * PERCENTAGE_FRACTION) / totalVote;\n tier = ratio > TIER_2_THRESHOLD ? Tier.Tier2 : ratio > TIER_1_THRESHOLD ? Tier.Tier1 : Tier.Tier0;\n }\n\n /**\n * @dev Internal function to access the mapping from bridge operator => BridgeSlashInfo.\n * @return bridgeSlashInfos the mapping from bridge operator => BridgeSlashInfo.\n */\n function _getBridgeSlashInfos() internal pure returns (mapping(address => BridgeSlashInfo) storage bridgeSlashInfos) {\n assembly (\"memory-safe\") {\n bridgeSlashInfos.slot := BRIDGE_SLASH_INFOS_SLOT\n }\n }\n\n /**\n * @dev Internal function to retrieve the penalty durations for each slashing tier.\n * @return penaltyDurations An array containing the penalty durations for Tier0, Tier1, and Tier2 in that order.\n */\n function _getPenaltyDurations() internal pure virtual returns (uint256[] memory penaltyDurations) {\n // reserve index 0\n penaltyDurations = new uint256[](3);\n penaltyDurations[uint8(Tier.Tier1)] = TIER_1_PENALTY_DURATION;\n penaltyDurations[uint8(Tier.Tier2)] = TIER_2_PENALTY_DURATION;\n }\n}\n" + }, + "contracts/ronin/gateway/BridgeTracking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport { IBridgeManager } from \"../../interfaces/bridge/IBridgeManager.sol\";\nimport { IBridgeSlash } from \"../../interfaces/bridge/IBridgeSlash.sol\";\nimport { IBridgeReward } from \"../../interfaces/bridge/IBridgeReward.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { HasBridgeDeprecated, HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\ncontract BridgeTracking is HasBridgeDeprecated, HasValidatorDeprecated, HasContracts, Initializable, IBridgeTracking {\n struct PeriodVotingMetric {\n /// @dev Total requests that are tracked in the period. This value is 0 until the {_bufferMetric.requests[]} gets added into a period metric.\n uint256 totalRequest;\n uint256 totalBallot;\n mapping(address => uint256) totalBallotOf;\n address[] voters;\n }\n\n struct PeriodVotingMetricTimeWrapper {\n uint256 lastEpoch;\n Request[] requests;\n PeriodVotingMetric data;\n }\n\n struct ReceiptTrackingInfo {\n /// @dev The period that the receipt is approved. Value 0 means the receipt is not approved yet.\n uint256 approvedPeriod;\n /// @dev The address list of voters\n address[] voters;\n /// @dev Mapping from voter => flag indicating the voter casts vote for this receipt\n mapping(address => bool) voted;\n /// @dev The period that the receipt is tracked, i.e. the metric is transferred from buffer to the period. Value 0 means the receipt is currently in buffer or not tracked yet.\n uint256 trackedPeriod;\n }\n\n /// @dev The block that the contract allows incoming mutable calls.\n uint256 internal _startedAtBlock;\n\n /// @dev The temporary info of votes and ballots\n PeriodVotingMetricTimeWrapper internal _bufferMetric;\n /// @dev Mapping from period number => vote stats based on period\n mapping(uint256 => PeriodVotingMetric) internal _periodMetric;\n /// @dev Mapping from vote kind => receipt id => receipt stats\n mapping(VoteKind => mapping(uint256 => ReceiptTrackingInfo)) internal _receiptTrackingInfo;\n /// @dev The latest period that get synced with bridge's slashing and rewarding contract\n uint256 internal _lastSyncPeriod;\n\n modifier skipOnNotStarted() {\n _skipOnNotStarted();\n _;\n }\n\n /**\n * @dev Returns the whole transaction in case the current block is less than start block.\n */\n function _skipOnNotStarted() private view {\n if (block.number < _startedAtBlock) {\n assembly {\n return(0, 0)\n }\n }\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(address bridgeContract, address validatorContract, uint256 startedAtBlock_) external initializer {\n _setContract(ContractType.BRIDGE, bridgeContract);\n _setContract(ContractType.VALIDATOR, validatorContract);\n _startedAtBlock = startedAtBlock_;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.BRIDGE, ______deprecatedBridge);\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n\n delete ______deprecatedBridge;\n delete ______deprecatedValidator;\n }\n\n function initializeV3(\n address bridgeManager,\n address bridgeSlash,\n address bridgeReward,\n address dposGA\n ) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeManager);\n _setContract(ContractType.BRIDGE_SLASH, bridgeSlash);\n _setContract(ContractType.BRIDGE_REWARD, bridgeReward);\n _setContract(ContractType.GOVERNANCE_ADMIN, dposGA);\n _lastSyncPeriod = type(uint256).max;\n }\n\n /**\n * @dev Helper for running upgrade script, required to only revoked once by the DPoS's governance admin.\n * The following must be assured after initializing REP2:\n * `_lastSyncPeriod`\n * == `{BridgeReward}.latestRewardedPeriod + 1`\n * == `{BridgeSlash}._startedAtPeriod - 1`\n * == `currentPeriod()`\n */\n function initializeREP2() external onlyContract(ContractType.GOVERNANCE_ADMIN) {\n require(_lastSyncPeriod == type(uint256).max, \"already init rep 2\");\n _lastSyncPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _setContract(ContractType.GOVERNANCE_ADMIN, address(0));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function startedAtBlock() external view override returns (uint256) {\n return _startedAtBlock;\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalVote(uint256 period) public view override returns (uint256 totalVote_) {\n totalVote_ = _periodMetric[period].totalRequest;\n if (_isBufferCountedForPeriod(period)) {\n totalVote_ += _bufferMetric.requests.length;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallot(uint256 period) public view override returns (uint256 totalBallot_) {\n totalBallot_ = _periodMetric[period].totalBallot;\n if (_isBufferCountedForPeriod(period)) {\n totalBallot_ += _bufferMetric.data.totalBallot;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function getManyTotalBallots(\n uint256 period,\n address[] calldata operators\n ) external view override returns (uint256[] memory _res) {\n _res = _getManyTotalBallots(period, operators);\n }\n\n function _getManyTotalBallots(\n uint256 period,\n address[] memory operators\n ) internal view returns (uint256[] memory res) {\n uint256 length = operators.length;\n res = new uint256[](length);\n bool isBufferCounted = _isBufferCountedForPeriod(period);\n for (uint i = 0; i < length; ) {\n res[i] = _totalBallotOf(period, operators[i], isBufferCounted);\n\n unchecked {\n ++i;\n }\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function totalBallotOf(uint256 period, address bridgeOperator) public view override returns (uint256) {\n return _totalBallotOf(period, bridgeOperator, _isBufferCountedForPeriod(period));\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function handleVoteApproved(\n VoteKind kind,\n uint256 requestId\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // Only records for the receipt which not approved\n if (_receiptInfo.approvedPeriod == 0) {\n _trySyncBuffer();\n uint256 currentPeriod = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _receiptInfo.approvedPeriod = currentPeriod;\n\n Request storage _bufferRequest = _bufferMetric.requests.push();\n _bufferRequest.kind = kind;\n _bufferRequest.id = requestId;\n\n address[] storage _voters = _receiptInfo.voters;\n for (uint i = 0; i < _voters.length; ) {\n _increaseBallot(kind, requestId, _voters[i], currentPeriod);\n\n unchecked {\n ++i;\n }\n }\n\n delete _receiptInfo.voters;\n }\n }\n\n /**\n * @inheritdoc IBridgeTracking\n */\n function recordVote(\n VoteKind kind,\n uint256 requestId,\n address operator\n ) external override onlyContract(ContractType.BRIDGE) skipOnNotStarted {\n uint256 period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _trySyncBuffer();\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n\n // When the vote is not approved yet, the voters are saved in the receipt info, and not increase ballot metric.\n // The ballot metric will be increased later in the {handleVoteApproved} method.\n if (_receiptInfo.approvedPeriod == 0) {\n _receiptInfo.voters.push(operator);\n return;\n }\n\n _increaseBallot(kind, requestId, operator, period);\n\n uint256 lastSyncPeriod = _lastSyncPeriod;\n // When switching to new period, wrap up vote info, then slash and distribute reward accordingly.\n if (lastSyncPeriod < period) {\n _lastSyncPeriod = period;\n\n address[] memory allOperators = IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getBridgeOperators();\n uint256[] memory ballots = _getManyTotalBallots(lastSyncPeriod, allOperators);\n\n uint256 totalVote_ = totalVote(lastSyncPeriod);\n uint256 totalBallot_ = totalBallot(lastSyncPeriod);\n\n address bridgeSlashContract = getContract(ContractType.BRIDGE_SLASH);\n (bool success, bytes memory returnOrRevertData) = bridgeSlashContract.call(\n abi.encodeCall(\n IBridgeSlash.execSlashBridgeOperators,\n (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod)\n )\n );\n if (!success) {\n emit ExternalCallFailed(\n bridgeSlashContract,\n IBridgeSlash.execSlashBridgeOperators.selector,\n returnOrRevertData\n );\n }\n\n address bridgeRewardContract = getContract(ContractType.BRIDGE_REWARD);\n (success, returnOrRevertData) = bridgeRewardContract.call(\n abi.encodeCall(IBridgeReward.execSyncReward, (allOperators, ballots, totalBallot_, totalVote_, lastSyncPeriod))\n );\n if (!success) {\n emit ExternalCallFailed(bridgeRewardContract, IBridgeReward.execSyncReward.selector, returnOrRevertData);\n }\n }\n }\n\n /**\n * @dev Increases the ballot for the operator at a period.\n */\n function _increaseBallot(VoteKind kind, uint256 requestId, address operator, uint256 currentPeriod) internal {\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[kind][requestId];\n if (_receiptInfo.voted[operator]) {\n return;\n }\n\n _receiptInfo.voted[operator] = true;\n\n uint256 trackedPeriod = _receiptInfo.trackedPeriod;\n\n // Do not increase ballot for receipt that is neither in the buffer, nor in the most current tracked period.\n // If the receipt is not tracked in a period, increase metric in buffer.\n unchecked {\n if (trackedPeriod == 0) {\n if (_bufferMetric.data.totalBallotOf[operator] == 0) {\n _bufferMetric.data.voters.push(operator);\n }\n _bufferMetric.data.totalBallot++;\n _bufferMetric.data.totalBallotOf[operator]++;\n }\n // If the receipt is tracked in the most current tracked period, increase metric in the period.\n else if (trackedPeriod == currentPeriod) {\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalBallot++;\n _metric.totalBallotOf[operator]++;\n }\n }\n }\n\n /**\n * @dev See `totalBallotOf`.\n */\n function _totalBallotOf(\n uint256 period,\n address operator,\n bool mustCountLastStats\n ) internal view returns (uint256 _totalBallot) {\n _totalBallot = _periodMetric[period].totalBallotOf[operator];\n if (mustCountLastStats) {\n _totalBallot += _bufferMetric.data.totalBallotOf[operator];\n }\n }\n\n /**\n * @dev Syncs period stats. Move all data from the buffer metric to the period metric.\n *\n * Requirements:\n * - The epoch after the buffer epoch is wrapped up.\n */\n function _trySyncBuffer() internal {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n if (_bufferMetric.lastEpoch < currentEpoch) {\n (, uint256 trackedPeriod) = validatorContract.tryGetPeriodOfEpoch(_bufferMetric.lastEpoch + 1);\n _bufferMetric.lastEpoch = currentEpoch;\n\n // Copy numbers of totals\n PeriodVotingMetric storage _metric = _periodMetric[trackedPeriod];\n _metric.totalRequest += _bufferMetric.requests.length;\n _metric.totalBallot += _bufferMetric.data.totalBallot;\n\n // Copy voters info and voters' ballot\n for (uint i = 0; i < _bufferMetric.data.voters.length; ) {\n address voter = _bufferMetric.data.voters[i];\n _metric.totalBallotOf[voter] += _bufferMetric.data.totalBallotOf[voter];\n delete _bufferMetric.data.totalBallotOf[voter]; // need to manually delete each element, due to mapping\n\n unchecked {\n ++i;\n }\n }\n\n // Mark all receipts in the buffer as tracked. Keep total number of receipts and delete receipt details.\n for (uint i = 0; i < _bufferMetric.requests.length; ) {\n Request storage _bufferRequest = _bufferMetric.requests[i];\n ReceiptTrackingInfo storage _receiptInfo = _receiptTrackingInfo[_bufferRequest.kind][_bufferRequest.id];\n _receiptInfo.trackedPeriod = trackedPeriod;\n\n unchecked {\n ++i;\n }\n }\n\n delete _bufferMetric.requests;\n delete _bufferMetric.data;\n }\n }\n\n /**\n * @dev Returns whether the buffer stats must be counted or not.\n */\n function _isBufferCountedForPeriod(uint256 queriedPeriod) internal view returns (bool) {\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 currentEpoch = validatorContract.epochOf(block.number);\n (bool filled, uint256 periodOfNextTemporaryEpoch) = validatorContract.tryGetPeriodOfEpoch(\n _bufferMetric.lastEpoch + 1\n );\n return filled && queriedPeriod == periodOfNextTemporaryEpoch && _bufferMetric.lastEpoch < currentEpoch;\n }\n}\n" + }, + "contracts/ronin/gateway/PauseEnforcer.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/IPauseTarget.sol\";\n\ncontract PauseEnforcer is AccessControlEnumerable, Initializable {\n /**\n * @dev Error thrown when the target is already on paused state.\n */\n error ErrTargetIsOnPaused();\n\n /**\n * @dev Error thrown when the target is not on paused state.\n */\n error ErrTargetIsNotOnPaused();\n\n /**\n * @dev Error thrown when the contract is not on emergency pause.\n */\n error ErrNotOnEmergencyPause();\n\n bytes32 public constant SENTRY_ROLE = keccak256(\"SENTRY_ROLE\");\n\n /// @dev The contract that can be paused or unpaused by the SENTRY_ROLE.\n IPauseTarget public target;\n /// @dev Indicating whether or not the target contract is paused in emergency mode.\n bool public emergency;\n\n /// @dev Emitted when the emergency ppause is triggered by `account`.\n event EmergencyPaused(address account);\n /// @dev Emitted when the emergency unpause is triggered by `account`.\n event EmergencyUnpaused(address account);\n /// @dev Emitted when the target is changed.\n event TargetChanged(IPauseTarget target);\n\n modifier onEmergency() {\n if (!emergency) revert ErrNotOnEmergencyPause();\n\n _;\n }\n\n modifier targetPaused() {\n if (!target.paused()) revert ErrTargetIsOnPaused();\n\n _;\n }\n\n modifier targetNotPaused() {\n if (target.paused()) revert ErrTargetIsNotOnPaused();\n\n _;\n }\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(IPauseTarget _target, address _admin, address[] memory _sentries) external initializer {\n _changeTarget(_target);\n _setupRole(DEFAULT_ADMIN_ROLE, _admin);\n for (uint _i; _i < _sentries.length; ) {\n _grantRole(SENTRY_ROLE, _sentries[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Grants the SENTRY_ROLE to the specified address.\n */\n function grantSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _grantRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Revokes the SENTRY_ROLE from the specified address.\n */\n function revokeSentry(address _sentry) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _revokeRole(SENTRY_ROLE, _sentry);\n }\n\n /**\n * @dev Triggers a pause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is not already paused.\n */\n function triggerPause() external onlyRole(SENTRY_ROLE) targetNotPaused {\n emergency = true;\n target.pause();\n emit EmergencyPaused(msg.sender);\n }\n\n /**\n * @dev Triggers an unpause on the target contract.\n *\n * Requirements:\n * - Only be called by accounts with the SENTRY_ROLE,\n * - The target contract is already paused.\n * - The target contract is paused in emergency mode.\n */\n function triggerUnpause() external onlyRole(SENTRY_ROLE) onEmergency targetPaused {\n emergency = false;\n target.unpause();\n emit EmergencyUnpaused(msg.sender);\n }\n\n /**\n * @dev Setter for `target`.\n *\n * Requirements:\n * - Only admin can call this method.\n */\n function changeTarget(IPauseTarget _target) external onlyRole(DEFAULT_ADMIN_ROLE) {\n _changeTarget(_target);\n }\n\n /**\n * @dev Internal helper for setting value to `target`.\n */\n function _changeTarget(IPauseTarget _target) internal {\n target = _target;\n emit TargetChanged(_target);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninBridgeManager.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType, RoleAccess, ErrUnauthorized, BridgeManager } from \"../../extensions/bridge-operator-governance/BridgeManager.sol\";\nimport { Ballot, GlobalProposal, Proposal, GovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport { CoreGovernance, GlobalCoreGovernance, GlobalGovernanceProposal } from \"../../extensions/sequential-governance/governance-proposal/GlobalGovernanceProposal.sol\";\nimport { VoteStatusConsumer } from \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport { ErrQueryForEmptyVote } from \"../../utils/CommonErrors.sol\";\n\ncontract RoninBridgeManager is BridgeManager, GovernanceProposal, GlobalGovernanceProposal {\n constructor(\n uint256 num,\n uint256 denom,\n uint256 roninChainId,\n uint256 expiryDuration,\n address bridgeContract,\n address[] memory callbackRegisters,\n address[] memory bridgeOperators,\n address[] memory governors,\n uint96[] memory voteWeights,\n GlobalProposal.TargetOption[] memory targetOptions,\n address[] memory targets\n )\n payable\n CoreGovernance(expiryDuration)\n GlobalCoreGovernance(targetOptions, targets)\n BridgeManager(num, denom, roninChainId, bridgeContract, callbackRegisters, bridgeOperators, governors, voteWeights)\n {}\n\n /**\n * CURRENT NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 expiryTimestamp,\n address[] calldata targets,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts,\n Ballot.VoteType support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal({\n chainId: block.chainid,\n expiryTimestamp: expiryTimestamp,\n targets: targets,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: _voter\n });\n _castProposalVoteForCurrentNetwork(_voter, _proposal, support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, proposal, support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata proposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castProposalBySignatures(proposal, supports_, signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * GLOBAL NETWORK\n */\n\n /**\n * @dev See `CoreGovernance-_proposeGlobal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobal(\n uint256 expiryTimestamp,\n GlobalProposal.TargetOption[] calldata targetOptions,\n uint256[] calldata values,\n bytes[] calldata calldatas,\n uint256[] calldata gasAmounts\n ) external onlyGovernor {\n _proposeGlobal({\n expiryTimestamp: expiryTimestamp,\n targetOptions: targetOptions,\n values: values,\n calldatas: calldatas,\n gasAmounts: gasAmounts,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeGlobalProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function proposeGlobalProposalStructAndCastVotes(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external onlyGovernor {\n _proposeGlobalProposalStructAndCastVotes({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR,\n creator: msg.sender\n });\n }\n\n /**\n * @dev See `GovernanceProposal-_castGlobalProposalBySignatures`.\n */\n function castGlobalProposalBySignatures(\n GlobalProposal.GlobalProposalDetail calldata globalProposal,\n Ballot.VoteType[] calldata supports_,\n Signature[] calldata signatures\n ) external {\n _castGlobalProposalBySignatures({\n globalProposal: globalProposal,\n supports_: supports_,\n signatures: signatures,\n domainSeparator: DOMAIN_SEPARATOR\n });\n }\n\n /**\n * COMMON METHODS\n */\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @dev Returns the expiry duration for a new proposal.\n */\n function getProposalExpiryDuration() external view returns (uint256) {\n return _getProposalExpiryDuration();\n }\n\n /**\n * @dev Internal function to get the chain type of the contract.\n * @return The chain type, indicating the type of the chain the contract operates on (e.g., RoninChain).\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n\n /**\n * @dev Internal function to get the total weights of all governors.\n * @return The total weights of all governors combined.\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return getTotalWeight();\n }\n\n /**\n * @dev Internal function to get the minimum vote weight required for governance actions.\n * @return The minimum vote weight required for governance actions.\n */\n function _getMinimumVoteWeight() internal view virtual override returns (uint256) {\n return minimumVoteWeight();\n }\n\n /**\n * @dev Internal function to get the vote weight of a specific governor.\n * @param _governor The address of the governor to get the vote weight for.\n * @return The vote weight of the specified governor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n return _getGovernorWeight(_governor);\n }\n}\n" + }, + "contracts/ronin/gateway/RoninGatewayV3.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"@openzeppelin/contracts/access/AccessControlEnumerable.sol\";\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../extensions/GatewayV3.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/MinimumWithdrawal.sol\";\nimport \"../../interfaces/IERC20Mintable.sol\";\nimport \"../../interfaces/IERC721Mintable.sol\";\nimport \"../../interfaces/bridge/IBridgeTracking.sol\";\nimport \"../../interfaces/IRoninGatewayV3.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/consumers/VoteStatusConsumer.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/IsolatedGovernance.sol\";\nimport \"../../interfaces/bridge/IBridgeManager.sol\";\n\ncontract RoninGatewayV3 is\n GatewayV3,\n Initializable,\n MinimumWithdrawal,\n AccessControlEnumerable,\n VoteStatusConsumer,\n IRoninGatewayV3,\n HasContracts\n{\n using Token for Token.Info;\n using Transfer for Transfer.Request;\n using Transfer for Transfer.Receipt;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @custom:deprecated Previously `withdrawalMigrated` (non-zero value)\n bool private ___deprecated4;\n /// @dev Total withdrawal\n uint256 public withdrawalCount;\n /// @dev Mapping from chain id => deposit id => deposit vote\n mapping(uint256 => mapping(uint256 => IsolatedGovernance.Vote)) public depositVote;\n /// @dev Mapping from withdrawal id => mainchain withdrew vote\n mapping(uint256 => IsolatedGovernance.Vote) public mainchainWithdrewVote;\n /// @dev Mapping from withdrawal id => withdrawal receipt\n mapping(uint256 => Transfer.Receipt) public withdrawal;\n /// @dev Mapping from withdrawal id => validator address => signatures\n mapping(uint256 => mapping(address => bytes)) internal _withdrawalSig;\n /// @dev Mapping from token address => chain id => mainchain token address\n mapping(address => mapping(uint256 => MappedToken)) internal _mainchainToken;\n\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address private ____deprecated0;\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address private ____deprecated1;\n\n /// @dev Mapping from withdrawal id => vote for recording withdrawal stats\n mapping(uint256 => IsolatedGovernance.Vote) public withdrawalStatVote;\n\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address private ____deprecated2;\n\n uint256 internal _trustedNum;\n uint256 internal _trustedDenom;\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n modifier onlyBridgeOperator() {\n _requireBridgeOperator();\n _;\n }\n\n /**\n * @dev Reverts if the method caller is not bridge operator.\n */\n function _requireBridgeOperator() internal view {\n if (!IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).isBridgeOperator(msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.__DEPRECATED_BRIDGE_OPERATOR);\n }\n\n /**\n * @dev Initializes contract storage.\n */\n function initialize(\n address _roleSetter,\n uint256 _numerator,\n uint256 _denominator,\n uint256 _trustedNumerator,\n uint256 _trustedDenominator,\n address[] calldata /* _withdrawalMigrators */,\n // _packedAddresses[0]: roninTokens\n // _packedAddresses[1]: mainchainTokens\n address[][2] calldata _packedAddresses,\n // _packedNumbers[0]: chainIds\n // _packedNumbers[1]: minimumThresholds\n uint256[][2] calldata _packedNumbers,\n Token.Standard[] calldata _standards\n ) external virtual initializer {\n _setupRole(DEFAULT_ADMIN_ROLE, _roleSetter);\n _setThreshold(_numerator, _denominator);\n _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n if (_packedAddresses[0].length > 0) {\n _mapTokens(_packedAddresses[0], _packedAddresses[1], _packedNumbers[0], _standards);\n _setMinimumThresholds(_packedAddresses[0], _packedNumbers[1]);\n }\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ____deprecated0);\n _setContract(ContractType.BRIDGE_TRACKING, ____deprecated1);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ____deprecated2);\n delete ____deprecated0;\n delete ____deprecated1;\n delete ____deprecated2;\n }\n\n function initializeV3(address bridgeAdmin) external reinitializer(3) {\n _setContract(ContractType.BRIDGE_MANAGER, bridgeAdmin);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getWithdrawalSignatures(\n uint256 withdrawalId,\n address[] calldata operators\n ) external view returns (bytes[] memory _signatures) {\n _signatures = new bytes[](operators.length);\n for (uint256 _i = 0; _i < operators.length; ) {\n _signatures[_i] = _withdrawalSig[withdrawalId][operators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositFor(Transfer.Receipt calldata _receipt) external whenNotPaused onlyBridgeOperator {\n address _sender = msg.sender;\n _depositFor(_receipt, _sender, minimumVoteWeight());\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).recordVote(\n IBridgeTracking.VoteKind.Deposit,\n _receipt.id,\n _sender\n );\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkAcknowledgeMainchainWithdrew(\n uint256[] calldata _withdrawalIds\n ) external onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _governor = msg.sender;\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 _withdrawalId;\n _executedReceipts = new bool[](_withdrawalIds.length);\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _withdrawalIds.length; ) {\n _withdrawalId = _withdrawalIds[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId, _governor);\n if (mainchainWithdrew(_withdrawalId)) {\n _executedReceipts[_i] = true;\n } else {\n IsolatedGovernance.Vote storage _vote = mainchainWithdrewVote[_withdrawalId];\n Transfer.Receipt memory _withdrawal = withdrawal[_withdrawalId];\n bytes32 _hash = _withdrawal.hash();\n VoteStatus _status = _castIsolatedVote(_vote, _governor, _minVoteWeight, _hash);\n if (_status == VoteStatus.Approved) {\n _vote.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.MainchainWithdrawal, _withdrawalId);\n emit MainchainWithdrew(_hash, _withdrawal);\n }\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function tryBulkDepositFor(\n Transfer.Receipt[] calldata _receipts\n ) external whenNotPaused onlyBridgeOperator returns (bool[] memory _executedReceipts) {\n address _sender = msg.sender;\n\n Transfer.Receipt memory _receipt;\n _executedReceipts = new bool[](_receipts.length);\n uint256 _minVoteWeight = minimumVoteWeight();\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < _receipts.length; ) {\n _receipt = _receipts[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Deposit, _receipt.id, _sender);\n if (depositVote[_receipt.mainchain.chainId][_receipt.id].status == VoteStatus.Executed) {\n _executedReceipts[_i] = true;\n } else {\n _depositFor(_receipt, _sender, _minVoteWeight);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalFor(Transfer.Request calldata _request, uint256 _chainId) external whenNotPaused {\n _requestWithdrawalFor(_request, msg.sender, _chainId);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkRequestWithdrawalFor(Transfer.Request[] calldata _requests, uint256 _chainId) external whenNotPaused {\n if (_requests.length == 0) revert ErrEmptyArray();\n\n for (uint256 _i; _i < _requests.length; ) {\n _requestWithdrawalFor(_requests[_i], msg.sender, _chainId);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function requestWithdrawalSignatures(uint256 _withdrawalId) external whenNotPaused {\n if (mainchainWithdrew(_withdrawalId)) revert ErrWithdrawnOnMainchainAlready();\n\n Transfer.Receipt memory _receipt = withdrawal[_withdrawalId];\n if (_receipt.ronin.chainId != block.chainid) {\n revert ErrInvalidChainId(msg.sig, _receipt.ronin.chainId, block.chainid);\n }\n\n emit WithdrawalSignaturesRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function bulkSubmitWithdrawalSignatures(\n uint256[] calldata withdrawals,\n bytes[] calldata signatures\n ) external whenNotPaused onlyBridgeOperator {\n address operator = msg.sender;\n\n if (!(withdrawals.length > 0 && withdrawals.length == signatures.length)) {\n revert ErrLengthMismatch(msg.sig);\n }\n\n uint256 _minVoteWeight = minimumVoteWeight();\n\n uint256 id;\n IBridgeTracking _bridgeTrackingContract = IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING));\n for (uint256 _i; _i < withdrawals.length; ) {\n id = withdrawals[_i];\n _withdrawalSig[id][operator] = signatures[_i];\n _bridgeTrackingContract.recordVote(IBridgeTracking.VoteKind.Withdrawal, id, operator);\n\n IsolatedGovernance.Vote storage _proposal = withdrawalStatVote[id];\n VoteStatus _status = _castIsolatedVote(_proposal, operator, _minVoteWeight, bytes32(id));\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n _bridgeTrackingContract.handleVoteApproved(IBridgeTracking.VoteKind.Withdrawal, id);\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) external onlyAdmin {\n if (_roninTokens.length == 0) revert ErrLengthMismatch(msg.sig);\n _mapTokens(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function depositVoted(uint256 _chainId, uint256 _depositId, address _voter) external view returns (bool) {\n return depositVote[_chainId][_depositId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrewVoted(uint256 _withdrawalId, address _voter) external view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].voted(_voter);\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function mainchainWithdrew(uint256 _withdrawalId) public view returns (bool) {\n return mainchainWithdrewVote[_withdrawalId].status == VoteStatus.Executed;\n }\n\n /**\n * @inheritdoc IRoninGatewayV3\n */\n function getMainchainToken(address _roninToken, uint256 _chainId) public view returns (MappedToken memory _token) {\n _token = _mainchainToken[_roninToken][_chainId];\n if (_token.tokenAddr == address(0)) revert ErrUnsupportedToken();\n }\n\n /**\n * @dev Maps Ronin tokens to mainchain networks.\n *\n * Requirement:\n * - The arrays have the same length.\n *\n * Emits the `TokenMapped` event.\n *\n */\n function _mapTokens(\n address[] calldata _roninTokens,\n address[] calldata _mainchainTokens,\n uint256[] calldata _chainIds,\n Token.Standard[] calldata _standards\n ) internal {\n if (!(_roninTokens.length == _mainchainTokens.length && _roninTokens.length == _chainIds.length))\n revert ErrLengthMismatch(msg.sig);\n\n for (uint256 _i; _i < _roninTokens.length; ) {\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].tokenAddr = _mainchainTokens[_i];\n _mainchainToken[_roninTokens[_i]][_chainIds[_i]].erc = _standards[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n emit TokenMapped(_roninTokens, _mainchainTokens, _chainIds, _standards);\n }\n\n /**\n * @dev Deposits based on the receipt.\n *\n * Emits the `Deposited` once the assets are released.\n *\n */\n function _depositFor(Transfer.Receipt memory receipt, address operator, uint256 minVoteWeight) internal {\n uint256 id = receipt.id;\n receipt.info.validate();\n if (receipt.kind != Transfer.Kind.Deposit) revert ErrInvalidReceiptKind();\n\n if (receipt.ronin.chainId != block.chainid) revert ErrInvalidChainId(msg.sig, receipt.ronin.chainId, block.chainid);\n\n MappedToken memory _token = getMainchainToken(receipt.ronin.tokenAddr, receipt.mainchain.chainId);\n\n if (!(_token.erc == receipt.info.erc && _token.tokenAddr == receipt.mainchain.tokenAddr))\n revert ErrInvalidReceipt();\n\n IsolatedGovernance.Vote storage _proposal = depositVote[receipt.mainchain.chainId][id];\n bytes32 _receiptHash = receipt.hash();\n VoteStatus _status = _castIsolatedVote(_proposal, operator, minVoteWeight, _receiptHash);\n emit DepositVoted(operator, id, receipt.mainchain.chainId, _receiptHash);\n if (_status == VoteStatus.Approved) {\n _proposal.status = VoteStatus.Executed;\n receipt.info.handleAssetTransfer(payable(receipt.ronin.addr), receipt.ronin.tokenAddr, IWETH(address(0)));\n IBridgeTracking(getContract(ContractType.BRIDGE_TRACKING)).handleVoteApproved(\n IBridgeTracking.VoteKind.Deposit,\n receipt.id\n );\n emit Deposited(_receiptHash, receipt);\n }\n }\n\n /**\n * @dev Locks the assets and request withdrawal.\n *\n * Requirements:\n * - The token info is valid.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _requestWithdrawalFor(Transfer.Request calldata _request, address _requester, uint256 _chainId) internal {\n _request.info.validate();\n _checkWithdrawal(_request);\n MappedToken memory _token = getMainchainToken(_request.tokenAddr, _chainId);\n if (_request.info.erc != _token.erc) revert ErrInvalidTokenStandard();\n\n _request.info.transferFrom(_requester, address(this), _request.tokenAddr);\n _storeAsReceipt(_request, _chainId, _requester, _token.tokenAddr);\n }\n\n /**\n * @dev Stores the withdrawal request as a receipt.\n *\n * Emits the `WithdrawalRequested` event.\n *\n */\n function _storeAsReceipt(\n Transfer.Request calldata _request,\n uint256 _chainId,\n address _requester,\n address _mainchainTokenAddr\n ) internal returns (uint256 _withdrawalId) {\n _withdrawalId = withdrawalCount++;\n Transfer.Receipt memory _receipt = _request.into_withdrawal_receipt(\n _requester,\n _withdrawalId,\n _mainchainTokenAddr,\n _chainId\n );\n withdrawal[_withdrawalId] = _receipt;\n emit WithdrawalRequested(_receipt.hash(), _receipt);\n }\n\n /**\n * @dev Don't send me RON.\n */\n function _fallback() internal virtual {\n revert ErrInvalidRequest();\n }\n\n /**\n * @inheritdoc GatewayV3\n */\n function _getTotalWeight() internal view virtual override returns (uint256) {\n return IBridgeManager(getContract(ContractType.BRIDGE_MANAGER)).getTotalWeight();\n }\n\n /**\n * @dev Casts and updates the vote result.\n *\n * Requirements:\n * - The vote is not finalized.\n * - The voter has not voted for the round.\n *\n */\n function _castIsolatedVote(\n IsolatedGovernance.Vote storage _v,\n address _voter,\n uint256 _minVoteWeight,\n bytes32 _hash\n ) internal virtual returns (VoteStatus _status) {\n _v.castVote(_voter, _hash);\n uint256 _totalWeight = _getVoteWeight(_v, _hash);\n return _v.syncVoteStatus(_minVoteWeight, _totalWeight, _hash);\n }\n\n /**\n * @dev Returns the vote weight for a specified hash.\n */\n function _getVoteWeight(\n IsolatedGovernance.Vote storage _v,\n bytes32 _hash\n ) internal view returns (uint256 _totalWeight) {\n (, address[] memory bridgeOperators, uint96[] memory weights) = IBridgeManager(\n getContract(ContractType.BRIDGE_MANAGER)\n ).getFullBridgeOperatorInfos();\n uint256 length = bridgeOperators.length;\n unchecked {\n for (uint _i; _i < length; ++_i) {\n if (_v.voteHashOf[bridgeOperators[_i]] == _hash) {\n _totalWeight += weights[_i];\n }\n }\n }\n }\n\n function setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) external virtual onlyAdmin returns (uint256, uint256) {\n return _setTrustedThreshold(_trustedNumerator, _trustedDenominator);\n }\n\n /**\n * @dev Returns the threshold about trusted org.\n */\n function getTrustedThreshold() external view virtual returns (uint256 trustedNum_, uint256 trustedDenom_) {\n return (_trustedNum, _trustedDenom);\n }\n\n /**\n * @dev Sets trusted threshold and returns the old one.\n *\n * Emits the `TrustedThresholdUpdated` event.\n *\n */\n function _setTrustedThreshold(\n uint256 _trustedNumerator,\n uint256 _trustedDenominator\n ) internal virtual returns (uint256 _previousTrustedNum, uint256 _previousTrustedDenom) {\n if (_trustedNumerator > _trustedDenominator) revert ErrInvalidTrustedThreshold();\n\n _previousTrustedNum = _num;\n _previousTrustedDenom = _denom;\n _trustedNum = _trustedNumerator;\n _trustedDenom = _trustedDenominator;\n unchecked {\n emit TrustedThresholdUpdated(\n nonce++,\n _trustedNumerator,\n _trustedDenominator,\n _previousTrustedNum,\n _previousTrustedDenom\n );\n }\n }\n\n /**\n * @dev Returns minimum trusted vote weight.\n */\n function _minimumTrustedVoteWeight(uint256 _totalTrustedWeight) internal view virtual returns (uint256) {\n return (_trustedNum * _totalTrustedWeight + _trustedDenom - 1) / _trustedDenom;\n }\n}\n" + }, + "contracts/ronin/Maintenance.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IMaintenance.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../utils/CommonErrors.sol\";\n\ncontract Maintenance is IMaintenance, HasContracts, HasValidatorDeprecated, Initializable {\n using Math for uint256;\n\n /// @dev Mapping from consensus address => maintenance schedule.\n mapping(address => Schedule) internal _schedule;\n\n /// @dev The min duration to maintenance in blocks.\n uint256 public minMaintenanceDurationInBlock;\n /// @dev The max duration to maintenance in blocks.\n uint256 public maxMaintenanceDurationInBlock;\n /// @dev The offset to the min block number that the schedule can start.\n uint256 public minOffsetToStartSchedule;\n /// @dev The offset to the max block number that the schedule can start.\n uint256 public maxOffsetToStartSchedule;\n /// @dev The max number of scheduled maintenances.\n uint256 public maxSchedule;\n /// @dev The cooldown time to request new schedule.\n uint256 public cooldownSecsToMaintain;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedules,\n uint256 _cooldownSecsToMaintain\n ) external onlyAdmin {\n _setMaintenanceConfig(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedules,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function schedule(address _consensusAddr, uint256 _startedAtBlock, uint256 _endedAtBlock) external override {\n IRoninValidatorSet _validator = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n\n if (!_validator.isBlockProducer(_consensusAddr)) revert ErrUnauthorized(msg.sig, RoleAccess.BLOCK_PRODUCER);\n if (!_validator.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n if (checkScheduled(_consensusAddr)) revert ErrAlreadyScheduled();\n if (!checkCooldownEnded(_consensusAddr)) revert ErrCooldownTimeNotYetEnded();\n if (totalSchedule() >= maxSchedule) revert ErrTotalOfSchedulesExceeded();\n if (!_startedAtBlock.inRange(block.number + minOffsetToStartSchedule, block.number + maxOffsetToStartSchedule)) {\n revert ErrStartBlockOutOfRange();\n }\n if (_startedAtBlock >= _endedAtBlock) revert ErrStartBlockOutOfRange();\n\n uint256 _maintenanceElapsed = _endedAtBlock - _startedAtBlock + 1;\n\n if (!_maintenanceElapsed.inRange(minMaintenanceDurationInBlock, maxMaintenanceDurationInBlock)) {\n revert ErrInvalidMaintenanceDuration();\n }\n if (!_validator.epochEndingAt(_startedAtBlock - 1)) revert ErrStartBlockOutOfRange();\n if (!_validator.epochEndingAt(_endedAtBlock)) revert ErrEndBlockOutOfRange();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n _sSchedule.from = _startedAtBlock;\n _sSchedule.to = _endedAtBlock;\n _sSchedule.lastUpdatedBlock = block.number;\n _sSchedule.requestTimestamp = block.timestamp;\n emit MaintenanceScheduled(_consensusAddr, _sSchedule);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function cancelSchedule(address _consensusAddr) external override {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(_consensusAddr, msg.sender)) {\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n }\n if (!checkScheduled(_consensusAddr)) revert ErrUnexistedSchedule();\n if (checkMaintained(_consensusAddr, block.number)) revert ErrAlreadyOnMaintenance();\n\n Schedule storage _sSchedule = _schedule[_consensusAddr];\n delete _sSchedule.from;\n delete _sSchedule.to;\n _sSchedule.lastUpdatedBlock = block.number;\n emit MaintenanceScheduleCancelled(_consensusAddr);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function getSchedule(address _consensusAddr) external view override returns (Schedule memory) {\n return _schedule[_consensusAddr];\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintained(\n address[] calldata _addrList,\n uint256 _block\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = checkMaintained(_addrList[_i], _block);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkManyMaintainedInBlockRange(\n address[] calldata _addrList,\n uint256 _fromBlock,\n uint256 _toBlock\n ) external view override returns (bool[] memory _resList) {\n _resList = new bool[](_addrList.length);\n for (uint _i = 0; _i < _addrList.length; ) {\n _resList[_i] = _maintainingInBlockRange(_addrList[_i], _fromBlock, _toBlock);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function totalSchedule() public view override returns (uint256 _count) {\n address[] memory _validators = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).getValidators();\n unchecked {\n for (uint _i = 0; _i < _validators.length; _i++) {\n if (checkScheduled(_validators[_i])) {\n _count++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintained(address _consensusAddr, uint256 _block) public view override returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return _s.from <= _block && _block <= _s.to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkMaintainedInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) public view override returns (bool) {\n return _maintainingInBlockRange(_consensusAddr, _fromBlock, _toBlock);\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkScheduled(address _consensusAddr) public view override returns (bool) {\n return block.number <= _schedule[_consensusAddr].to;\n }\n\n /**\n * @inheritdoc IMaintenance\n */\n function checkCooldownEnded(address _consensusAddr) public view override returns (bool) {\n return block.timestamp > _schedule[_consensusAddr].requestTimestamp + cooldownSecsToMaintain;\n }\n\n /**\n * @dev Sets the min block period and max block period to maintenance.\n *\n * Requirements:\n * - The max period is larger than the min period.\n *\n * Emits the event `MaintenanceConfigUpdated`.\n *\n */\n function _setMaintenanceConfig(\n uint256 _minMaintenanceDurationInBlock,\n uint256 _maxMaintenanceDurationInBlock,\n uint256 _minOffsetToStartSchedule,\n uint256 _maxOffsetToStartSchedule,\n uint256 _maxSchedule,\n uint256 _cooldownSecsToMaintain\n ) internal {\n if (_minMaintenanceDurationInBlock >= _maxMaintenanceDurationInBlock) revert ErrInvalidMaintenanceDurationConfig();\n if (_minOffsetToStartSchedule >= _maxOffsetToStartSchedule) revert ErrInvalidOffsetToStartScheduleConfigs();\n\n minMaintenanceDurationInBlock = _minMaintenanceDurationInBlock;\n maxMaintenanceDurationInBlock = _maxMaintenanceDurationInBlock;\n minOffsetToStartSchedule = _minOffsetToStartSchedule;\n maxOffsetToStartSchedule = _maxOffsetToStartSchedule;\n maxSchedule = _maxSchedule;\n cooldownSecsToMaintain = _cooldownSecsToMaintain;\n emit MaintenanceConfigUpdated(\n _minMaintenanceDurationInBlock,\n _maxMaintenanceDurationInBlock,\n _minOffsetToStartSchedule,\n _maxOffsetToStartSchedule,\n _maxSchedule,\n _cooldownSecsToMaintain\n );\n }\n\n /**\n * @dev Check if the validator was maintaining in the current period.\n *\n * Note: This method should be called at the end of the period.\n */\n function _maintainingInBlockRange(\n address _consensusAddr,\n uint256 _fromBlock,\n uint256 _toBlock\n ) private view returns (bool) {\n Schedule storage _s = _schedule[_consensusAddr];\n return Math.twoRangeOverlap(_fromBlock, _toBlock, _s.from, _s.to);\n }\n}\n" + }, + "contracts/ronin/profile/Profile.sol": { + "content": "// SPDX-License-Identifier: MIT\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IProfile.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\nimport { ContractType } from \"../../utils/ContractType.sol\";\nimport \"./ProfileHandler.sol\";\n\npragma solidity ^0.8.9;\n\ncontract Profile is IProfile, ProfileHandler, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n function initialize(address validatorContract) external initializer {\n _setContract(ContractType.VALIDATOR, validatorContract);\n }\n\n function migrateMainnetV2() external {\n require(block.chainid == 2020, \"mismatch chainID\");\n require(msg.sender == 0x4d58Ea7231c394d5804e8B06B1365915f906E27F, \"not mainnet deployer\");\n\n address[29] memory consensusList = [\n 0x52C0dcd83aa1999BA6c3b0324C8299E30207373C,\n 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38,\n 0xE07D7e56588a6FD860c5073c70a099658C060F3D,\n 0x52349003240770727900b06a3B3a90f5c0219ADe,\n 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8,\n 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e,\n 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5,\n 0xd11D9842baBd5209b9B1155e46f5878c989125b7,\n 0x61089875fF9e506ae78C7FE9f7c388416520E386,\n 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159,\n 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1,\n 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D,\n 0x9B959D27840a31988410Ee69991BCF0110D61F02,\n 0xEE11d2016e9f2faE606b2F12986811F4abbe6215,\n 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01,\n 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf,\n 0x6E46924371d0e910769aaBE0d867590deAC20684,\n 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc,\n 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B,\n 0x32D619Dc6188409CebbC52f921Ab306F07DB085b,\n 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984,\n 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9,\n 0xFc3e31519B551bd594235dd0eF014375a87C4e21,\n 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0,\n 0x22C23429e46e7944D2918F2B368b799b11C417C1,\n 0x03A7B98C226225e330d11D1B9177891391Fa4f80,\n 0x20238eB5643d4D7b7Ab3C30f3bf7B8E2B85cA1e7,\n 0x07d28F88D677C4056EA6722aa35d92903b2a63da,\n 0x262B9fcfe8CFA900aF4D1f5c20396E969B9655DD\n ];\n\n CandidateProfile storage _profile;\n for (uint i; i < consensusList.length; i++) {\n _profile = _id2Profile[consensusList[i]];\n _profile.id = consensusList[i];\n }\n }\n\n /**\n * @inheritdoc IProfile\n */\n function getId2Profile(address id) external view returns (CandidateProfile memory) {\n return _id2Profile[id];\n }\n\n /**\n * @inheritdoc IProfile\n */\n function addNewProfile(CandidateProfile memory profile) external onlyAdmin {\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function registerProfile(CandidateProfile memory profile) external {\n if (profile.id != profile.consensus) revert ErrIdAndConsensusDiffer();\n\n CandidateProfile storage _profile = _id2Profile[profile.id];\n if (_profile.id != address(0)) revert ErrExistentProfile();\n if (\n msg.sender != profile.admin ||\n !IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isCandidateAdmin(profile.consensus, profile.admin)\n ) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkDuplicatedInRegistry(profile);\n\n _addNewProfile(_profile, profile);\n }\n\n /**\n * @inheritdoc IProfile\n */\n function changePubkey(address id, bytes memory pubkey) external {\n CandidateProfile storage _profile = _getId2ProfileHelper(id);\n if (msg.sender != _profile.admin) revert ErrUnauthorized(msg.sig, RoleAccess.ADMIN);\n _checkNonDuplicatedPubkey(pubkey);\n _setPubkey(_profile, pubkey);\n\n emit PubkeyChanged(id, pubkey);\n }\n}\n" + }, + "contracts/ronin/profile/ProfileHandler.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../utils/RoleAccess.sol\";\nimport { ProfileStorage } from \"./ProfileStorage.sol\";\n\nabstract contract ProfileHandler is ProfileStorage {\n /**\n * @dev Checks each element in the new profile and reverts if there is duplication with any existing profile.\n */\n function _checkDuplicatedInRegistry(CandidateProfile memory profile) internal view {\n _checkNonZeroAndNonDuplicated(RoleAccess.CONSENSUS, profile.consensus);\n _checkNonZeroAndNonDuplicated(RoleAccess.CANDIDATE_ADMIN, profile.admin);\n _checkNonZeroAndNonDuplicated(RoleAccess.TREASURY, profile.treasury);\n _checkNonDuplicated(RoleAccess.TREASURY, profile.governor);\n _checkNonDuplicatedPubkey(profile.pubkey);\n }\n\n function _checkNonZeroAndNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (addr == address(0)) revert ErrZeroAddress(addressType);\n _checkNonDuplicated(addressType, addr);\n }\n\n function _checkNonDuplicated(RoleAccess addressType, address addr) internal view {\n if (_registry[uint256(uint160(addr))]) {\n revert ErrDuplicatedInfo(addressType, uint256(uint160(addr)));\n }\n }\n\n function _checkNonDuplicatedPubkey(bytes memory pubkey) internal view {\n if (_registry[_hashPubkey(pubkey)]) {\n revert ErrDuplicatedPubkey(pubkey);\n }\n }\n}\n" + }, + "contracts/ronin/profile/ProfileStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\n\nabstract contract ProfileStorage is IProfile, HasContracts {\n /// @dev Mapping from id address => candidate profile.\n mapping(address => CandidateProfile) internal _id2Profile;\n /**\n * @dev Mapping from any address or keccak256(pubkey) => whether it is already registered.\n * This registry can only be toggled to `true` and NOT vice versa. All registered values\n * cannot be reused.\n */\n mapping(uint256 => bool) internal _registry;\n /// @dev Upgradeable gap.\n bytes32[49] __gap;\n\n /**\n * @dev Add a profile from memory to storage.\n */\n function _addNewProfile(CandidateProfile storage _profile, CandidateProfile memory newProfile) internal {\n _profile.id = newProfile.id;\n\n _setConsensus(_profile, newProfile.consensus);\n _setAdmin(_profile, newProfile.admin);\n _setTreasury(_profile, newProfile.treasury);\n _setGovernor(_profile, newProfile.governor);\n _setPubkey(_profile, newProfile.pubkey);\n\n emit ProfileAdded(newProfile.id);\n }\n\n function _setConsensus(CandidateProfile storage _profile, address consensus) internal {\n _profile.consensus = consensus;\n _registry[uint256(uint160(consensus))] = true;\n }\n\n function _setAdmin(CandidateProfile storage _profile, address admin) internal {\n _profile.admin = admin;\n _registry[uint256(uint160(admin))] = true;\n }\n\n function _setTreasury(CandidateProfile storage _profile, address payable treasury) internal {\n _profile.treasury = treasury;\n _registry[uint256(uint160(address(treasury)))] = true;\n }\n\n /**\n * @dev Allow to registry a profile without governor address since not all validators are governing validators.\n */\n function _setGovernor(CandidateProfile storage _profile, address governor) internal {\n _profile.governor = governor;\n if (governor != address(0)) {\n _registry[uint256(uint160(governor))] = true;\n }\n }\n\n function _setPubkey(CandidateProfile storage _profile, bytes memory pubkey) internal {\n _profile.pubkey = pubkey;\n _registry[_hashPubkey(pubkey)] = true;\n }\n\n /**\n * @dev Get an existed profile struct from `id`. Revert if the profile does not exists.\n */\n function _getId2ProfileHelper(address id) internal view returns (CandidateProfile storage _profile) {\n _profile = _id2Profile[id];\n if (_profile.id == address(0)) revert ErrNonExistentProfile();\n }\n\n /**\n * @dev Returns hash of a public key.\n */\n function _hashPubkey(bytes memory pubkey) internal pure returns (uint256) {\n return uint256(keccak256(pubkey));\n }\n}\n" + }, + "contracts/ronin/RoninGovernanceAdmin.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport \"../extensions/sequential-governance/governance-proposal/GovernanceProposal.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/GovernanceAdmin.sol\";\nimport \"../libraries/EmergencyExitBallot.sol\";\nimport { ErrorHandler } from \"../libraries/ErrorHandler.sol\";\nimport { IsolatedGovernance } from \"../libraries/IsolatedGovernance.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../interfaces/IRoninGovernanceAdmin.sol\";\n\ncontract RoninGovernanceAdmin is\n HasContracts,\n IRoninGovernanceAdmin,\n GovernanceAdmin,\n GovernanceProposal,\n HasValidatorDeprecated\n{\n using ErrorHandler for bool;\n using Proposal for Proposal.ProposalDetail;\n using IsolatedGovernance for IsolatedGovernance.Vote;\n\n /// @dev Mapping from request hash => emergency poll\n mapping(bytes32 => IsolatedGovernance.Vote) internal _emergencyExitPoll;\n\n modifier onlyGovernor() {\n _requireGorvernor();\n _;\n }\n\n constructor(\n uint256 _roninChainId,\n address _roninTrustedOrganizationContract,\n address _validatorContract,\n uint256 _expiryDuration\n ) CoreGovernance(_expiryDuration) GovernanceAdmin(_roninChainId, _roninTrustedOrganizationContract) {\n _setContract(ContractType.VALIDATOR, _validatorContract);\n }\n\n function _requireGorvernor() private view {\n if (_getWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n }\n\n /**\n * @inheritdoc IHasContracts\n */\n function setContract(\n ContractType contractType,\n address addr\n ) external override(HasContracts, GovernanceAdmin) onlySelfCall {\n _requireHasCode(addr);\n _setContract(contractType, addr);\n }\n\n /**\n * @dev Returns whether the voter casted vote for emergency exit poll.\n */\n function emergencyPollVoted(bytes32 _voteHash, address _voter) external view returns (bool) {\n return _emergencyExitPoll[_voteHash].voted(_voter);\n }\n\n /**\n * @dev See `CoreGovernance-_proposeProposal`.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function propose(\n uint256 _chainId,\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts\n ) external onlyGovernor {\n _proposeProposal(_chainId, _expiryTimestamp, _targets, _values, _calldatas, _gasAmounts, msg.sender);\n }\n\n /**\n * @dev See `GovernanceProposal-_proposeProposalStructAndCastVotes`.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalStructAndCastVotes(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external onlyGovernor {\n _proposeProposalStructAndCastVotes(_proposal, _supports, _signatures, DOMAIN_SEPARATOR, msg.sender);\n }\n\n /**\n * @dev Proposes and casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n * - The proposal is for the current network.\n *\n */\n function proposeProposalForCurrentNetwork(\n uint256 _expiryTimestamp,\n address[] calldata _targets,\n uint256[] calldata _values,\n bytes[] calldata _calldatas,\n uint256[] calldata _gasAmounts,\n Ballot.VoteType _support\n ) external onlyGovernor {\n address _voter = msg.sender;\n Proposal.ProposalDetail memory _proposal = _proposeProposal(\n block.chainid,\n _expiryTimestamp,\n _targets,\n _values,\n _calldatas,\n _gasAmounts,\n _voter\n );\n _castProposalVoteForCurrentNetwork(_voter, _proposal, _support);\n }\n\n /**\n * @dev Casts vote for a proposal on the current network.\n *\n * Requirements:\n * - The method caller is governor.\n *\n */\n function castProposalVoteForCurrentNetwork(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType _support\n ) external onlyGovernor {\n _castProposalVoteForCurrentNetwork(msg.sender, _proposal, _support);\n }\n\n /**\n * @dev See `GovernanceProposal-_castProposalBySignatures`.\n */\n function castProposalBySignatures(\n Proposal.ProposalDetail calldata _proposal,\n Ballot.VoteType[] calldata _supports,\n Signature[] calldata _signatures\n ) external {\n _castProposalBySignatures(_proposal, _supports, _signatures, DOMAIN_SEPARATOR);\n }\n\n /**\n * @dev Deletes the expired proposal by its chainId and nonce, without creating a new proposal.\n *\n * Requirements:\n * - The proposal is already created.\n *\n */\n function deleteExpired(uint256 _chainId, uint256 _round) external {\n ProposalVote storage _vote = vote[_chainId][_round];\n if (_vote.hash == 0) revert ErrQueryForEmptyVote();\n\n _tryDeleteExpiredVotingRound(_vote);\n }\n\n /**\n * @inheritdoc IRoninGovernanceAdmin\n */\n function createEmergencyExitPoll(\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyContract(ContractType.VALIDATOR) {\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n _v.createdAt = block.timestamp;\n _v.expiredAt = _expiredAt;\n emit EmergencyExitPollCreated(_hash, _consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n }\n\n /**\n * @dev Votes for an emergency exit. Executes to unlock fund for the emergency exit's requester.\n *\n * Requirements:\n * - The voter is governor.\n * - The voting is existent.\n * - The voting is not expired yet.\n *\n */\n function voteEmergencyExit(\n bytes32 _voteHash,\n address _consensusAddr,\n address _recipientAfterUnlockedFund,\n uint256 _requestedAt,\n uint256 _expiredAt\n ) external onlyGovernor {\n address _voter = msg.sender;\n bytes32 _hash = EmergencyExitBallot.hash(_consensusAddr, _recipientAfterUnlockedFund, _requestedAt, _expiredAt);\n if (_voteHash != _hash) revert ErrInvalidVoteHash();\n\n IsolatedGovernance.Vote storage _v = _emergencyExitPoll[_hash];\n if (_v.createdAt == 0) revert ErrQueryForNonExistentVote();\n if (_v.status == VoteStatus.Expired) revert ErrQueryForExpiredVote();\n\n _v.castVote(_voter, _hash);\n emit EmergencyExitPollVoted(_hash, _voter);\n\n address[] memory _voters = _v.filterByHash(_hash);\n VoteStatus _stt = _v.syncVoteStatus(_getMinimumVoteWeight(), _sumGovernorWeight(_voters), _hash);\n if (_stt == VoteStatus.Approved) {\n _execReleaseLockedFundForEmergencyExitRequest(_consensusAddr, _recipientAfterUnlockedFund);\n emit EmergencyExitPollApproved(_hash);\n _v.status = VoteStatus.Executed;\n } else if (_stt == VoteStatus.Expired) {\n emit EmergencyExitPollExpired(_hash);\n }\n }\n\n /**\n * @dev Returns weight of a govenor.\n */\n function _getWeight(address _governor) internal view virtual override returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.getGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governor)\n )\n );\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Returns the total weight of a list address of governors.\n */\n function _sumGovernorWeight(address[] memory _governors) internal view virtual returns (uint256) {\n bytes4 _selector = IRoninTrustedOrganization.sumGovernorWeight.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.RONIN_TRUSTED_ORGANIZATION).staticcall(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _governors)\n )\n );\n\n _success.handleRevert(_selector, _returndata);\n return abi.decode(_returndata, (uint256));\n }\n\n /**\n * @dev Trigger function from validator contract to unlock fund for emeregency exit request.\n */\n function _execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address _recipientAfterUnlockedFund\n ) internal virtual {\n bytes4 _selector = IEmergencyExit.execReleaseLockedFundForEmergencyExitRequest.selector;\n (bool _success, bytes memory _returndata) = getContract(ContractType.VALIDATOR).call(\n abi.encodeWithSelector(\n // TransparentUpgradeableProxyV2.functionDelegateCall.selector,\n 0x4bb5274a,\n abi.encodeWithSelector(_selector, _consensusAddr, _recipientAfterUnlockedFund)\n )\n );\n _success.handleRevert(_selector, _returndata);\n }\n\n /**\n * @dev See `CoreGovernance-_getChainType`.\n */\n function _getChainType() internal pure override returns (ChainType) {\n return ChainType.RoninChain;\n }\n}\n" + }, + "contracts/ronin/slash-indicator/CreditScore.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ICreditScore.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasMaintenanceDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrUnauthorized, RoleAccess } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CreditScore is\n ICreditScore,\n HasContracts,\n HasValidatorDeprecated,\n HasMaintenanceDeprecated,\n PercentageConsumer\n{\n /// @dev Mapping from validator address => period index => whether bailed out before\n mapping(address => mapping(uint256 => bool)) internal _checkBailedOutAtPeriod;\n /// @dev Mapping from validator address => credit score\n mapping(address => uint256) internal _creditScore;\n\n /// @dev The max gained number of credit score per period.\n uint256 internal _gainCreditScore;\n /// @dev The max number of credit score that a validator can hold.\n uint256 internal _maxCreditScore;\n /// @dev The number that will be multiplied with the remaining jailed time to get the cost of bailing out.\n uint256 internal _bailOutCostMultiplier;\n /// @dev The percentage of reward to be cut off from the validator in the rest of the period after bailed out.\n uint256 internal _cutOffPercentageAfterBailout;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ICreditScore\n */\n function updateCreditScores(\n address[] calldata _validators,\n uint256 _period\n ) external override onlyContract(ContractType.VALIDATOR) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(msg.sender);\n uint256 _periodStartAtBlock = _validatorContract.currentPeriodStartAtBlock();\n\n bool[] memory _jaileds = _validatorContract.checkManyJailed(_validators);\n bool[] memory _maintaineds = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintainedInBlockRange(\n _validators,\n _periodStartAtBlock,\n block.number\n );\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n\n uint256 _indicator = getUnavailabilityIndicator(_validator, _period);\n bool _isJailedInPeriod = _jaileds[_i];\n bool _isMaintainingInPeriod = _maintaineds[_i];\n\n uint256 _actualGain = (_isJailedInPeriod || _isMaintainingInPeriod)\n ? 0\n : Math.subNonNegative(_gainCreditScore, _indicator);\n\n _creditScore[_validator] = Math.addWithUpperbound(_creditScore[_validator], _actualGain, _maxCreditScore);\n _updatedCreditScores[_i] = _creditScore[_validator];\n unchecked {\n ++_i;\n }\n }\n\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n function execResetCreditScores(\n address[] calldata _validators\n ) external override onlyContract(ContractType.VALIDATOR) {\n uint256[] memory _updatedCreditScores = new uint256[](_validators.length);\n for (uint _i = 0; _i < _validators.length; ) {\n address _validator = _validators[_i];\n delete _creditScore[_validator];\n delete _updatedCreditScores[_i];\n\n unchecked {\n ++_i;\n }\n }\n emit CreditScoresUpdated(_validators, _updatedCreditScores);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function bailOut(address _consensusAddr) external override {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (!_validatorContract.isValidatorCandidate(_consensusAddr))\n revert ErrUnauthorized(msg.sig, RoleAccess.VALIDATOR_CANDIDATE);\n\n if (!_validatorContract.isCandidateAdmin(_consensusAddr, msg.sender))\n revert ErrUnauthorized(msg.sig, RoleAccess.CANDIDATE_ADMIN);\n\n (bool _isJailed, , uint256 _jailedEpochLeft) = _validatorContract.getJailedTimeLeft(_consensusAddr);\n if (!_isJailed) revert ErrCallerMustBeJailedInTheCurrentPeriod();\n\n uint256 _period = _validatorContract.currentPeriod();\n if (_checkBailedOutAtPeriod[_consensusAddr][_period]) revert ErrValidatorHasBailedOutPreviously();\n\n uint256 _score = _creditScore[_consensusAddr];\n uint256 _cost = _jailedEpochLeft * _bailOutCostMultiplier;\n if (_score < _cost) revert ErrInsufficientCreditScoreToBailOut();\n\n _validatorContract.execBailOut(_consensusAddr, _period);\n\n _creditScore[_consensusAddr] -= _cost;\n _setUnavailabilityIndicator(_consensusAddr, _period, 0);\n _checkBailedOutAtPeriod[_consensusAddr][_period] = true;\n emit BailedOut(_consensusAddr, _period, _cost);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) external override onlyAdmin {\n _setCreditScoreConfigs(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n\n /**\n * @dev See `ISlashUnavailability`\n */\n function getUnavailabilityIndicator(address _validator, uint256 _period) public view virtual returns (uint256);\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScoreConfigs()\n external\n view\n override\n returns (\n uint256 gainCreditScore_,\n uint256 maxCreditScore_,\n uint256 bailOutCostMultiplier_,\n uint256 cutOffPercentageAfterBailout_\n )\n {\n return (_gainCreditScore, _maxCreditScore, _bailOutCostMultiplier, _cutOffPercentageAfterBailout);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getCreditScore(address _validator) external view override returns (uint256) {\n return _creditScore[_validator];\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function getManyCreditScores(\n address[] calldata _validators\n ) public view override returns (uint256[] memory _resultList) {\n _resultList = new uint256[](_validators.length);\n\n for (uint _i = 0; _i < _resultList.length; ) {\n _resultList[_i] = _creditScore[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual override returns (bool) {\n return _checkBailedOutAtPeriod[_validator][_period];\n }\n\n /**\n * @dev See `SlashUnavailability`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual;\n\n /**\n * @dev See `ICreditScore-setCreditScoreConfigs`.\n */\n function _setCreditScoreConfigs(\n uint256 _gainScore,\n uint256 _maxScore,\n uint256 _bailOutMultiplier,\n uint256 _cutOffPercentage\n ) internal {\n if (_gainScore > _maxScore) revert ErrInvalidCreditScoreConfig();\n if (_cutOffPercentage > _MAX_PERCENTAGE) revert ErrInvalidCutOffPercentageConfig();\n\n _gainCreditScore = _gainScore;\n _maxCreditScore = _maxScore;\n _bailOutCostMultiplier = _bailOutMultiplier;\n _cutOffPercentageAfterBailout = _cutOffPercentage;\n emit CreditScoreConfigsUpdated(_gainScore, _maxScore, _bailOutMultiplier, _cutOffPercentage);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeOperator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../extensions/collections/HasProxyAdmin.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeOperator.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashBridgeOperator is\n ISlashBridgeOperator,\n HasProxyAdmin,\n HasContracts,\n HasValidatorDeprecated,\n PercentageConsumer\n{\n /**\n * @dev The bridge operators will be deprecated reward if (s)he missed more than the ratio.\n * Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier1;\n /**\n * @dev The bridge operators will be deprecated all rewards including bridge reward and mining reward if (s)he missed\n * more than the ratio. Values 0-10,000 map to 0%-100%.\n */\n uint256 internal _missingVotesRatioTier2;\n /// @dev The number of blocks to jail the corresponding block producer when its bridge operator is slashed tier-2.\n uint256 internal _jailDurationForMissingVotesRatioTier2;\n /// @dev The threshold to skip slashing the bridge operator in case the total number of votes in the bridge is too small.\n uint256 internal _skipBridgeOperatorSlashingThreshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function getBridgeOperatorSlashingConfigs()\n external\n view\n override\n returns (\n uint256 missingVotesRatioTier1_,\n uint256 missingVotesRatioTier2_,\n uint256 jailDurationForMissingVotesRatioTier2_,\n uint256 skipBridgeOperatorSlashingThreshold_\n )\n {\n return (\n _missingVotesRatioTier1,\n _missingVotesRatioTier2,\n _jailDurationForMissingVotesRatioTier2,\n _skipBridgeOperatorSlashingThreshold\n );\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) external override onlyAdmin {\n _setBridgeOperatorSlashingConfigs(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n\n /**\n * @inheritdoc ISlashBridgeOperator\n */\n function execSlashBridgeOperator(\n address _consensusAddr,\n uint256 _tier,\n uint256 _period\n ) external onlyContract(ContractType.VALIDATOR) {\n if (_tier == 1) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_1, _period);\n } else if (_tier == 2) {\n emit Slashed(_consensusAddr, SlashType.BRIDGE_OPERATOR_MISSING_VOTE_TIER_2, _period);\n }\n }\n\n /**\n * @dev See `ISlashBridgeOperator-setBridgeOperatorSlashingConfigs`.\n */\n function _setBridgeOperatorSlashingConfigs(\n uint256 _ratioTier1,\n uint256 _ratioTier2,\n uint256 _jailDurationTier2,\n uint256 _skipSlashingThreshold\n ) internal {\n if (_ratioTier1 > _ratioTier2 || _ratioTier1 > _MAX_PERCENTAGE || _ratioTier2 > _MAX_PERCENTAGE) {\n revert ErrInvalidRatios();\n }\n\n _missingVotesRatioTier1 = _ratioTier1;\n _missingVotesRatioTier2 = _ratioTier2;\n _jailDurationForMissingVotesRatioTier2 = _jailDurationTier2;\n _skipBridgeOperatorSlashingThreshold = _skipSlashingThreshold;\n emit BridgeOperatorSlashingConfigsUpdated(_ratioTier1, _ratioTier2, _jailDurationTier2, _skipSlashingThreshold);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashBridgeVoting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated, HasTrustedOrgDeprecated, HasGovernanceAdminDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { IBridgeAdminProposal } from \"../../interfaces/IBridgeAdminProposal.sol\";\nimport \"../../interfaces/slash-indicator/ISlashBridgeVoting.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\n\n// TODO: remove this from slashing logic of consensus contract\nabstract contract SlashBridgeVoting is\n ISlashBridgeVoting,\n HasContracts,\n HasValidatorDeprecated,\n HasTrustedOrgDeprecated,\n HasGovernanceAdminDeprecated\n{\n /// @dev Mapping from validator address => period index => bridge voting slashed\n mapping(address => mapping(uint256 => bool)) internal _bridgeVotingSlashed;\n /// @dev The threshold to slash when a trusted organization does not vote for bridge operators.\n uint256 internal _bridgeVotingThreshold;\n /// @dev The amount of RON to slash bridge voting.\n uint256 internal _bridgeVotingSlashAmount;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function slashBridgeVoting(address _consensusAddr) external onlyAdmin {\n IRoninTrustedOrganization.TrustedOrganization memory _org = IRoninTrustedOrganization(\n getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)\n ).getTrustedOrganization(_consensusAddr);\n uint256 _lastVotedBlock = Math.max(\n IBridgeAdminProposal(getContract(ContractType.BRIDGE_MANAGER)).lastVotedBlock(_org.bridgeVoter),\n _org.addedBlock\n );\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n\n if (block.number - _lastVotedBlock <= _bridgeVotingThreshold || _bridgeVotingSlashed[_consensusAddr][_period])\n revert ErrInvalidSlash();\n\n _bridgeVotingSlashed[_consensusAddr][_period] = true;\n emit Slashed(_consensusAddr, SlashType.BRIDGE_VOTING, _period);\n _validatorContract.execSlash(_consensusAddr, 0, _bridgeVotingSlashAmount, false);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function getBridgeVotingSlashingConfigs()\n external\n view\n override\n returns (uint256 bridgeVotingThreshold_, uint256 bridgeVotingSlashAmount_)\n {\n return (_bridgeVotingThreshold, _bridgeVotingSlashAmount);\n }\n\n /**\n * @inheritdoc ISlashBridgeVoting\n */\n function setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) external override onlyAdmin {\n _setBridgeVotingSlashingConfigs(_threshold, _slashAmount);\n }\n\n /**\n * @dev See `ISlashBridgeVoting-setBridgeVotingSlashingConfigs`.\n */\n function _setBridgeVotingSlashingConfigs(uint256 _threshold, uint256 _slashAmount) internal {\n _bridgeVotingThreshold = _threshold;\n _bridgeVotingSlashAmount = _slashAmount;\n emit BridgeVotingSlashingConfigsUpdated(_threshold, _slashAmount);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashDoubleSign.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashDoubleSign.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../precompile-usages/PCUValidateDoubleSign.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract SlashDoubleSign is ISlashDoubleSign, HasContracts, HasValidatorDeprecated, PCUValidateDoubleSign {\n /// @dev The amount of RON to slash double sign.\n uint256 internal _slashDoubleSignAmount;\n /// @dev The block number that the punished validator will be jailed until, due to double signing.\n uint256 internal _doubleSigningJailUntilBlock;\n /** @dev The offset from the submitted block to the current block, from which double signing will be invalidated.\n * This parameter is exposed for system transaction.\n **/\n uint256 internal _doubleSigningOffsetLimitBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) _submittedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[24] private ______gap;\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function slashDoubleSign(\n address _consensusAddr,\n bytes calldata _header1,\n bytes calldata _header2\n ) external override onlyAdmin {\n bytes32 _header1Checksum = keccak256(_header1);\n bytes32 _header2Checksum = keccak256(_header2);\n\n if (_submittedEvidence[_header1Checksum] || _submittedEvidence[_header2Checksum]) {\n revert ErrEvidenceAlreadySubmitted();\n }\n\n if (_pcValidateEvidence(_consensusAddr, _header1, _header2)) {\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n _submittedEvidence[_header1Checksum] = true;\n _submittedEvidence[_header2Checksum] = true;\n emit Slashed(_consensusAddr, SlashType.DOUBLE_SIGNING, _period);\n _validatorContract.execSlash(_consensusAddr, _doubleSigningJailUntilBlock, _slashDoubleSignAmount, true);\n }\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function getDoubleSignSlashingConfigs()\n external\n view\n override\n returns (\n uint256 slashDoubleSignAmount_,\n uint256 doubleSigningJailUntilBlock_,\n uint256 doubleSigningOffsetLimitBlock_\n )\n {\n return (_slashDoubleSignAmount, _doubleSigningJailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @inheritdoc ISlashDoubleSign\n */\n function setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) external override onlyAdmin {\n _setDoubleSignSlashingConfigs(_slashAmount, _jailUntilBlock, _offsetLimitBlock);\n }\n\n /**\n * @dev See `ISlashDoubleSign-setDoubleSignSlashingConfigs`.\n */\n function _setDoubleSignSlashingConfigs(\n uint256 _slashAmount,\n uint256 _jailUntilBlock,\n uint256 _offsetLimitBlock\n ) internal {\n _slashDoubleSignAmount = _slashAmount;\n _doubleSigningJailUntilBlock = _jailUntilBlock;\n _doubleSigningOffsetLimitBlock = _offsetLimitBlock;\n emit DoubleSignSlashingConfigsUpdated(_slashAmount, _jailUntilBlock, _doubleSigningOffsetLimitBlock);\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n}\n" + }, + "contracts/ronin/slash-indicator/SlashFastFinality.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/slash-indicator/ISlashFastFinality.sol\";\nimport { IRoninValidatorSet } from \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport { IProfile } from \"../../interfaces/IProfile.sol\";\nimport { IRoninTrustedOrganization } from \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../precompile-usages/PCUValidateFastFinality.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashFastFinality is ISlashFastFinality, HasContracts, PCUValidateFastFinality {\n /// @dev The amount of RON to slash fast finality.\n uint256 internal _slashFastFinalityAmount;\n /// @dev The block number that the punished validator will be jailed until, due to malicious fast finality.\n uint256 internal _fastFinalityJailUntilBlock;\n /// @dev Recording of submitted proof to prevent relay attack.\n mapping(bytes32 => bool) internal _processedEvidence;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[21] private ______gap;\n\n modifier onlyGoverningValidator() {\n if (_getGovernorWeight(msg.sender) == 0) revert ErrUnauthorized(msg.sig, RoleAccess.GOVERNOR);\n _;\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function slashFastFinality(\n address consensusAddr,\n bytes calldata voterPublicKey,\n uint256 targetBlockNumber,\n bytes32[2] calldata targetBlockHash,\n bytes[][2] calldata listOfPublicKey,\n bytes[2] calldata aggregatedSignature\n ) external override onlyGoverningValidator {\n IProfile profileContract = IProfile(getContract(ContractType.PROFILE));\n bytes memory expectingPubKey = (profileContract.getId2Profile(consensusAddr)).pubkey;\n if (keccak256(voterPublicKey) != keccak256(expectingPubKey)) revert ErrInvalidArguments(msg.sig);\n\n bytes32 evidenceHash = keccak256(abi.encodePacked(consensusAddr, targetBlockNumber));\n if (_processedEvidence[evidenceHash]) revert ErrEvidenceAlreadySubmitted();\n\n if (\n _pcValidateFastFinalityEvidence(\n voterPublicKey,\n targetBlockNumber,\n targetBlockHash,\n listOfPublicKey,\n aggregatedSignature\n )\n ) {\n _processedEvidence[evidenceHash] = true;\n\n IRoninValidatorSet validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 period = validatorContract.currentPeriod();\n emit Slashed(consensusAddr, SlashType.FAST_FINALITY, period);\n validatorContract.execSlash({\n validatorAddr: consensusAddr,\n newJailedUntil: _fastFinalityJailUntilBlock,\n slashAmount: _slashFastFinalityAmount,\n cannotBailout: true\n });\n }\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function getFastFinalitySlashingConfigs()\n external\n view\n override\n returns (uint256 slashFastFinalityAmount_, uint256 fastFinalityJailUntilBlock_)\n {\n return (_slashFastFinalityAmount, _fastFinalityJailUntilBlock);\n }\n\n /**\n * @inheritdoc ISlashFastFinality\n */\n function setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) external override onlyAdmin {\n _setFastFinalitySlashingConfigs(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev See `ISlashFastFinality-setFastFinalitySlashingConfigs`.\n */\n function _setFastFinalitySlashingConfigs(uint256 slashAmount, uint256 jailUntilBlock) internal {\n _slashFastFinalityAmount = slashAmount;\n _fastFinalityJailUntilBlock = jailUntilBlock;\n emit FastFinalitySlashingConfigsUpdated(slashAmount, jailUntilBlock);\n }\n\n /**\n * @dev Get governor, i.e. governing validator's weight, of the `addr`.\n */\n function _getGovernorWeight(address addr) internal view returns (uint256) {\n return IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getGovernorWeight(addr);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashIndicator.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"./SlashDoubleSign.sol\";\nimport \"./SlashFastFinality.sol\";\nimport \"./SlashBridgeVoting.sol\";\nimport \"./SlashBridgeOperator.sol\";\nimport \"./SlashUnavailability.sol\";\nimport \"./CreditScore.sol\";\n\ncontract SlashIndicator is\n ISlashIndicator,\n SlashDoubleSign,\n SlashFastFinality,\n SlashBridgeVoting,\n SlashBridgeOperator,\n SlashUnavailability,\n CreditScore,\n Initializable\n{\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address __roninGovernanceAdminContract,\n // _bridgeOperatorSlashingConfigs[0]: _missingVotesRatioTier1\n // _bridgeOperatorSlashingConfigs[1]: _missingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[2]: _jailDurationForMissingVotesRatioTier2\n // _bridgeOperatorSlashingConfigs[3]: _skipBridgeOperatorSlashingThreshold\n uint256[4] calldata _bridgeOperatorSlashingConfigs,\n // _bridgeVotingSlashingConfigs[0]: _bridgeVotingThreshold\n // _bridgeVotingSlashingConfigs[1]: _bridgeVotingSlashAmount\n uint256[2] calldata _bridgeVotingSlashingConfigs,\n // _doubleSignSlashingConfigs[0]: _slashDoubleSignAmount\n // _doubleSignSlashingConfigs[1]: _doubleSigningJailUntilBlock\n // _doubleSignSlashingConfigs[2]: _doubleSigningOffsetLimitBlock\n uint256[3] calldata _doubleSignSlashingConfigs,\n // _unavailabilitySlashingConfigs[0]: _unavailabilityTier1Threshold\n // _unavailabilitySlashingConfigs[1]: _unavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[2]: _slashAmountForUnavailabilityTier2Threshold\n // _unavailabilitySlashingConfigs[3]: _jailDurationForUnavailabilityTier2Threshold\n uint256[4] calldata _unavailabilitySlashingConfigs,\n // _creditScoreConfigs[0]: _gainCreditScore\n // _creditScoreConfigs[1]: _maxCreditScore\n // _creditScoreConfigs[2]: _bailOutCostMultiplier\n // _creditScoreConfigs[3]: _cutOffPercentageAfterBailout\n uint256[4] calldata _creditScoreConfigs\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.GOVERNANCE_ADMIN, __roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setBridgeOperatorSlashingConfigs(\n _bridgeOperatorSlashingConfigs[0],\n _bridgeOperatorSlashingConfigs[1],\n _bridgeOperatorSlashingConfigs[2],\n _bridgeOperatorSlashingConfigs[3]\n );\n _setBridgeVotingSlashingConfigs(_bridgeVotingSlashingConfigs[0], _bridgeVotingSlashingConfigs[1]);\n _setDoubleSignSlashingConfigs(\n _doubleSignSlashingConfigs[0],\n _doubleSignSlashingConfigs[1],\n _doubleSignSlashingConfigs[2]\n );\n _setUnavailabilitySlashingConfigs(\n _unavailabilitySlashingConfigs[0],\n _unavailabilitySlashingConfigs[1],\n _unavailabilitySlashingConfigs[2],\n _unavailabilitySlashingConfigs[3]\n );\n _setCreditScoreConfigs(\n _creditScoreConfigs[0],\n _creditScoreConfigs[1],\n _creditScoreConfigs[2],\n _creditScoreConfigs[3]\n );\n }\n\n function initializeV2(address roninGovernanceAdminContract) external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.GOVERNANCE_ADMIN, roninGovernanceAdminContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedValidator;\n delete ______deprecatedMaintenance;\n delete ______deprecatedTrustedOrg;\n delete ______deprecatedGovernanceAdmin;\n }\n\n function initializeV3(address profileContract) external reinitializer(3) {\n _setContract(ContractType.PROFILE, profileContract);\n _setFastFinalitySlashingConfigs(_slashDoubleSignAmount, _doubleSigningJailUntilBlock);\n }\n\n /**\n * @dev Helper for CreditScore contract to reset the indicator of the validator after bailing out.\n */\n function _setUnavailabilityIndicator(\n address _validator,\n uint256 _period,\n uint256 _indicator\n ) internal override(CreditScore, SlashUnavailability) {\n SlashUnavailability._setUnavailabilityIndicator(_validator, _period, _indicator);\n }\n\n /**\n * @dev Helper for CreditScore contract to query indicator of the validator.\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ISlashUnavailability, SlashUnavailability) returns (uint256) {\n return SlashUnavailability.getUnavailabilityIndicator(_validator, _period);\n }\n\n /**\n * @inheritdoc ICreditScore\n */\n function checkBailedOutAtPeriod(\n address _validator,\n uint256 _period\n ) public view override(CreditScore, ICreditScore, SlashUnavailability) returns (bool) {\n return CreditScore.checkBailedOutAtPeriod(_validator, _period);\n }\n\n /**\n * @dev Sanity check the address to be slashed\n */\n function _shouldSlash(address _addr) internal view override(SlashDoubleSign, SlashUnavailability) returns (bool) {\n return\n (msg.sender != _addr) &&\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isBlockProducer(_addr) &&\n !IMaintenance(getContract(ContractType.MAINTENANCE)).checkMaintained(_addr, block.number);\n }\n}\n" + }, + "contracts/ronin/slash-indicator/SlashUnavailability.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"./CreditScore.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../interfaces/slash-indicator/ISlashUnavailability.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport { ErrInvalidThreshold } from \"../../utils/CommonErrors.sol\";\n\nabstract contract SlashUnavailability is ISlashUnavailability, HasContracts, HasValidatorDeprecated {\n /// @dev The last block that a validator is slashed for unavailability.\n uint256 public lastUnavailabilitySlashedBlock;\n /// @dev Mapping from validator address => period index => unavailability indicator.\n mapping(address => mapping(uint256 => uint256)) internal _unavailabilityIndicator;\n\n /**\n * @dev The mining reward will be deprecated, if (s)he missed more than this threshold.\n * This threshold is applied for tier-1 and tier-3 of unavailability slash.\n */\n uint256 internal _unavailabilityTier1Threshold;\n /**\n * @dev The mining reward will be deprecated, (s)he will be put in jailed, and will be deducted\n * self-staking if (s)he misses more than this threshold. This threshold is applied for tier-2 slash.\n */\n uint256 internal _unavailabilityTier2Threshold;\n /**\n * @dev The amount of RON to deduct from self-staking of a block producer when (s)he is slashed with\n * tier-2 or tier-3.\n **/\n uint256 internal _slashAmountForUnavailabilityTier2Threshold;\n /// @dev The number of blocks to jail a block producer when (s)he is slashed with tier-2 or tier-3.\n uint256 internal _jailDurationForUnavailabilityTier2Threshold;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n modifier oncePerBlock() {\n if (block.number <= lastUnavailabilitySlashedBlock) {\n revert ErrCannotSlashAValidatorTwiceOrSlashMoreThanOneValidatorInOneBlock();\n }\n\n lastUnavailabilitySlashedBlock = block.number;\n _;\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function slashUnavailability(address _validatorAddr) external override oncePerBlock {\n if (msg.sender != block.coinbase) revert ErrUnauthorized(msg.sig, RoleAccess.COINBASE);\n\n if (!_shouldSlash(_validatorAddr)) {\n // Should return instead of throwing error since this is a part of system transaction.\n return;\n }\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n uint256 _period = _validatorContract.currentPeriod();\n uint256 _count;\n unchecked {\n _count = ++_unavailabilityIndicator[_validatorAddr][_period];\n }\n uint256 _newJailedUntilBlock = Math.addIfNonZero(block.number, _jailDurationForUnavailabilityTier2Threshold);\n\n if (_count == _unavailabilityTier2Threshold) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_2, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n false\n );\n } else if (_count == _unavailabilityTier1Threshold) {\n bool _tier1SecondTime = checkBailedOutAtPeriod(_validatorAddr, _period);\n if (!_tier1SecondTime) {\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_1, _period);\n _validatorContract.execSlash(_validatorAddr, 0, 0, false);\n } else {\n /// Handles tier-3\n emit Slashed(_validatorAddr, SlashType.UNAVAILABILITY_TIER_3, _period);\n _validatorContract.execSlash(\n _validatorAddr,\n _newJailedUntilBlock,\n _slashAmountForUnavailabilityTier2Threshold,\n true\n );\n }\n }\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) external override onlyAdmin {\n _setUnavailabilitySlashingConfigs(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilitySlashingConfigs()\n external\n view\n override\n returns (\n uint256 unavailabilityTier1Threshold_,\n uint256 unavailabilityTier2Threshold_,\n uint256 slashAmountForUnavailabilityTier2Threshold_,\n uint256 jailDurationForUnavailabilityTier2Threshold_\n )\n {\n return (\n _unavailabilityTier1Threshold,\n _unavailabilityTier2Threshold,\n _slashAmountForUnavailabilityTier2Threshold,\n _jailDurationForUnavailabilityTier2Threshold\n );\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function currentUnavailabilityIndicator(address _validator) external view override returns (uint256) {\n return\n getUnavailabilityIndicator(_validator, IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod());\n }\n\n /**\n * @inheritdoc ISlashUnavailability\n */\n function getUnavailabilityIndicator(\n address _validator,\n uint256 _period\n ) public view virtual override returns (uint256) {\n return _unavailabilityIndicator[_validator][_period];\n }\n\n /**\n * @dev Sets the unavailability indicator of the `_validator` at `_period`.\n */\n function _setUnavailabilityIndicator(address _validator, uint256 _period, uint256 _indicator) internal virtual {\n _unavailabilityIndicator[_validator][_period] = _indicator;\n }\n\n /**\n * @dev See `ISlashUnavailability-setUnavailabilitySlashingConfigs`.\n */\n function _setUnavailabilitySlashingConfigs(\n uint256 _tier1Threshold,\n uint256 _tier2Threshold,\n uint256 _slashAmountForTier2Threshold,\n uint256 _jailDurationForTier2Threshold\n ) internal {\n if (_unavailabilityTier1Threshold > _unavailabilityTier2Threshold) revert ErrInvalidThreshold(msg.sig);\n\n _unavailabilityTier1Threshold = _tier1Threshold;\n _unavailabilityTier2Threshold = _tier2Threshold;\n _slashAmountForUnavailabilityTier2Threshold = _slashAmountForTier2Threshold;\n _jailDurationForUnavailabilityTier2Threshold = _jailDurationForTier2Threshold;\n emit UnavailabilitySlashingConfigsUpdated(\n _tier1Threshold,\n _tier2Threshold,\n _slashAmountForTier2Threshold,\n _jailDurationForTier2Threshold\n );\n }\n\n /**\n * @dev Returns whether the account `_addr` should be slashed or not.\n */\n function _shouldSlash(address _addr) internal view virtual returns (bool);\n\n /**\n * @dev See `ICreditScore-checkBailedOutAtPeriod`\n */\n function checkBailedOutAtPeriod(address _validator, uint256 _period) public view virtual returns (bool);\n}\n" + }, + "contracts/ronin/staking/BaseStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/security/ReentrancyGuard.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/staking/IBaseStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasValidatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./RewardCalculation.sol\";\n\nabstract contract BaseStaking is\n RONTransferHelper,\n ReentrancyGuard,\n RewardCalculation,\n HasContracts,\n IBaseStaking,\n HasValidatorDeprecated\n{\n /// @dev Mapping from pool address => staking pool detail\n mapping(address => PoolDetail) internal _stakingPool;\n\n /// @dev The cooldown time in seconds to undelegate from the last timestamp (s)he delegated.\n uint256 internal _cooldownSecsToUndelegate;\n /// @dev The number of seconds that a candidate must wait to be revoked and take the self-staking amount back.\n uint256 internal _waitingSecsToRevoke;\n\n /// @dev Mapping from admin address of an active pool => consensus address.\n mapping(address => address) internal _adminOfActivePoolMapping;\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n modifier noEmptyValue() {\n _requireValue();\n _;\n }\n\n modifier anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) {\n _anyExceptPoolAdmin(_pool, _delegator);\n _;\n }\n\n modifier onlyPoolAdmin(PoolDetail storage _pool, address _requester) {\n _requirePoolAdmin(_pool, _requester);\n _;\n }\n\n modifier poolIsActive(address _poolAddr) {\n _poolIsActive(_poolAddr);\n _;\n }\n\n function _requireValue() private view {\n if (msg.value == 0) revert ErrZeroValue();\n }\n\n function _requirePoolAdmin(PoolDetail storage _pool, address _requester) private view {\n if (_pool.admin != _requester) revert ErrOnlyPoolAdminAllowed();\n }\n\n function _anyExceptPoolAdmin(PoolDetail storage _pool, address _delegator) private view {\n if (_pool.admin == _delegator) revert ErrPoolAdminForbidden();\n }\n\n function _poolIsActive(address _poolAddr) private view {\n if (!IRoninValidatorSet(getContract(ContractType.VALIDATOR)).isValidatorCandidate(_poolAddr))\n revert ErrInactivePool(_poolAddr);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function isAdminOfActivePool(address _poolAdminAddr) public view override returns (bool) {\n return _adminOfActivePoolMapping[_poolAdminAddr] != address(0);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolAddressOf(address _poolAdminAddr) external view override returns (address) {\n return _adminOfActivePoolMapping[_poolAdminAddr];\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getPoolDetail(\n address _poolAddr\n ) external view returns (address _admin, uint256 _stakingAmount, uint256 _stakingTotal) {\n PoolDetail storage _pool = _stakingPool[_poolAddr];\n return (_pool.admin, _pool.stakingAmount, _pool.stakingTotal);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function getManySelfStakings(address[] calldata _pools) external view returns (uint256[] memory _selfStakings) {\n _selfStakings = new uint256[](_pools.length);\n for (uint _i = 0; _i < _pools.length; ) {\n _selfStakings[_i] = _stakingPool[_pools[_i]].stakingAmount;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view override returns (uint256) {\n return _stakingPool[_poolAddr].stakingTotal;\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingTotals(\n address[] calldata _poolList\n ) public view override returns (uint256[] memory _stakingAmounts) {\n _stakingAmounts = new uint256[](_poolList.length);\n for (uint _i = 0; _i < _poolList.length; ) {\n _stakingAmounts[_i] = getStakingTotal(_poolList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view override returns (uint256) {\n return _stakingPool[_poolAddr].delegatingAmount[_user];\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getManyStakingAmounts(\n address[] calldata _poolAddrs,\n address[] calldata _userList\n ) external view override returns (uint256[] memory _stakingAmounts) {\n if (_poolAddrs.length != _userList.length) revert ErrInvalidArrays();\n _stakingAmounts = new uint256[](_poolAddrs.length);\n for (uint _i = 0; _i < _stakingAmounts.length; ) {\n _stakingAmounts[_i] = _stakingPool[_poolAddrs[_i]].delegatingAmount[_userList[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function cooldownSecsToUndelegate() external view returns (uint256) {\n return _cooldownSecsToUndelegate;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function waitingSecsToRevoke() external view returns (uint256) {\n return _waitingSecsToRevoke;\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setCooldownSecsToUndelegate(uint256 _cooldownSecs) external override onlyAdmin {\n _setCooldownSecsToUndelegate(_cooldownSecs);\n }\n\n /**\n * @inheritdoc IBaseStaking\n */\n function setWaitingSecsToRevoke(uint256 _secs) external override onlyAdmin {\n _setWaitingSecsToRevoke(_secs);\n }\n\n /**\n * @dev Sets the minium number of seconds to undelegate.\n *\n * Emits the event `CooldownSecsToUndelegateUpdated`.\n *\n */\n function _setCooldownSecsToUndelegate(uint256 _cooldownSecs) internal {\n _cooldownSecsToUndelegate = _cooldownSecs;\n emit CooldownSecsToUndelegateUpdated(_cooldownSecs);\n }\n\n /**\n * @dev Sets the number of seconds that a candidate must wait to be revoked.\n *\n * Emits the event `WaitingSecsToRevokeUpdated`.\n *\n */\n function _setWaitingSecsToRevoke(uint256 _secs) internal {\n _waitingSecsToRevoke = _secs;\n emit WaitingSecsToRevokeUpdated(_secs);\n }\n\n /**\n * @dev Changes the delegate amount.\n */\n function _changeDelegatingAmount(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _newDelegatingAmount,\n uint256 _newStakingTotal\n ) internal {\n _syncUserReward(_pool.addr, _delegator, _newDelegatingAmount);\n _pool.stakingTotal = _newStakingTotal;\n _pool.delegatingAmount[_delegator] = _newDelegatingAmount;\n }\n}\n" + }, + "contracts/ronin/staking/CandidateStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../libraries/AddressArrayUtils.sol\";\nimport \"../../interfaces/staking/ICandidateStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract CandidateStaking is BaseStaking, ICandidateStaking, GlobalConfigConsumer, PercentageConsumer {\n /// @dev The minimum threshold for being a validator candidate.\n uint256 internal _minValidatorStakingAmount;\n\n /// @dev The max commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _maxCommissionRate;\n /// @dev The min commission rate that the validator can set (in range of [0;100_00] means [0-100%])\n uint256 internal _minCommissionRate;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] ______gap;\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function minValidatorStakingAmount() public view override returns (uint256) {\n return _minValidatorStakingAmount;\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function getCommissionRateRange() external view override returns (uint256, uint256) {\n return (_minCommissionRate, _maxCommissionRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setMinValidatorStakingAmount(uint256 _threshold) external override onlyAdmin {\n _setMinValidatorStakingAmount(_threshold);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function setCommissionRateRange(uint256 _minRate, uint256 _maxRate) external override onlyAdmin {\n _setCommissionRateRange(_minRate, _maxRate);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external payable override nonReentrant {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n\n uint256 _amount = msg.value;\n address payable _poolAdmin = payable(msg.sender);\n _applyValidatorCandidate({\n _poolAdmin: _poolAdmin,\n _candidateAdmin: _candidateAdmin,\n _consensusAddr: _consensusAddr,\n _treasuryAddr: _treasuryAddr,\n _commissionRate: _commissionRate,\n _amount: _amount\n });\n\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n _pool.admin = _poolAdmin;\n _pool.addr = _consensusAddr;\n _adminOfActivePoolMapping[_poolAdmin] = _consensusAddr;\n\n _stake(_stakingPool[_consensusAddr], _poolAdmin, _amount);\n emit PoolApproved(_consensusAddr, _poolAdmin);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n if (_commissionRate > _maxCommissionRate || _commissionRate < _minCommissionRate) revert ErrInvalidCommissionRate();\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestUpdateCommissionRate(\n _consensusAddr,\n _effectiveDaysOnwards,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function execDeprecatePools(\n address[] calldata _pools,\n uint256 _newPeriod\n ) external override onlyContract(ContractType.VALIDATOR) {\n if (_pools.length == 0) {\n return;\n }\n\n for (uint _i = 0; _i < _pools.length; ) {\n PoolDetail storage _pool = _stakingPool[_pools[_i]];\n // Deactivate the pool admin in the active mapping.\n delete _adminOfActivePoolMapping[_pool.admin];\n\n // Deduct and transfer the self staking amount to the pool admin.\n uint256 _deductingAmount = _pool.stakingAmount;\n if (_deductingAmount > 0) {\n _deductStakingAmount(_pool, _deductingAmount);\n if (!_unsafeSendRONLimitGas(payable(_pool.admin), _deductingAmount, DEFAULT_ADDITION_GAS)) {\n emit StakingAmountTransferFailed(_pool.addr, _pool.admin, _deductingAmount, address(this).balance);\n }\n }\n\n // Settle the unclaimed reward and transfer to the pool admin.\n uint256 _lastRewardAmount = _claimReward(_pools[_i], _pool.admin, _newPeriod);\n if (_lastRewardAmount > 0) {\n _unsafeSendRONLimitGas(payable(_pool.admin), _lastRewardAmount, DEFAULT_ADDITION_GAS);\n }\n\n unchecked {\n ++_i;\n }\n }\n\n emit PoolsDeprecated(_pools);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function stake(address _consensusAddr) external payable override noEmptyValue poolIsActive(_consensusAddr) {\n _stake(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function unstake(\n address _consensusAddr,\n uint256 _amount\n ) external override nonReentrant poolIsActive(_consensusAddr) {\n if (_amount == 0) revert ErrUnstakeZeroAmount();\n address _requester = msg.sender;\n PoolDetail storage _pool = _stakingPool[_consensusAddr];\n uint256 _remainAmount = _pool.stakingAmount - _amount;\n if (_remainAmount < _minValidatorStakingAmount) revert ErrStakingAmountLeft();\n\n _unstake(_pool, _requester, _amount);\n if (!_unsafeSendRONLimitGas(payable(_requester), _amount, DEFAULT_ADDITION_GAS)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestRenounce(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execRequestRenounceCandidate(\n _consensusAddr,\n _waitingSecsToRevoke\n );\n }\n\n /**\n * @inheritdoc ICandidateStaking\n */\n function requestEmergencyExit(\n address _consensusAddr\n ) external override poolIsActive(_consensusAddr) onlyPoolAdmin(_stakingPool[_consensusAddr], msg.sender) {\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execEmergencyExit(_consensusAddr, _waitingSecsToRevoke);\n }\n\n /**\n * @dev See `ICandidateStaking-applyValidatorCandidate`\n */\n function _applyValidatorCandidate(\n address payable _poolAdmin,\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate,\n uint256 _amount\n ) internal {\n if (!_unsafeSendRONLimitGas(_poolAdmin, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_poolAdmin, \"pool admin\");\n if (!_unsafeSendRONLimitGas(_treasuryAddr, 0, DEFAULT_ADDITION_GAS))\n revert ErrCannotInitTransferRON(_treasuryAddr, \"treasury\");\n if (_amount < _minValidatorStakingAmount) revert ErrInsufficientStakingAmount();\n if (_poolAdmin != _candidateAdmin || _candidateAdmin != _treasuryAddr) revert ErrThreeInteractionAddrsNotEqual();\n\n {\n address[] memory _diffAddrs = new address[](2);\n _diffAddrs[0] = _poolAdmin;\n _diffAddrs[1] = _consensusAddr;\n if (AddressArrayUtils.hasDuplicate(_diffAddrs)) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @dev See `ICandidateStaking-stake`\n */\n function _stake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n _pool.stakingAmount += _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal + _amount);\n _pool.lastDelegatingTimestamp[_requester] = block.timestamp;\n emit Staked(_pool.addr, _amount);\n }\n\n /**\n * @dev See `ICandidateStaking-unstake`\n */\n function _unstake(\n PoolDetail storage _pool,\n address _requester,\n uint256 _amount\n ) internal onlyPoolAdmin(_pool, _requester) {\n if (_amount > _pool.stakingAmount) revert ErrInsufficientStakingAmount();\n if (_pool.lastDelegatingTimestamp[_requester] + _cooldownSecsToUndelegate > block.timestamp) {\n revert ErrUnstakeTooEarly();\n }\n\n _pool.stakingAmount -= _amount;\n _changeDelegatingAmount(_pool, _requester, _pool.stakingAmount, _pool.stakingTotal - _amount);\n emit Unstaked(_pool.addr, _amount);\n }\n\n /**\n * @dev Deducts from staking amount of the validator `_consensusAddr` for `_amount`.\n *\n * Emits the event `Unstaked`.\n *\n * @return The actual deducted amount\n */\n function _deductStakingAmount(PoolDetail storage _pool, uint256 _amount) internal virtual returns (uint256);\n\n /**\n * @dev Sets the minimum threshold for being a validator candidate.\n *\n * Emits the `MinValidatorStakingAmountUpdated` event.\n *\n */\n function _setMinValidatorStakingAmount(uint256 _threshold) internal {\n _minValidatorStakingAmount = _threshold;\n emit MinValidatorStakingAmountUpdated(_threshold);\n }\n\n /**\n * @dev Sets the max commission rate that a candidate can set.\n *\n * Emits the `MaxCommissionRateUpdated` event.\n *\n */\n function _setCommissionRateRange(uint256 _minRate, uint256 _maxRate) internal {\n if (_maxRate > _MAX_PERCENTAGE || _minRate > _maxRate) revert ErrInvalidCommissionRate();\n _maxCommissionRate = _maxRate;\n _minCommissionRate = _minRate;\n emit CommissionRateRangeUpdated(_minRate, _maxRate);\n }\n}\n" + }, + "contracts/ronin/staking/DelegatorStaking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IDelegatorStaking.sol\";\nimport \"./BaseStaking.sol\";\n\nabstract contract DelegatorStaking is BaseStaking, IDelegatorStaking {\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegate(address _consensusAddr) external payable noEmptyValue poolIsActive(_consensusAddr) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n _delegate(_stakingPool[_consensusAddr], msg.sender, msg.value);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function undelegate(address _consensusAddr, uint256 _amount) external nonReentrant {\n address payable _delegator = payable(msg.sender);\n _undelegate(_stakingPool[_consensusAddr], _delegator, _amount);\n if (!_sendRON(_delegator, _amount)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function bulkUndelegate(address[] calldata _consensusAddrs, uint256[] calldata _amounts) external nonReentrant {\n if (_consensusAddrs.length == 0 || _consensusAddrs.length != _amounts.length) revert ErrInvalidArrays();\n\n address payable _delegator = payable(msg.sender);\n uint256 _total;\n\n for (uint _i = 0; _i < _consensusAddrs.length; ) {\n _total += _amounts[_i];\n _undelegate(_stakingPool[_consensusAddrs[_i]], _delegator, _amounts[_i]);\n\n unchecked {\n ++_i;\n }\n }\n\n if (!_sendRON(_delegator, _total)) revert ErrCannotTransferRON();\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function redelegate(\n address _consensusAddrSrc,\n address _consensusAddrDst,\n uint256 _amount\n ) external nonReentrant poolIsActive(_consensusAddrDst) {\n address _delegator = msg.sender;\n _undelegate(_stakingPool[_consensusAddrSrc], _delegator, _amount);\n _delegate(_stakingPool[_consensusAddrDst], _delegator, _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function claimRewards(\n address[] calldata _consensusAddrList\n ) external override nonReentrant returns (uint256 _amount) {\n _amount = _claimRewards(msg.sender, _consensusAddrList);\n _transferRON(payable(msg.sender), _amount);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function delegateRewards(\n address[] calldata _consensusAddrList,\n address _consensusAddrDst\n ) external override nonReentrant poolIsActive(_consensusAddrDst) returns (uint256 _amount) {\n if (isAdminOfActivePool(msg.sender)) revert ErrAdminOfAnyActivePoolForbidden(msg.sender);\n return _delegateRewards(msg.sender, _consensusAddrList, _consensusAddrDst);\n }\n\n /**\n * @inheritdoc IDelegatorStaking\n */\n function getRewards(\n address _user,\n address[] calldata _poolAddrList\n ) external view returns (uint256[] memory _rewards) {\n address _consensusAddr;\n uint256 _period = IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n _rewards = new uint256[](_poolAddrList.length);\n\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _consensusAddr = _poolAddrList[_i];\n _rewards[_i] = _getReward(_consensusAddr, _user, _period, getStakingAmount(_consensusAddr, _user));\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Delegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n *\n * Emits the `Delegated` event.\n *\n * Note: This function does not verify the `msg.value` with the amount.\n *\n */\n function _delegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) internal anyExceptPoolAdmin(_pool, _delegator) {\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] + _amount,\n _pool.stakingTotal + _amount\n );\n _pool.lastDelegatingTimestamp[_delegator] = block.timestamp;\n emit Delegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Undelegates from a validator address.\n *\n * Requirements:\n * - The delegator is not the pool admin.\n * - The amount is larger than 0.\n * - The delegating amount is larger than or equal to the undelegating amount.\n *\n * Emits the `Undelegated` event.\n *\n * Note: Consider transferring back the amount of RON after calling this function.\n *\n */\n function _undelegate(\n PoolDetail storage _pool,\n address _delegator,\n uint256 _amount\n ) private anyExceptPoolAdmin(_pool, _delegator) {\n if (_amount == 0) revert ErrUndelegateZeroAmount();\n if (_pool.delegatingAmount[_delegator] < _amount) revert ErrInsufficientDelegatingAmount();\n\n IRoninValidatorSet _validatorContract = IRoninValidatorSet(getContract(ContractType.VALIDATOR));\n if (\n _validatorContract.isValidatorCandidate(_pool.addr) &&\n _validatorContract.getCandidateInfo(_pool.addr).revokingTimestamp == 0 && // if candidate is not on renunciation\n _pool.lastDelegatingTimestamp[_delegator] + _cooldownSecsToUndelegate >= block.timestamp // delegator is still in cooldown\n ) revert ErrUndelegateTooEarly();\n\n _changeDelegatingAmount(\n _pool,\n _delegator,\n _pool.delegatingAmount[_delegator] - _amount,\n _pool.stakingTotal - _amount\n );\n emit Undelegated(_delegator, _pool.addr, _amount);\n }\n\n /**\n * @dev Claims rewards from the pools `_poolAddrList`.\n * Note: This function does not transfer reward to user.\n */\n function _claimRewards(address _user, address[] memory _poolAddrList) internal returns (uint256 _amount) {\n uint256 _period = _currentPeriod();\n for (uint256 _i = 0; _i < _poolAddrList.length; ) {\n _amount += _claimReward(_poolAddrList[_i], _user, _period);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Claims the rewards and delegates them to the consensus address.\n */\n function _delegateRewards(\n address _user,\n address[] calldata _poolAddrList,\n address _poolAddrDst\n ) internal returns (uint256 _amount) {\n _amount = _claimRewards(_user, _poolAddrList);\n _delegate(_stakingPool[_poolAddrDst], _user, _amount);\n }\n}\n" + }, + "contracts/ronin/staking/RewardCalculation.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../interfaces/staking/IRewardPool.sol\";\nimport \"../../libraries/Math.sol\";\n\n/**\n * @title RewardCalculation contract\n * @dev This contract mainly contains the methods to calculate reward for staking contract.\n */\nabstract contract RewardCalculation is IRewardPool {\n /// @dev Mapping from pool address => period number => accumulated rewards per share (one unit staking)\n mapping(address => mapping(uint256 => PeriodWrapper)) private _accumulatedRps;\n /// @dev Mapping from the pool address => user address => the reward info of the user\n mapping(address => mapping(address => UserRewardFields)) private _userReward;\n /// @dev Mapping from the pool address => reward pool fields\n mapping(address => PoolFields) private _stakingPool;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IRewardPool\n */\n function getReward(address _poolAddr, address _user) external view returns (uint256) {\n return _getReward(_poolAddr, _user, _currentPeriod(), getStakingAmount(_poolAddr, _user));\n }\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingAmount(address _poolAddr, address _user) public view virtual returns (uint256);\n\n /**\n * @inheritdoc IRewardPool\n */\n function getStakingTotal(address _poolAddr) public view virtual returns (uint256);\n\n /**\n * @dev Returns the reward amount that user claimable.\n */\n function _getReward(\n address _poolAddr,\n address _user,\n uint256 _latestPeriod,\n uint256 _latestStakingAmount\n ) internal view returns (uint256) {\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n\n if (_reward.lastPeriod == _latestPeriod) {\n return _reward.debited;\n }\n\n uint256 _aRps;\n uint256 _lastPeriodReward;\n PoolFields storage _pool = _stakingPool[_poolAddr];\n PeriodWrapper storage _wrappedArps = _accumulatedRps[_poolAddr][_reward.lastPeriod];\n\n if (_wrappedArps.lastPeriod > 0) {\n // Calculates the last period reward if the aRps at the period is set\n _aRps = _wrappedArps.inner;\n _lastPeriodReward = _reward.lowestAmount * (_aRps - _reward.aRps);\n } else {\n // Fallbacks to the previous aRps in case the aRps is not set\n _aRps = _reward.aRps;\n }\n\n uint256 _newPeriodsReward = _latestStakingAmount * (_pool.aRps - _aRps);\n return _reward.debited + (_lastPeriodReward + _newPeriodsReward) / 1e18;\n }\n\n /**\n * @dev Syncs the user reward.\n *\n * Emits the event `UserRewardUpdated` once the debit amount is updated.\n * Emits the event `PoolSharesUpdated` once the pool share is updated.\n *\n * Note: The method should be called whenever the user's staking amount changes.\n *\n */\n function _syncUserReward(address _poolAddr, address _user, uint256 _newStakingAmount) internal {\n uint256 _period = _currentPeriod();\n PoolFields storage _pool = _stakingPool[_poolAddr];\n uint256 _lastShares = _pool.shares.inner;\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(getStakingTotal(_poolAddr), _period);\n }\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n uint256 _debited = _getReward(_poolAddr, _user, _period, _currentStakingAmount);\n\n if (_reward.debited != _debited) {\n _reward.debited = _debited;\n emit UserRewardUpdated(_poolAddr, _user, _debited);\n }\n\n _syncMinStakingAmount(_pool, _reward, _period, _newStakingAmount, _currentStakingAmount);\n _reward.aRps = _pool.aRps;\n _reward.lastPeriod = _period;\n\n if (_pool.shares.inner != _lastShares) {\n emit PoolSharesUpdated(_period, _poolAddr, _pool.shares.inner);\n }\n }\n\n /**\n * @dev Syncs the minimum staking amount of an user in the current period.\n */\n function _syncMinStakingAmount(\n PoolFields storage _pool,\n UserRewardFields storage _reward,\n uint256 _latestPeriod,\n uint256 _newStakingAmount,\n uint256 _currentStakingAmount\n ) internal {\n if (_reward.lastPeriod < _latestPeriod) {\n _reward.lowestAmount = _currentStakingAmount;\n }\n\n uint256 _lowestAmount = Math.min(_reward.lowestAmount, _newStakingAmount);\n uint256 _diffAmount = _reward.lowestAmount - _lowestAmount;\n if (_diffAmount > 0) {\n _reward.lowestAmount = _lowestAmount;\n if (_pool.shares.inner < _diffAmount) revert ErrInvalidPoolShare();\n _pool.shares.inner -= _diffAmount;\n }\n }\n\n /**\n * @dev Claims the settled reward for a specific user.\n *\n * @param _lastPeriod Must be in two possible value: `_currentPeriod` in normal calculation, or\n * `_currentPeriod + 1` in case of calculating the reward for revoked validators.\n *\n * Emits the `RewardClaimed` event and the `UserRewardUpdated` event.\n *\n * Note: This method should be called before transferring rewards for the user.\n *\n */\n function _claimReward(address _poolAddr, address _user, uint256 _lastPeriod) internal returns (uint256 _amount) {\n uint256 _currentStakingAmount = getStakingAmount(_poolAddr, _user);\n _amount = _getReward(_poolAddr, _user, _lastPeriod, _currentStakingAmount);\n emit RewardClaimed(_poolAddr, _user, _amount);\n\n UserRewardFields storage _reward = _userReward[_poolAddr][_user];\n _reward.debited = 0;\n _syncMinStakingAmount(_stakingPool[_poolAddr], _reward, _lastPeriod, _currentStakingAmount, _currentStakingAmount);\n _reward.lastPeriod = _lastPeriod;\n _reward.aRps = _stakingPool[_poolAddr].aRps;\n emit UserRewardUpdated(_poolAddr, _user, 0);\n }\n\n /**\n * @dev Records the amount of rewards `_rewards` for the pools `_poolAddrs`.\n *\n * Emits the event `PoolsUpdated` once the contract recorded the rewards successfully.\n * Emits the event `PoolsUpdateFailed` once the input array lengths are not equal.\n * Emits the event `PoolUpdateConflicted` when the pool is already updated in the period.\n *\n * Note: This method should be called once at the period ending.\n *\n */\n function _recordRewards(address[] memory _poolAddrs, uint256[] calldata _rewards, uint256 _period) internal {\n if (_poolAddrs.length != _rewards.length) {\n emit PoolsUpdateFailed(_period, _poolAddrs, _rewards);\n return;\n }\n\n uint256 _rps;\n uint256 _count;\n address _poolAddr;\n uint256 _stakingTotal;\n uint256[] memory _aRps = new uint256[](_poolAddrs.length);\n uint256[] memory _shares = new uint256[](_poolAddrs.length);\n address[] memory _conflicted = new address[](_poolAddrs.length);\n\n for (uint _i = 0; _i < _poolAddrs.length; _i++) {\n _poolAddr = _poolAddrs[_i];\n PoolFields storage _pool = _stakingPool[_poolAddr];\n _stakingTotal = getStakingTotal(_poolAddr);\n\n if (_accumulatedRps[_poolAddr][_period].lastPeriod == _period) {\n unchecked {\n _conflicted[_count++] = _poolAddr;\n }\n continue;\n }\n\n // Updates the pool shares if it is outdated\n if (_pool.shares.lastPeriod < _period) {\n _pool.shares = PeriodWrapper(_stakingTotal, _period);\n }\n\n // The rps is 0 if no one stakes for the pool\n _rps = _pool.shares.inner == 0 ? 0 : (_rewards[_i] * 1e18) / _pool.shares.inner;\n _aRps[_i - _count] = _pool.aRps += _rps;\n _accumulatedRps[_poolAddr][_period] = PeriodWrapper(_pool.aRps, _period);\n _pool.shares.inner = _stakingTotal;\n _shares[_i - _count] = _pool.shares.inner;\n _poolAddrs[_i - _count] = _poolAddr;\n }\n\n if (_count > 0) {\n assembly {\n mstore(_conflicted, _count)\n mstore(_poolAddrs, sub(mload(_poolAddrs), _count))\n }\n emit PoolsUpdateConflicted(_period, _conflicted);\n }\n\n if (_poolAddrs.length > 0) {\n emit PoolsUpdated(_period, _poolAddrs, _aRps, _shares);\n }\n }\n\n /**\n * @dev Returns the current period.\n */\n function _currentPeriod() internal view virtual returns (uint256);\n}\n" + }, + "contracts/ronin/staking/Staking.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../libraries/Math.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CandidateStaking.sol\";\nimport \"./DelegatorStaking.sol\";\n\ncontract Staking is IStaking, CandidateStaking, DelegatorStaking, Initializable {\n constructor() {\n _disableInitializers();\n }\n\n receive() external payable onlyContract(ContractType.VALIDATOR) {}\n\n fallback() external payable onlyContract(ContractType.VALIDATOR) {}\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __minValidatorStakingAmount,\n uint256 __maxCommissionRate,\n uint256 __cooldownSecsToUndelegate,\n uint256 __waitingSecsToRevoke\n ) external initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setMinValidatorStakingAmount(__minValidatorStakingAmount);\n _setCommissionRateRange(0, __maxCommissionRate);\n _setCooldownSecsToUndelegate(__cooldownSecsToUndelegate);\n _setWaitingSecsToRevoke(__waitingSecsToRevoke);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n /**\n * @dev This method only work on testnet, to hotfix the applied validator candidate that is failed.\n * TODO: Should remove this method before deploying it on mainnet.\n */\n function tmp_re_applyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external {\n require(block.chainid == 2021, \"E1\");\n require(msg.sender == 0x57832A94810E18c84a5A5E2c4dD67D012ade574F, \"E2\");\n\n IRoninValidatorSet(getContract(ContractType.VALIDATOR)).execApplyValidatorCandidate(\n _candidateAdmin,\n _consensusAddr,\n _treasuryAddr,\n _commissionRate\n );\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execRecordRewards(\n address[] calldata _consensusAddrs,\n uint256[] calldata _rewards,\n uint256 _period\n ) external payable override onlyContract(ContractType.VALIDATOR) {\n _recordRewards(_consensusAddrs, _rewards, _period);\n }\n\n /**\n * @inheritdoc IStaking\n */\n function execDeductStakingAmount(\n address _consensusAddr,\n uint256 _amount\n ) external override onlyContract(ContractType.VALIDATOR) returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = _deductStakingAmount(_stakingPool[_consensusAddr], _amount);\n address payable _validatorContractAddr = payable(msg.sender);\n if (!_unsafeSendRON(_validatorContractAddr, _actualDeductingAmount)) {\n emit StakingAmountDeductFailed(\n _consensusAddr,\n _validatorContractAddr,\n _actualDeductingAmount,\n address(this).balance\n );\n }\n }\n\n /**\n * @inheritdoc RewardCalculation\n */\n function _currentPeriod() internal view virtual override returns (uint256) {\n return IRoninValidatorSet(getContract(ContractType.VALIDATOR)).currentPeriod();\n }\n\n /**\n * @inheritdoc CandidateStaking\n */\n function _deductStakingAmount(\n PoolDetail storage _pool,\n uint256 _amount\n ) internal override returns (uint256 _actualDeductingAmount) {\n _actualDeductingAmount = Math.min(_pool.stakingAmount, _amount);\n\n _pool.stakingAmount -= _actualDeductingAmount;\n _changeDelegatingAmount(\n _pool,\n _pool.admin,\n _pool.stakingAmount,\n Math.subNonNegative(_pool.stakingTotal, _actualDeductingAmount)\n );\n emit Unstaked(_pool.addr, _actualDeductingAmount);\n }\n}\n" + }, + "contracts/ronin/StakingVesting.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../interfaces/IStakingVesting.sol\";\nimport \"../extensions/collections/HasContracts.sol\";\nimport \"../extensions/consumers/PercentageConsumer.sol\";\nimport { RONTransferHelper } from \"../extensions/RONTransferHelper.sol\";\nimport { HasValidatorDeprecated } from \"../utils/DeprecatedSlots.sol\";\nimport \"../utils/CommonErrors.sol\";\n\ncontract StakingVesting is\n IStakingVesting,\n PercentageConsumer,\n HasValidatorDeprecated,\n HasContracts,\n Initializable,\n RONTransferHelper\n{\n /// @dev The block bonus for the block producer whenever a new block is mined.\n uint256 internal _blockProducerBonusPerBlock;\n /// @dev The block bonus for the bridge operator whenever a new block is mined.\n uint256 internal _bridgeOperatorBonusPerBlock;\n /// @dev The last block number that the staking vesting sent.\n uint256 public lastBlockSendingBonus;\n /// @dev The percentage that extracted from reward of block producer for fast finality.\n uint256 internal _fastFinalityRewardPercentage;\n\n constructor() {\n _disableInitializers();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __validatorContract,\n uint256 __blockProducerBonusPerBlock,\n uint256 __bridgeOperatorBonusPerBlock\n ) external payable initializer {\n _setContract(ContractType.VALIDATOR, __validatorContract);\n _setBlockProducerBonusPerBlock(__blockProducerBonusPerBlock);\n _setBridgeOperatorBonusPerBlock(__bridgeOperatorBonusPerBlock);\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.VALIDATOR, ______deprecatedValidator);\n delete ______deprecatedValidator;\n }\n\n function initializeV3(uint256 fastFinalityRewardPercent) external reinitializer(3) {\n _setFastFinalityRewardPercentage(fastFinalityRewardPercent);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function receiveRON() external payable {}\n\n /**\n * @inheritdoc IStakingVesting\n */\n function blockProducerBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _blockProducerBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function bridgeOperatorBlockBonus(uint256 /* _block */) public view override returns (uint256) {\n return _bridgeOperatorBonusPerBlock;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function fastFinalityRewardPercentage() external view override returns (uint256) {\n return _fastFinalityRewardPercentage;\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function requestBonus(\n bool forBlockProducer,\n bool forBridgeOperator\n )\n external\n override\n onlyContract(ContractType.VALIDATOR)\n returns (bool success, uint256 blockProducerBonus, uint256 bridgeOperatorBonus, uint256 fastFinalityRewardPercent)\n {\n if (block.number <= lastBlockSendingBonus) revert ErrBonusAlreadySent();\n\n lastBlockSendingBonus = block.number;\n\n blockProducerBonus = forBlockProducer ? blockProducerBlockBonus(block.number) : 0;\n bridgeOperatorBonus = forBridgeOperator ? bridgeOperatorBlockBonus(block.number) : 0;\n fastFinalityRewardPercent = _fastFinalityRewardPercentage;\n\n uint256 totalAmount = blockProducerBonus + bridgeOperatorBonus;\n\n if (totalAmount > 0) {\n address payable validatorContractAddr = payable(msg.sender);\n\n success = _unsafeSendRON(validatorContractAddr, totalAmount);\n\n if (!success) {\n emit BonusTransferFailed(\n block.number,\n validatorContractAddr,\n blockProducerBonus,\n bridgeOperatorBonus,\n address(this).balance\n );\n return (success, 0, 0, 0);\n }\n\n emit BonusTransferred(block.number, validatorContractAddr, blockProducerBonus, bridgeOperatorBonus);\n }\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBlockProducerBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBlockProducerBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setBridgeOperatorBonusPerBlock(uint256 _amount) external override onlyAdmin {\n _setBridgeOperatorBonusPerBlock(_amount);\n }\n\n /**\n * @inheritdoc IStakingVesting\n */\n function setFastFinalityRewardPercentage(uint256 percent) external override onlyAdmin {\n if (percent > _MAX_PERCENTAGE) revert ErrInvalidArguments(msg.sig);\n _setFastFinalityRewardPercentage(percent);\n }\n\n /**\n * @dev Sets the bonus amount per block for block producer.\n *\n * Emits the event `BlockProducerBonusPerBlockUpdated`.\n *\n */\n function _setBlockProducerBonusPerBlock(uint256 _amount) internal {\n _blockProducerBonusPerBlock = _amount;\n emit BlockProducerBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the bonus amount per block for bridge operator.\n *\n * Emits the event `BridgeOperatorBonusPerBlockUpdated`.\n *\n */\n function _setBridgeOperatorBonusPerBlock(uint256 _amount) internal {\n _bridgeOperatorBonusPerBlock = _amount;\n emit BridgeOperatorBonusPerBlockUpdated(_amount);\n }\n\n /**\n * @dev Sets the percent of fast finality reward.\n *\n * Emits the event `FastFinalityRewardPercentageUpdated`.\n *\n */\n function _setFastFinalityRewardPercentage(uint256 percent) internal {\n _fastFinalityRewardPercentage = percent;\n emit FastFinalityRewardPercentageUpdated(percent);\n }\n}\n" + }, + "contracts/ronin/validator/CandidateManager.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../extensions/consumers/PercentageConsumer.sol\";\nimport \"../../interfaces/validator/ICandidateManager.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport { HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\n\nabstract contract CandidateManager is\n ICandidateManager,\n PercentageConsumer,\n GlobalConfigConsumer,\n HasContracts,\n HasStakingDeprecated\n{\n /// @dev Maximum number of validator candidate\n uint256 private _maxValidatorCandidate;\n\n /// @dev The validator candidate array\n address[] internal _candidates;\n /// @dev Mapping from candidate consensus address => bitwise negation of validator index in `_candidates`\n mapping(address => uint256) internal _candidateIndex;\n /// @dev Mapping from candidate consensus address => their info\n mapping(address => ValidatorCandidate) internal _candidateInfo;\n\n /**\n * @dev The minimum offset in day from current date to the effective date of a new commission schedule.\n * Value of 1 means the change gets affected at the beginning of the following day.\n **/\n uint256 internal _minEffectiveDaysOnwards;\n /// @dev Mapping from candidate consensus address => schedule commission change.\n mapping(address => CommissionSchedule) internal _candidateCommissionChangeSchedule;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc ICandidateManager\n */\n function maxValidatorCandidate() public view override returns (uint256) {\n return _maxValidatorCandidate;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function minEffectiveDaysOnward() external view override returns (uint256) {\n return _minEffectiveDaysOnwards;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMaxValidatorCandidate(uint256 _number) external override onlyAdmin {\n _setMaxValidatorCandidate(_number);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function setMinEffectiveDaysOnwards(uint256 _numOfDays) external override onlyAdmin {\n _setMinEffectiveDaysOnwards(_numOfDays);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execApplyValidatorCandidate(\n address _candidateAdmin,\n address _consensusAddr,\n address payable _treasuryAddr,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n uint256 _length = _candidates.length;\n if (_length >= maxValidatorCandidate()) revert ErrExceedsMaxNumberOfCandidate();\n if (isValidatorCandidate(_consensusAddr)) revert ErrExistentCandidate();\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n\n for (uint _i; _i < _candidates.length; ) {\n ValidatorCandidate storage existentInfo = _candidateInfo[_candidates[_i]];\n if (_candidateAdmin == existentInfo.admin) revert ErrExistentCandidateAdmin(_candidateAdmin);\n if (_treasuryAddr == existentInfo.treasuryAddr) revert ErrExistentTreasury(_treasuryAddr);\n\n unchecked {\n ++_i;\n }\n }\n\n _candidateIndex[_consensusAddr] = ~_length;\n _candidates.push(_consensusAddr);\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n _info.admin = _candidateAdmin;\n _info.consensusAddr = _consensusAddr;\n _info.treasuryAddr = _treasuryAddr;\n _info.commissionRate = _commissionRate;\n emit CandidateGranted(_consensusAddr, _treasuryAddr, _candidateAdmin);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestRenounceCandidate(\n address _consensusAddr,\n uint256 _secsLeft\n ) external override onlyContract(ContractType.STAKING) {\n if (_isTrustedOrg(_consensusAddr)) revert ErrTrustedOrgCannotRenounce();\n\n ValidatorCandidate storage _info = _candidateInfo[_consensusAddr];\n if (_info.revokingTimestamp != 0) revert ErrAlreadyRequestedRevokingCandidate();\n _setRevokingTimestamp(_info, block.timestamp + _secsLeft);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function execRequestUpdateCommissionRate(\n address _consensusAddr,\n uint256 _effectiveDaysOnwards,\n uint256 _commissionRate\n ) external override onlyContract(ContractType.STAKING) {\n if (_candidateCommissionChangeSchedule[_consensusAddr].effectiveTimestamp != 0) {\n revert ErrAlreadyRequestedUpdatingCommissionRate();\n }\n if (_commissionRate > _MAX_PERCENTAGE) revert ErrInvalidCommissionRate();\n if (_effectiveDaysOnwards < _minEffectiveDaysOnwards) revert ErrInvalidEffectiveDaysOnwards();\n\n CommissionSchedule storage _schedule = _candidateCommissionChangeSchedule[_consensusAddr];\n uint256 _effectiveTimestamp = ((block.timestamp / PERIOD_DURATION) + _effectiveDaysOnwards) * PERIOD_DURATION;\n _schedule.effectiveTimestamp = _effectiveTimestamp;\n _schedule.commissionRate = _commissionRate;\n\n emit CommissionRateUpdateScheduled(_consensusAddr, _effectiveTimestamp, _commissionRate);\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isValidatorCandidate(address _addr) public view override returns (bool) {\n return _candidateIndex[_addr] != 0;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfos() external view override returns (ValidatorCandidate[] memory _list) {\n _list = new ValidatorCandidate[](_candidates.length);\n for (uint _i; _i < _list.length; ) {\n _list[_i] = _candidateInfo[_candidates[_i]];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCandidateInfo(address _candidate) external view override returns (ValidatorCandidate memory) {\n if (!isValidatorCandidate(_candidate)) revert ErrNonExistentCandidate();\n return _candidateInfo[_candidate];\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getValidatorCandidates() public view override returns (address[] memory) {\n return _candidates;\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function getCommissionChangeSchedule(address _candidate) external view override returns (CommissionSchedule memory) {\n return _candidateCommissionChangeSchedule[_candidate];\n }\n\n /**\n * @dev Removes unsastisfied candidates, the ones who have insufficient minimum candidate staking amount,\n * or the ones who requested to renounce their candidate role.\n *\n * Emits the event `CandidatesRevoked` when a candidate is revoked.\n *\n */\n function _syncCandidateSet(uint256 _nextPeriod) internal returns (address[] memory _unsatisfiedCandidates) {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n uint256 _waitingSecsToRevoke = _staking.waitingSecsToRevoke();\n uint256 _minStakingAmount = _staking.minValidatorStakingAmount();\n uint256[] memory _selfStakings = _staking.getManySelfStakings(_candidates);\n\n uint256 _length = _candidates.length;\n uint256 _unsatisfiedCount;\n _unsatisfiedCandidates = new address[](_length);\n\n {\n uint256 _i;\n address _addr;\n ValidatorCandidate storage _info;\n while (_i < _length) {\n _addr = _candidates[_i];\n _info = _candidateInfo[_addr];\n\n // Checks for under-balance status of candidates\n bool _hasTopupDeadline = _info.topupDeadline != 0;\n if (_selfStakings[_i] < _minStakingAmount) {\n // Updates deadline on the first time unsatisfied the staking amount condition\n if (!_hasTopupDeadline) {\n uint256 _topupDeadline = block.timestamp + _waitingSecsToRevoke;\n _info.topupDeadline = _topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, _topupDeadline);\n }\n } else if (_hasTopupDeadline) {\n // Removes the deadline if the staking amount condition is satisfied\n delete _info.topupDeadline;\n emit CandidateTopupDeadlineUpdated(_addr, 0);\n }\n\n // Removes unsastisfied candidates\n bool _revokingActivated = (_info.revokingTimestamp != 0 && _info.revokingTimestamp <= block.timestamp) ||\n _emergencyExitLockedFundReleased(_addr);\n bool _topupDeadlineMissed = _info.topupDeadline != 0 && _info.topupDeadline <= block.timestamp;\n if (_revokingActivated || _topupDeadlineMissed) {\n _selfStakings[_i] = _selfStakings[--_length];\n unchecked {\n _unsatisfiedCandidates[_unsatisfiedCount++] = _addr;\n }\n _removeCandidate(_addr);\n continue;\n }\n\n // Checks for schedule of commission change and updates commission rate\n uint256 _scheduleTimestamp = _candidateCommissionChangeSchedule[_addr].effectiveTimestamp;\n if (_scheduleTimestamp != 0 && _scheduleTimestamp <= block.timestamp) {\n uint256 _commisionRate = _candidateCommissionChangeSchedule[_addr].commissionRate;\n delete _candidateCommissionChangeSchedule[_addr];\n _info.commissionRate = _commisionRate;\n emit CommissionRateUpdated(_addr, _commisionRate);\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n assembly {\n mstore(_unsatisfiedCandidates, _unsatisfiedCount)\n }\n\n if (_unsatisfiedCount > 0) {\n emit CandidatesRevoked(_unsatisfiedCandidates);\n _staking.execDeprecatePools(_unsatisfiedCandidates, _nextPeriod);\n }\n }\n\n /**\n * @inheritdoc ICandidateManager\n */\n function isCandidateAdmin(address _candidate, address _admin) external view override returns (bool) {\n return _candidateInfo[_candidate].admin == _admin;\n }\n\n /**\n * @dev Sets the maximum number of validator candidate.\n *\n * Emits the `MaxValidatorCandidateUpdated` event.\n *\n */\n function _setMaxValidatorCandidate(uint256 _threshold) internal {\n _maxValidatorCandidate = _threshold;\n emit MaxValidatorCandidateUpdated(_threshold);\n }\n\n /**\n * @dev Sets the minimum number of days onwards to the effective date of commission rate change.\n *\n * Emits the `MinEffectiveDaysOnwardsUpdated` event.\n *\n */\n function _setMinEffectiveDaysOnwards(uint256 _numOfDays) internal {\n if (_numOfDays < 1) revert ErrInvalidMinEffectiveDaysOnwards();\n _minEffectiveDaysOnwards = _numOfDays;\n emit MinEffectiveDaysOnwardsUpdated(_numOfDays);\n }\n\n /**\n * @dev Removes the candidate.\n */\n function _removeCandidate(address _addr) internal virtual {\n uint256 _idx = _candidateIndex[_addr];\n if (_idx == 0) {\n return;\n }\n\n delete _candidateInfo[_addr];\n delete _candidateIndex[_addr];\n delete _candidateCommissionChangeSchedule[_addr];\n\n address _lastCandidate = _candidates[_candidates.length - 1];\n if (_lastCandidate != _addr) {\n _candidateIndex[_lastCandidate] = _idx;\n _candidates[~_idx] = _lastCandidate;\n }\n\n _candidates.pop();\n }\n\n /**\n * @dev Sets timestamp to revoke a candidate.\n */\n function _setRevokingTimestamp(ValidatorCandidate storage _candidate, uint256 _timestamp) internal {\n if (!isValidatorCandidate(_candidate.consensusAddr)) revert ErrNonExistentCandidate();\n _candidate.revokingTimestamp = _timestamp;\n emit CandidateRevokingTimestampUpdated(_candidate.consensusAddr, _timestamp);\n }\n\n /**\n * @dev Returns a flag indicating whether the fund is unlocked.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual returns (bool);\n\n /**\n * @dev Returns whether the consensus address is a trusted org or not.\n */\n function _isTrustedOrg(address _consensusAddr) internal virtual returns (bool);\n}\n" + }, + "contracts/ronin/validator/CoinbaseExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IStakingVesting.sol\";\nimport \"../../interfaces/IMaintenance.sol\";\nimport \"../../interfaces/IRoninTrustedOrganization.sol\";\nimport \"../../interfaces/IFastFinalityTracking.sol\";\nimport \"../../interfaces/slash-indicator/ISlashIndicator.sol\";\nimport \"../../interfaces/validator/ICoinbaseExecution.sol\";\nimport \"../../libraries/EnumFlags.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasStakingVestingDeprecated, HasBridgeTrackingDeprecated, HasMaintenanceDeprecated, HasSlashIndicatorDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"../../precompile-usages/PCUSortValidators.sol\";\nimport \"../../precompile-usages/PCUPickValidatorSet.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\nimport { EmergencyExit } from \"./EmergencyExit.sol\";\nimport { ErrCallerMustBeCoinbase } from \"../../utils/CommonErrors.sol\";\n\nabstract contract CoinbaseExecution is\n ICoinbaseExecution,\n RONTransferHelper,\n PCUSortValidators,\n PCUPickValidatorSet,\n HasContracts,\n HasStakingVestingDeprecated,\n HasBridgeTrackingDeprecated,\n HasMaintenanceDeprecated,\n HasSlashIndicatorDeprecated,\n EmergencyExit\n{\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n modifier onlyCoinbase() {\n _requireCoinbase();\n _;\n }\n\n modifier whenEpochEnding() {\n if (!epochEndingAt(block.number)) revert ErrAtEndOfEpochOnly();\n _;\n }\n\n modifier oncePerEpoch() {\n if (epochOf(_lastUpdatedBlock) >= epochOf(block.number)) revert ErrAlreadyWrappedEpoch();\n _lastUpdatedBlock = block.number;\n _;\n }\n\n function _requireCoinbase() private view {\n if (msg.sender != block.coinbase) revert ErrCallerMustBeCoinbase();\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function submitBlockReward() external payable override onlyCoinbase {\n bool requestForBlockProducer = isBlockProducer(msg.sender) &&\n !_jailed(msg.sender) &&\n !_miningRewardDeprecated(msg.sender, currentPeriod());\n\n (, uint256 blockProducerBonus, , uint256 fastFinalityRewardPercentage) = IStakingVesting(\n getContract(ContractType.STAKING_VESTING)\n ).requestBonus({ forBlockProducer: requestForBlockProducer, forBridgeOperator: false });\n\n // Deprecates reward for non-validator or slashed validator\n if (!requestForBlockProducer) {\n _totalDeprecatedReward += msg.value;\n emit BlockRewardDeprecated(msg.sender, msg.value, BlockRewardDeprecatedType.UNAVAILABILITY);\n return;\n }\n\n emit BlockRewardSubmitted(msg.sender, msg.value, blockProducerBonus);\n\n uint256 period = currentPeriod();\n uint256 reward = msg.value + blockProducerBonus;\n uint256 rewardFastFinality = (reward * fastFinalityRewardPercentage) / _MAX_PERCENTAGE; // reward for fast finality\n uint256 rewardProducingBlock = reward - rewardFastFinality; // reward for producing blocks\n uint256 cutOffReward;\n\n // Add fast finality reward to total reward for current epoch, then split it later in the {wrapupEpoch} method.\n _totalFastFinalityReward += rewardFastFinality;\n\n if (_miningRewardBailoutCutOffAtPeriod[msg.sender][period]) {\n (, , , uint256 cutOffPercentage) = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR))\n .getCreditScoreConfigs();\n cutOffReward = (rewardProducingBlock * cutOffPercentage) / _MAX_PERCENTAGE;\n _totalDeprecatedReward += cutOffReward;\n emit BlockRewardDeprecated(msg.sender, cutOffReward, BlockRewardDeprecatedType.AFTER_BAILOUT);\n }\n\n rewardProducingBlock -= cutOffReward;\n (uint256 minRate, uint256 maxRate) = IStaking(getContract(ContractType.STAKING)).getCommissionRateRange();\n uint256 rate = Math.max(Math.min(_candidateInfo[msg.sender].commissionRate, maxRate), minRate);\n uint256 miningAmount = (rate * rewardProducingBlock) / _MAX_PERCENTAGE;\n _miningReward[msg.sender] += miningAmount;\n\n uint256 delegatingAmount = rewardProducingBlock - miningAmount;\n _delegatingReward[msg.sender] += delegatingAmount;\n }\n\n /**\n * @inheritdoc ICoinbaseExecution\n */\n function wrapUpEpoch() external payable virtual override onlyCoinbase whenEpochEnding oncePerEpoch {\n uint256 _newPeriod = _computePeriod(block.timestamp);\n bool _periodEnding = _isPeriodEnding(_newPeriod);\n\n address[] memory _currentValidators = getValidators();\n address[] memory _revokedCandidates;\n uint256 _epoch = epochOf(block.number);\n uint256 _nextEpoch = _epoch + 1;\n uint256 _lastPeriod = currentPeriod();\n\n _syncFastFinalityReward(_epoch, _currentValidators);\n\n if (_periodEnding) {\n (\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) = _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(_lastPeriod, _currentValidators);\n _settleAndTransferDelegatingRewards(_lastPeriod, _currentValidators, _totalDelegatingReward, _delegatingRewards);\n _tryRecycleLockedFundsFromEmergencyExits();\n _recycleDeprecatedRewards();\n ISlashIndicator _slashIndicatorContract = ISlashIndicator(getContract(ContractType.SLASH_INDICATOR));\n _slashIndicatorContract.updateCreditScores(_currentValidators, _lastPeriod);\n (_currentValidators, _revokedCandidates) = _syncValidatorSet(_newPeriod);\n if (_revokedCandidates.length > 0) {\n _slashIndicatorContract.execResetCreditScores(_revokedCandidates);\n }\n _currentPeriodStartAtBlock = block.number + 1;\n }\n _revampRoles(_newPeriod, _nextEpoch, _currentValidators);\n emit WrappedUpEpoch(_lastPeriod, _epoch, _periodEnding);\n _periodOf[_nextEpoch] = _newPeriod;\n _lastUpdatedPeriod = _newPeriod;\n }\n\n /**\n * @dev This method calculate and update reward of each `validators` accordingly thier fast finality voting performance\n * in the `epoch`. The leftover reward is added to the {_totalDeprecatedReward} and is recycled later to the\n * {StakingVesting} contract.\n *\n * Requirements:\n * - This method is only called once each epoch.\n */\n function _syncFastFinalityReward(uint256 epoch, address[] memory validators) private {\n uint256[] memory voteCounts = IFastFinalityTracking(getContract(ContractType.FAST_FINALITY_TRACKING))\n .getManyFinalityVoteCounts(epoch, validators);\n uint256 divisor = _numberOfBlocksInEpoch * validators.length;\n uint256 iReward;\n uint256 totalReward = _totalFastFinalityReward;\n uint256 totalDispensedReward = 0;\n\n for (uint i; i < validators.length; ) {\n iReward = (totalReward * voteCounts[i]) / divisor;\n _fastFinalityReward[validators[i]] += iReward;\n totalDispensedReward += iReward;\n unchecked {\n ++i;\n }\n }\n\n _totalDeprecatedReward += (totalReward - totalDispensedReward);\n delete _totalFastFinalityReward;\n }\n\n /**\n * @dev This loops over all current validators to:\n * - Update delegating reward for and calculate total delegating rewards to be sent to the staking contract,\n * - Distribute the reward of block producers and bridge operators to their treasury addresses,\n * - Update the total deprecated reward if the two previous conditions do not sastify.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeRewardToTreasuriesAndCalculateTotalDelegatingReward(\n uint256 _lastPeriod,\n address[] memory _currentValidators\n ) private returns (uint256 _totalDelegatingReward, uint256[] memory _delegatingRewards) {\n address _consensusAddr;\n address payable _treasury;\n _delegatingRewards = new uint256[](_currentValidators.length);\n\n for (uint _i; _i < _currentValidators.length; ) {\n _consensusAddr = _currentValidators[_i];\n _treasury = _candidateInfo[_consensusAddr].treasuryAddr;\n\n if (!_jailed(_consensusAddr) && !_miningRewardDeprecated(_consensusAddr, _lastPeriod)) {\n _totalDelegatingReward += _delegatingReward[_consensusAddr];\n _delegatingRewards[_i] = _delegatingReward[_consensusAddr];\n _distributeMiningReward(_consensusAddr, _treasury);\n _distributeFastFinalityReward(_consensusAddr, _treasury);\n } else {\n _totalDeprecatedReward +=\n _miningReward[_consensusAddr] +\n _delegatingReward[_consensusAddr] +\n _fastFinalityReward[_consensusAddr];\n }\n\n delete _delegatingReward[_consensusAddr];\n delete _miningReward[_consensusAddr];\n delete _fastFinalityReward[_consensusAddr];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @dev Distributes bonus of staking vesting and mining fee for the block producer.\n *\n * Emits the `MiningRewardDistributed` once the reward is distributed successfully.\n * Emits the `MiningRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _distributeMiningReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _miningReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit MiningRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit MiningRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n function _distributeFastFinalityReward(address _consensusAddr, address payable _treasury) private {\n uint256 _amount = _fastFinalityReward[_consensusAddr];\n if (_amount > 0) {\n if (_unsafeSendRONLimitGas(_treasury, _amount, DEFAULT_ADDITION_GAS)) {\n emit FastFinalityRewardDistributed(_consensusAddr, _treasury, _amount);\n return;\n }\n\n emit FastFinalityRewardDistributionFailed(_consensusAddr, _treasury, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Helper function to settle rewards for delegators of `_currentValidators` at the end of each period,\n * then transfer the rewards from this contract to the staking contract, in order to finalize a period.\n *\n * Emits the `StakingRewardDistributed` once the reward is distributed successfully.\n * Emits the `StakingRewardDistributionFailed` once the contract fails to distribute reward.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _settleAndTransferDelegatingRewards(\n uint256 _period,\n address[] memory _currentValidators,\n uint256 _totalDelegatingReward,\n uint256[] memory _delegatingRewards\n ) private {\n IStaking _staking = IStaking(getContract(ContractType.STAKING));\n if (_totalDelegatingReward > 0) {\n if (_unsafeSendRON(payable(address(_staking)), _totalDelegatingReward)) {\n _staking.execRecordRewards(_currentValidators, _delegatingRewards, _period);\n emit StakingRewardDistributed(_totalDelegatingReward, _currentValidators, _delegatingRewards);\n return;\n }\n\n emit StakingRewardDistributionFailed(\n _totalDelegatingReward,\n _currentValidators,\n _delegatingRewards,\n address(this).balance\n );\n }\n }\n\n /**\n * @dev Transfer the deprecated rewards e.g. the rewards that get deprecated when validator is slashed/maintained,\n * to the staking vesting contract\n *\n * Note: This method should be called once in the end of each period.\n */\n function _recycleDeprecatedRewards() private {\n uint256 _withdrawAmount = _totalDeprecatedReward;\n\n if (_withdrawAmount != 0) {\n address _withdrawTarget = getContract(ContractType.STAKING_VESTING);\n\n delete _totalDeprecatedReward;\n\n (bool _success, ) = _withdrawTarget.call{ value: _withdrawAmount }(\n abi.encodeWithSelector(IStakingVesting.receiveRON.selector)\n );\n\n if (_success) {\n emit DeprecatedRewardRecycled(_withdrawTarget, _withdrawAmount);\n } else {\n emit DeprecatedRewardRecycleFailed(_withdrawTarget, _withdrawAmount, address(this).balance);\n }\n }\n }\n\n /**\n * @dev Updates the validator set based on the validator candidates from the Staking contract.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _syncValidatorSet(\n uint256 _newPeriod\n ) private returns (address[] memory _newValidators, address[] memory _unsastifiedCandidates) {\n _unsastifiedCandidates = _syncCandidateSet(_newPeriod);\n uint256[] memory _weights = IStaking(getContract(ContractType.STAKING)).getManyStakingTotals(_candidates);\n uint256[] memory _trustedWeights = IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION))\n .getConsensusWeights(_candidates);\n uint256 _newValidatorCount;\n (_newValidators, _newValidatorCount) = _pcPickValidatorSet(\n _candidates,\n _weights,\n _trustedWeights,\n _maxValidatorNumber,\n _maxPrioritizedValidatorNumber\n );\n _setNewValidatorSet(_newValidators, _newValidatorCount, _newPeriod);\n }\n\n /**\n * @dev Private helper function helps writing the new validator set into the contract storage.\n *\n * Emits the `ValidatorSetUpdated` event.\n *\n * Note: This method should be called once in the end of each period.\n *\n */\n function _setNewValidatorSet(\n address[] memory _newValidators,\n uint256 _newValidatorCount,\n uint256 _newPeriod\n ) private {\n // Remove exceeding validators in the current set\n for (uint256 _i = _newValidatorCount; _i < validatorCount; ) {\n delete _validatorMap[_validators[_i]];\n delete _validators[_i];\n\n unchecked {\n ++_i;\n }\n }\n\n // Remove flag for all validator in the current set\n for (uint _i; _i < _newValidatorCount; ) {\n delete _validatorMap[_validators[_i]];\n\n unchecked {\n ++_i;\n }\n }\n\n // Update new validator set and set flag correspondingly.\n for (uint256 _i; _i < _newValidatorCount; ) {\n address _newValidator = _newValidators[_i];\n _validatorMap[_newValidator] = EnumFlags.ValidatorFlag.Both;\n _validators[_i] = _newValidator;\n\n unchecked {\n ++_i;\n }\n }\n\n validatorCount = _newValidatorCount;\n emit ValidatorSetUpdated(_newPeriod, _newValidators);\n }\n\n /**\n * @dev Activate/Deactivate the validators from producing blocks, based on their in jail status and maintenance status.\n *\n * Requirements:\n * - This method is called at the end of each epoch\n *\n * Emits the `BlockProducerSetUpdated` event.\n * Emits the `BridgeOperatorSetUpdated` event.\n *\n */\n function _revampRoles(uint256 _newPeriod, uint256 _nextEpoch, address[] memory _currentValidators) private {\n bool[] memory _maintainedList = IMaintenance(getContract(ContractType.MAINTENANCE)).checkManyMaintained(\n _currentValidators,\n block.number + 1\n );\n\n for (uint _i; _i < _currentValidators.length; ) {\n address _validator = _currentValidators[_i];\n bool _emergencyExitRequested = block.timestamp <= _emergencyExitJailedTimestamp[_validator];\n bool _isProducerBefore = isBlockProducer(_validator);\n bool _isProducerAfter = !(_jailedAtBlock(_validator, block.number + 1) ||\n _maintainedList[_i] ||\n _emergencyExitRequested);\n\n if (!_isProducerBefore && _isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].addFlag(EnumFlags.ValidatorFlag.BlockProducer);\n } else if (_isProducerBefore && !_isProducerAfter) {\n _validatorMap[_validator] = _validatorMap[_validator].removeFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n unchecked {\n ++_i;\n }\n }\n emit BlockProducerSetUpdated(_newPeriod, _nextEpoch, getBlockProducers());\n }\n\n /**\n * @dev Override `CandidateManager-_isTrustedOrg`.\n */\n function _isTrustedOrg(address _consensusAddr) internal view override returns (bool) {\n return\n IRoninTrustedOrganization(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).getConsensusWeight(\n _consensusAddr\n ) > 0;\n }\n}\n" + }, + "contracts/ronin/validator/EmergencyExit.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/RONTransferHelper.sol\";\nimport \"../../interfaces/IRoninGovernanceAdmin.sol\";\nimport \"../../interfaces/validator/IEmergencyExit.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\nimport \"./CandidateManager.sol\";\n\nabstract contract EmergencyExit is IEmergencyExit, RONTransferHelper, CandidateManager, CommonStorage {\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExitLockedAmount() external view returns (uint256) {\n return _emergencyExitLockedAmount;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function emergencyExpiryDuration() external view returns (uint256) {\n return _emergencyExpiryDuration;\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execEmergencyExit(\n address _consensusAddr,\n uint256 _secLeftToRevoke\n ) external onlyContract(ContractType.STAKING) {\n EmergencyExitInfo storage _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt != 0) revert ErrAlreadyRequestedEmergencyExit();\n\n uint256 _revokingTimestamp = block.timestamp + _secLeftToRevoke;\n _setRevokingTimestamp(_candidateInfo[_consensusAddr], _revokingTimestamp);\n _emergencyExitJailedTimestamp[_consensusAddr] = _revokingTimestamp;\n\n uint256 _deductedAmount = IStaking(msg.sender).execDeductStakingAmount(_consensusAddr, _emergencyExitLockedAmount);\n if (_deductedAmount > 0) {\n uint256 _recyclingAt = block.timestamp + _emergencyExpiryDuration;\n _lockedConsensusList.push(_consensusAddr);\n _info.lockedAmount = _deductedAmount;\n _info.recyclingAt = _recyclingAt;\n IRoninGovernanceAdmin(_getAdmin()).createEmergencyExitPoll(\n _consensusAddr,\n _candidateInfo[_consensusAddr].treasuryAddr,\n block.timestamp,\n _recyclingAt\n );\n }\n emit EmergencyExitRequested(_consensusAddr, _deductedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExitLockedAmount(uint256 _emergencyExitLockedAmount) external onlyAdmin {\n _setEmergencyExitLockedAmount(_emergencyExitLockedAmount);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function setEmergencyExpiryDuration(uint256 _emergencyExpiryDuration) external onlyAdmin {\n _setEmergencyExpiryDuration(_emergencyExpiryDuration);\n }\n\n /**\n * @inheritdoc IEmergencyExit\n */\n function execReleaseLockedFundForEmergencyExitRequest(\n address _consensusAddr,\n address payable _recipient\n ) external onlyAdmin {\n if (_exitInfo[_consensusAddr].recyclingAt == 0) {\n return;\n }\n\n uint256 _length = _lockedConsensusList.length;\n uint256 _index = _length;\n\n for (uint _i; _i < _length; ) {\n if (_lockedConsensusList[_i] == _consensusAddr) {\n _index = _i;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n\n // The locked amount might be recycled\n if (_index == _length) {\n return;\n }\n\n uint256 _amount = _exitInfo[_consensusAddr].lockedAmount;\n if (_amount > 0) {\n delete _exitInfo[_consensusAddr];\n if (_length > 1) {\n _lockedConsensusList[_index] = _lockedConsensusList[_length - 1];\n }\n _lockedConsensusList.pop();\n\n _lockedFundReleased[_consensusAddr] = true;\n if (_unsafeSendRONLimitGas(_recipient, _amount, DEFAULT_ADDITION_GAS)) {\n emit EmergencyExitLockedFundReleased(_consensusAddr, _recipient, _amount);\n return;\n }\n\n emit EmergencyExitLockedFundReleasingFailed(_consensusAddr, _recipient, _amount, address(this).balance);\n }\n }\n\n /**\n * @dev Tries to recycle the locked funds from emergency exit requests.\n */\n function _tryRecycleLockedFundsFromEmergencyExits() internal {\n uint256 _length = _lockedConsensusList.length;\n\n uint256 _i;\n address _addr;\n EmergencyExitInfo storage _info;\n\n while (_i < _length) {\n _addr = _lockedConsensusList[_i];\n _info = _exitInfo[_addr];\n\n if (_info.recyclingAt <= block.timestamp) {\n _totalDeprecatedReward += _info.lockedAmount;\n\n delete _exitInfo[_addr];\n if (--_length > 0) {\n _lockedConsensusList[_i] = _lockedConsensusList[_length];\n }\n _lockedConsensusList.pop();\n continue;\n }\n\n unchecked {\n _i++;\n }\n }\n }\n\n /**\n * @dev Override `CandidateManager-_emergencyExitLockedFundReleased`.\n */\n function _emergencyExitLockedFundReleased(address _consensusAddr) internal virtual override returns (bool) {\n return _lockedFundReleased[_consensusAddr];\n }\n\n /**\n * @dev Override `CandidateManager-_removeCandidate`.\n */\n function _removeCandidate(address _consensusAddr) internal override {\n delete _lockedFundReleased[_consensusAddr];\n super._removeCandidate(_consensusAddr);\n }\n\n /**\n * @dev See `setEmergencyExitLockedAmount.\n */\n function _setEmergencyExitLockedAmount(uint256 _amount) internal {\n _emergencyExitLockedAmount = _amount;\n emit EmergencyExitLockedAmountUpdated(_amount);\n }\n\n /**\n * @dev See `setEmergencyExpiryDuration`.\n */\n function _setEmergencyExpiryDuration(uint256 _duration) internal {\n _emergencyExpiryDuration = _duration;\n emit EmergencyExpiryDurationUpdated(_duration);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/NotifiedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ErrUnauthorizedCall } from \"../../../utils/CommonErrors.sol\";\n\ncontract NotifiedMigrator is ConditionalImplementControl {\n address public immutable NOTIFIER;\n\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl,\n address notifier\n ) payable ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {\n NOTIFIER = notifier;\n }\n\n /**\n * @dev See {IConditionalImplementControl-selfUpgrade}.\n */\n function selfUpgrade() external override onlyDelegateFromProxyStorage {\n if (msg.sender != NOTIFIER) revert ErrUnauthorizedCall(msg.sig);\n _upgradeTo(NEW_IMPL);\n }\n}\n" + }, + "contracts/ronin/validator/migrations/RoninValidatorSetTimedMigrator.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { IdentityGuard, IConditionalImplementControl, ConditionalImplementControl } from \"../../../extensions/version-control/ConditionalImplementControl.sol\";\nimport { ITimingInfo } from \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\nimport { ICoinbaseExecution } from \"../../../interfaces/validator/ICoinbaseExecution.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../../../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ContractType } from \"../../../utils/ContractType.sol\";\n\n/**\n * @title RoninValidatorSetTimedMigrator\n * @dev A contract that facilitates timed migration of the Ronin validator set using conditional version control.\n */\ncontract RoninValidatorSetTimedMigrator is ConditionalImplementControl {\n /**\n * @dev Modifier that executes the function when conditions are met.\n * If the function is {wrapUpEpoch} from {ICoinbaseExecution},\n * it checks the current period before and after execution.\n * If they differ, it triggers the {selfUpgrade} function.\n */\n modifier whenConditionsAreMet() override {\n if (msg.sig == ICoinbaseExecution.wrapUpEpoch.selector) {\n uint256 currentPeriod = _getCurrentPeriod();\n _;\n if (currentPeriod != _getCurrentPeriod()) {\n this.selfUpgrade();\n }\n } else {\n _;\n }\n }\n\n /**\n * @dev Constructs the {RoninValidatorSetTimedMigrator} contract.\n * @param proxyStorage The address of the proxy storage contract.\n * @param prevImpl The address of the current contract implementation.\n * @param newImpl The address of the new contract implementation.\n */\n constructor(\n address proxyStorage,\n address prevImpl,\n address newImpl\n ) ConditionalImplementControl(proxyStorage, prevImpl, newImpl) {}\n\n function selfUpgrade() external override onlyDelegateFromProxyStorage onlySelfCall {\n _upgradeTo(NEW_IMPL);\n\n IConditionalImplementControl(getContract(ContractType.STAKING)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.SLASH_INDICATOR)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.RONIN_TRUSTED_ORGANIZATION)).selfUpgrade();\n IConditionalImplementControl(getContract(ContractType.BRIDGE_TRACKING)).selfUpgrade();\n }\n\n /**\n * @dev Internal function to choose the current version of the contract implementation.\n * @return The address of the current version implementation.\n */\n function _getConditionedImplementation() internal view override returns (address) {\n return PREV_IMPL;\n }\n\n /**\n * @dev Internal function to get the current period from ITimingInfo.\n * @return The current period.\n */\n function _getCurrentPeriod() private view returns (uint256) {\n return ITimingInfo(address(this)).currentPeriod();\n }\n\n function _requireSelfCall() internal view override {\n ConditionalImplementControl._requireSelfCall();\n }\n}\n" + }, + "contracts/ronin/validator/RoninValidatorSet.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"@openzeppelin/contracts/proxy/utils/Initializable.sol\";\nimport \"../../interfaces/validator/IRoninValidatorSet.sol\";\nimport \"./CoinbaseExecution.sol\";\nimport \"./SlashingExecution.sol\";\n\ncontract RoninValidatorSet is Initializable, CoinbaseExecution, SlashingExecution {\n constructor() {\n _disableInitializers();\n }\n\n fallback() external payable {\n _fallback();\n }\n\n receive() external payable {\n _fallback();\n }\n\n /**\n * @dev Initializes the contract storage.\n */\n function initialize(\n address __slashIndicatorContract,\n address __stakingContract,\n address __stakingVestingContract,\n address __maintenanceContract,\n address __roninTrustedOrganizationContract,\n address /* __bridgeTrackingContract */,\n uint256 __maxValidatorNumber,\n uint256 __maxValidatorCandidate,\n uint256 __maxPrioritizedValidatorNumber,\n uint256 __minEffectiveDaysOnwards,\n uint256 __numberOfBlocksInEpoch,\n // __emergencyExitConfigs[0]: emergencyExitLockedAmount\n // __emergencyExitConfigs[1]: emergencyExpiryDuration\n uint256[2] calldata __emergencyExitConfigs\n ) external initializer {\n _setContract(ContractType.SLASH_INDICATOR, __slashIndicatorContract);\n _setContract(ContractType.STAKING, __stakingContract);\n _setContract(ContractType.STAKING_VESTING, __stakingVestingContract);\n _setContract(ContractType.MAINTENANCE, __maintenanceContract);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, __roninTrustedOrganizationContract);\n\n _setMaxValidatorNumber(__maxValidatorNumber);\n _setMaxValidatorCandidate(__maxValidatorCandidate);\n _setMaxPrioritizedValidatorNumber(__maxPrioritizedValidatorNumber);\n _setMinEffectiveDaysOnwards(__minEffectiveDaysOnwards);\n _setEmergencyExitLockedAmount(__emergencyExitConfigs[0]);\n _setEmergencyExpiryDuration(__emergencyExitConfigs[1]);\n _numberOfBlocksInEpoch = __numberOfBlocksInEpoch;\n }\n\n function initializeV2() external reinitializer(2) {\n _setContract(ContractType.STAKING, ______deprecatedStakingContract);\n _setContract(ContractType.MAINTENANCE, ______deprecatedMaintenance);\n _setContract(ContractType.SLASH_INDICATOR, ______deprecatedSlashIndicator);\n _setContract(ContractType.STAKING_VESTING, ______deprecatedStakingVesting);\n _setContract(ContractType.RONIN_TRUSTED_ORGANIZATION, ______deprecatedTrustedOrg);\n\n delete ______deprecatedStakingContract;\n delete ______deprecatedMaintenance;\n delete ______deprecatedSlashIndicator;\n delete ______deprecatedStakingVesting;\n delete ______deprecatedBridgeTracking;\n delete ______deprecatedTrustedOrg;\n }\n\n function initializeV3(address fastFinalityTrackingContract) external reinitializer(3) {\n _setContract(ContractType.FAST_FINALITY_TRACKING, fastFinalityTrackingContract);\n }\n\n /**\n * @dev Only receives RON from staking vesting contract (for topping up bonus), and from staking contract (for transferring\n * deducting amount on slashing).\n */\n function _fallback() internal view {\n if (msg.sender != getContract(ContractType.STAKING_VESTING) && msg.sender != getContract(ContractType.STAKING)) {\n revert ErrUnauthorizedReceiveRON();\n }\n }\n}\n" + }, + "contracts/ronin/validator/SlashingExecution.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../extensions/collections/HasContracts.sol\";\nimport \"../../interfaces/validator/ISlashingExecution.sol\";\nimport \"../../interfaces/staking/IStaking.sol\";\nimport \"../../libraries/Math.sol\";\nimport { HasSlashIndicatorDeprecated, HasStakingDeprecated } from \"../../utils/DeprecatedSlots.sol\";\nimport \"./storage-fragments/CommonStorage.sol\";\n\nabstract contract SlashingExecution is\n ISlashingExecution,\n HasContracts,\n HasSlashIndicatorDeprecated,\n HasStakingDeprecated,\n CommonStorage\n{\n /**\n * @inheritdoc ISlashingExecution\n */\n function execSlash(\n address validatorAddr,\n uint256 newJailedUntil,\n uint256 slashAmount,\n bool cannotBailout\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n uint256 period = currentPeriod();\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = true;\n\n _totalDeprecatedReward += _miningReward[validatorAddr] + _delegatingReward[validatorAddr];\n\n delete _miningReward[validatorAddr];\n delete _delegatingReward[validatorAddr];\n\n _blockProducerJailedBlock[validatorAddr] = Math.max(newJailedUntil, _blockProducerJailedBlock[validatorAddr]);\n\n if (slashAmount > 0) {\n uint256 _actualAmount = IStaking(getContract(ContractType.STAKING)).execDeductStakingAmount(\n validatorAddr,\n slashAmount\n );\n _totalDeprecatedReward += _actualAmount;\n }\n\n if (cannotBailout) {\n _cannotBailoutUntilBlock[validatorAddr] = Math.max(newJailedUntil, _cannotBailoutUntilBlock[validatorAddr]);\n }\n\n emit ValidatorPunished(validatorAddr, period, _blockProducerJailedBlock[validatorAddr], slashAmount, true, false);\n }\n\n /**\n * @inheritdoc ISlashingExecution\n */\n function execBailOut(\n address validatorAddr,\n uint256 period\n ) external override onlyContract(ContractType.SLASH_INDICATOR) {\n if (block.number <= _cannotBailoutUntilBlock[validatorAddr]) revert ErrCannotBailout(validatorAddr);\n\n // Note: Removing rewards of validator in `bailOut` function is not needed, since the rewards have been\n // removed previously in the `slash` function.\n _miningRewardBailoutCutOffAtPeriod[validatorAddr][period] = true;\n _miningRewardDeprecatedAtPeriod[validatorAddr][period] = false;\n _blockProducerJailedBlock[validatorAddr] = block.number - 1;\n\n emit ValidatorUnjailed(validatorAddr, period);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/CommonStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/ICommonInfo.sol\";\nimport \"./JailingStorage.sol\";\nimport \"./TimingStorage.sol\";\nimport \"./ValidatorInfoStorageV2.sol\";\n\nabstract contract CommonStorage is ICommonInfo, TimingStorage, JailingStorage, ValidatorInfoStorageV2 {\n /// @dev Mapping from consensus address => pending reward from producing block\n mapping(address => uint256) internal _miningReward;\n /// @dev Mapping from consensus address => pending reward from delegating\n mapping(address => uint256) internal _delegatingReward;\n\n /// @dev The total reward for fast finality\n uint256 internal _totalFastFinalityReward;\n /// @dev Mapping from consensus address => pending reward for fast finality\n mapping(address => uint256) internal _fastFinalityReward;\n\n /// @dev The deprecated reward that has not been withdrawn by admin\n uint256 internal _totalDeprecatedReward;\n\n /// @dev The amount of RON to lock from a consensus address.\n uint256 internal _emergencyExitLockedAmount;\n /// @dev The duration that an emergency request is expired and the fund will be recycled.\n uint256 internal _emergencyExpiryDuration;\n /// @dev The address list of consensus addresses that being locked fund.\n address[] internal _lockedConsensusList;\n /// @dev Mapping from consensus => request exist info\n mapping(address => EmergencyExitInfo) internal _exitInfo;\n /// @dev Mapping from consensus => flag indicating whether the locked fund is released\n mapping(address => bool) internal _lockedFundReleased;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[44] private ______gap;\n\n /**\n * @inheritdoc ICommonInfo\n */\n function getEmergencyExitInfo(\n address _consensusAddr\n ) external view override returns (EmergencyExitInfo memory _info) {\n _info = _exitInfo[_consensusAddr];\n if (_info.recyclingAt == 0) revert NonExistentRecyclingInfo();\n }\n\n /**\n * @inheritdoc ICommonInfo\n */\n function totalDeprecatedReward() external view override returns (uint256) {\n return _totalDeprecatedReward;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(\n uint256 _block\n ) public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.epochOf(_block);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override(ITimingInfo, JailingStorage, TimingStorage) returns (uint256) {\n return TimingStorage.currentPeriod();\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/JailingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../interfaces/validator/info-fragments/IJailingInfo.sol\";\nimport \"./TimingStorage.sol\";\n\nabstract contract JailingStorage is IJailingInfo {\n /// @dev Mapping from consensus address => period number => block producer has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardDeprecatedAtPeriod;\n /// @dev Mapping from consensus address => period number => whether the block producer get cut off reward, due to bailout.\n mapping(address => mapping(uint256 => bool)) internal _miningRewardBailoutCutOffAtPeriod;\n /// @dev Mapping from consensus address => period number => block operator has no pending reward.\n mapping(address => mapping(uint256 => bool)) internal ______deprecatedBridgeRewardDeprecatedAtPeriod;\n\n /// @dev Mapping from consensus address => the last block that the block producer is jailed.\n mapping(address => uint256) internal _blockProducerJailedBlock;\n /// @dev Mapping from consensus address => the last timestamp that the bridge operator is jailed.\n mapping(address => uint256) internal _emergencyExitJailedTimestamp;\n /// @dev Mapping from consensus address => the last block that the block producer cannot bailout.\n mapping(address => uint256) internal _cannotBailoutUntilBlock;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[48] private ______gap;\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailed(address _addr) external view override returns (bool) {\n return checkJailedAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeft(\n address _addr\n ) external view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n return getJailedTimeLeftAtBlock(_addr, block.number);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkJailedAtBlock(address _addr, uint256 _blockNum) public view override returns (bool) {\n return _jailedAtBlock(_addr, _blockNum);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function getJailedTimeLeftAtBlock(\n address _addr,\n uint256 _blockNum\n ) public view override returns (bool isJailed_, uint256 blockLeft_, uint256 epochLeft_) {\n uint256 _jailedBlock = _blockProducerJailedBlock[_addr];\n if (_jailedBlock < _blockNum) {\n return (false, 0, 0);\n }\n\n isJailed_ = true;\n blockLeft_ = _jailedBlock - _blockNum + 1;\n epochLeft_ = epochOf(_jailedBlock) - epochOf(_blockNum) + 1;\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkManyJailed(address[] calldata _addrList) external view override returns (bool[] memory _result) {\n _result = new bool[](_addrList.length);\n for (uint256 _i; _i < _addrList.length; ) {\n _result[_i] = _jailed(_addrList[_i]);\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecated(address _blockProducer) external view override returns (bool _result) {\n uint256 _period = currentPeriod();\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @inheritdoc IJailingInfo\n */\n function checkMiningRewardDeprecatedAtPeriod(\n address _blockProducer,\n uint256 _period\n ) external view override returns (bool _result) {\n return _miningRewardDeprecated(_blockProducer, _period);\n }\n\n /**\n * @dev See `ITimingInfo-epochOf`\n */\n function epochOf(uint256 _block) public view virtual returns (uint256);\n\n /**\n * @dev See `ITimingInfo-currentPeriod`\n */\n function currentPeriod() public view virtual returns (uint256);\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) during the current period.\n */\n function _jailed(address _validatorAddr) internal view returns (bool) {\n return _jailedAtBlock(_validatorAddr, block.number);\n }\n\n /**\n * @dev Returns whether the reward of the validator is put in jail (cannot join the set of validators) at a specific block.\n */\n function _jailedAtBlock(address _validatorAddr, uint256 _blockNum) internal view returns (bool) {\n return _blockNum <= _blockProducerJailedBlock[_validatorAddr];\n }\n\n /**\n * @dev Returns whether the block producer has no pending reward in that period.\n */\n function _miningRewardDeprecated(address _validatorAddr, uint256 _period) internal view returns (bool) {\n return _miningRewardDeprecatedAtPeriod[_validatorAddr][_period];\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/TimingStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../extensions/consumers/GlobalConfigConsumer.sol\";\nimport \"../../../interfaces/validator/info-fragments/ITimingInfo.sol\";\n\nabstract contract TimingStorage is ITimingInfo, GlobalConfigConsumer {\n /// @dev The number of blocks in a epoch\n uint256 internal _numberOfBlocksInEpoch;\n /// @dev The last updated block\n uint256 internal _lastUpdatedBlock;\n /// @dev The last updated period\n uint256 internal _lastUpdatedPeriod;\n /// @dev The starting block of the last updated period\n uint256 internal _currentPeriodStartAtBlock;\n\n /// @dev Mapping from epoch index => period index\n mapping(uint256 => uint256) internal _periodOf;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[49] private ______gap;\n\n /**\n * @inheritdoc ITimingInfo\n */\n function getLastUpdatedBlock() external view override returns (uint256) {\n return _lastUpdatedBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochOf(uint256 _block) public view virtual override returns (uint256) {\n return _block / _numberOfBlocksInEpoch + 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function tryGetPeriodOfEpoch(uint256 _epoch) external view returns (bool _filled, uint256 _periodNumber) {\n return (_epoch <= epochOf(block.number) || _periodOf[_epoch] > 0, _periodOf[_epoch]);\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function isPeriodEnding() external view override returns (bool) {\n return _isPeriodEnding(_computePeriod(block.timestamp));\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function epochEndingAt(uint256 _block) public view virtual override returns (bool) {\n return _block % _numberOfBlocksInEpoch == _numberOfBlocksInEpoch - 1;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriod() public view virtual override returns (uint256) {\n return _lastUpdatedPeriod;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function currentPeriodStartAtBlock() public view override returns (uint256) {\n return _currentPeriodStartAtBlock;\n }\n\n /**\n * @inheritdoc ITimingInfo\n */\n function numberOfBlocksInEpoch() public view virtual override returns (uint256 _numberOfBlocks) {\n return _numberOfBlocksInEpoch;\n }\n\n /**\n * @dev See `ITimingInfo-isPeriodEnding`\n */\n function _isPeriodEnding(uint256 _newPeriod) internal view virtual returns (bool) {\n return _newPeriod > _lastUpdatedPeriod;\n }\n\n /**\n * @dev Returns the calculated period.\n */\n function _computePeriod(uint256 _timestamp) internal pure returns (uint256) {\n return _timestamp / PERIOD_DURATION;\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorage.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfo.sol\";\n\nabstract contract ValidatorInfoStorage is IValidatorInfo, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getValidators()\n public\n view\n override\n returns (\n address[] memory _validatorList,\n address[] memory _bridgeOperators,\n EnumFlags.ValidatorFlag[] memory _flags\n )\n {\n _validatorList = new address[](validatorCount);\n _bridgeOperators = new address[](validatorCount);\n _flags = new EnumFlags.ValidatorFlag[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n _bridgeOperators[_i] = _bridgeOperatorOf(_validator);\n _flags[_i] = _validatorMap[_validator];\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isValidator(address _addr) public view override returns (bool) {\n return !_validatorMap[_addr].isNone();\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperators()\n public\n view\n override\n returns (address[] memory _bridgeOperatorList, address[] memory _validatorList)\n {\n uint256 _length = validatorCount;\n _bridgeOperatorList = new address[](_length);\n _validatorList = new address[](_length);\n uint256 _count = 0;\n unchecked {\n for (uint _i; _i < _length; ++_i) {\n if (isOperatingBridge(_validators[_i])) {\n address __validator = _validators[_i];\n _bridgeOperatorList[_count] = _bridgeOperatorOf(__validator);\n _validatorList[_count++] = __validator;\n }\n }\n }\n\n assembly {\n mstore(_bridgeOperatorList, _count)\n mstore(_validatorList, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function getBridgeOperatorsOf(\n address[] memory _validatorAddrs\n ) public view override returns (address[] memory _bridgeOperatorList) {\n _bridgeOperatorList = new address[](_validatorAddrs.length);\n for (uint _i; _i < _bridgeOperatorList.length; ) {\n _bridgeOperatorList[_i] = _bridgeOperatorOf(_validatorAddrs[_i]);\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isBridgeOperator(address _bridgeOperatorAddr) external view override returns (bool _isOperator) {\n for (uint _i; _i < validatorCount; ) {\n if (_bridgeOperatorOf(_validators[_i]) == _bridgeOperatorAddr && isOperatingBridge(_validators[_i])) {\n _isOperator = true;\n break;\n }\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function isOperatingBridge(address _consensusAddr) public view override returns (bool) {\n return _validatorMap[_consensusAddr].hasFlag(EnumFlags.ValidatorFlag.DeprecatedBridgeOperator);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function totalBridgeOperator() public view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isOperatingBridge(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfo\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev Returns the bridge operator of a consensus address.\n */\n function _bridgeOperatorOf(address _consensusAddr) internal view virtual returns (address);\n\n /**\n * @dev See `IValidatorInfo-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfo-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/validator/storage-fragments/ValidatorInfoStorageV2.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../../../libraries/EnumFlags.sol\";\nimport { HasTrustedOrgDeprecated } from \"../../../utils/DeprecatedSlots.sol\";\nimport \"../../../extensions/collections/HasContracts.sol\";\nimport \"../../../interfaces/validator/info-fragments/IValidatorInfoV2.sol\";\n\nabstract contract ValidatorInfoStorageV2 is IValidatorInfoV2, HasContracts, HasTrustedOrgDeprecated {\n using EnumFlags for EnumFlags.ValidatorFlag;\n\n /// @dev The maximum number of validator.\n uint256 internal _maxValidatorNumber;\n\n /// @dev The total of validators\n uint256 public validatorCount;\n /// @dev Mapping from validator index => validator address\n mapping(uint256 => address) internal _validators;\n /// @dev Mapping from address => flag indicating the validator ability: producing block, operating bridge\n mapping(address => EnumFlags.ValidatorFlag) internal _validatorMap;\n /// @dev The number of slot that is reserved for prioritized validators\n uint256 internal _maxPrioritizedValidatorNumber;\n\n /**\n * @dev This empty reserved space is put in place to allow future versions to add new\n * variables without shifting down storage in the inheritance chain.\n */\n uint256[50] private ______gap;\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getValidators() public view override returns (address[] memory _validatorList) {\n _validatorList = new address[](validatorCount);\n for (uint _i; _i < _validatorList.length; ) {\n address _validator = _validators[_i];\n _validatorList[_i] = _validator;\n\n unchecked {\n ++_i;\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function getBlockProducers() public view override returns (address[] memory _result) {\n _result = new address[](validatorCount);\n uint256 _count = 0;\n for (uint _i; _i < _result.length; ) {\n if (isBlockProducer(_validators[_i])) {\n _result[_count++] = _validators[_i];\n }\n\n unchecked {\n ++_i;\n }\n }\n\n assembly {\n mstore(_result, _count)\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function isBlockProducer(address _addr) public view override returns (bool) {\n return _validatorMap[_addr].hasFlag(EnumFlags.ValidatorFlag.BlockProducer);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function totalBlockProducer() external view returns (uint256 _total) {\n unchecked {\n for (uint _i; _i < validatorCount; _i++) {\n if (isBlockProducer(_validators[_i])) {\n _total++;\n }\n }\n }\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxValidatorNumber() external view override returns (uint256 _maximumValidatorNumber) {\n return _maxValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function maxPrioritizedValidatorNumber() external view override returns (uint256 _maximumPrioritizedValidatorNumber) {\n return _maxPrioritizedValidatorNumber;\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxValidatorNumber(uint256 _max) external override onlyAdmin {\n _setMaxValidatorNumber(_max);\n }\n\n /**\n * @inheritdoc IValidatorInfoV2\n */\n function setMaxPrioritizedValidatorNumber(uint256 _number) external override onlyAdmin {\n _setMaxPrioritizedValidatorNumber(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxValidatorNumber`\n */\n function _setMaxValidatorNumber(uint256 _number) internal {\n _maxValidatorNumber = _number;\n emit MaxValidatorNumberUpdated(_number);\n }\n\n /**\n * @dev See `IValidatorInfoV2-setMaxPrioritizedValidatorNumber`\n */\n function _setMaxPrioritizedValidatorNumber(uint256 _number) internal {\n if (_number > _maxValidatorNumber) revert ErrInvalidMaxPrioritizedValidatorNumber();\n _maxPrioritizedValidatorNumber = _number;\n emit MaxPrioritizedValidatorNumberUpdated(_number);\n }\n}\n" + }, + "contracts/ronin/VaultForwarder.sol": { + "content": "// SPDX-License-Identifier: MIT\n\npragma solidity ^0.8.9;\n\nimport \"../extensions/forwarder/Forwarder.sol\";\nimport \"../extensions/RONTransferHelper.sol\";\n\n/**\n * @title A vault contract that keeps RON, and behaves as an EOA account to interact with a target contract.\n * @dev There are three roles of interaction:\n * - Admin: top-up and withdraw RON to the vault, cannot forward call to the target.\n * - Moderator: forward all calls to the target, can top-up RON, cannot withdraw RON.\n * - Others: can top-up RON, cannot execute any other actions.\n */\ncontract VaultForwarder is Forwarder, RONTransferHelper {\n /// @dev Emitted when the admin withdraws all RON from the forwarder contract.\n event ForwarderRONWithdrawn(address indexed _recipient, uint256 _value);\n\n constructor(address[] memory _targets, address _admin, address _mod) Forwarder(_targets, _admin, _mod) {}\n\n /**\n * @dev Withdraws all balance from the transfer to the admin.\n *\n * Requirements:\n * - Only the admin can call this method.\n */\n function withdrawAll() external onlyRole(DEFAULT_ADMIN_ROLE) {\n uint256 _value = address(this).balance;\n emit ForwarderRONWithdrawn(msg.sender, _value);\n _transferRON(payable(msg.sender), _value);\n }\n}\n" + }, + "contracts/types/operations/LibTUint256Slot.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { TUint256Slot } from \"../Types.sol\";\n\n/**\n * @title LibTUint256Slot\n * @dev Library for handling unsigned 256-bit integers.\n */\nlibrary LibTUint256Slot {\n /// @dev value is equal to bytes4(keccak256(\"Panic(uint256)\"))\n /// @dev see: https://github.com/foundry-rs/forge-std/blob/master/src/StdError.sol\n uint256 private constant PANIC_ERROR_SIGNATURE = 0x4e487b71;\n /// @dev error code for {Arithmetic over/underflow} error\n uint256 private constant ARITHMETIC_ERROR_CODE = 0x11;\n /// @dev error code for {Division or modulo by 0} error\n uint256 private constant DIVISION_ERROR_CODE = 0x12;\n\n /**\n * @dev Loads the value of the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @return val The loaded value.\n */\n function load(TUint256Slot self) internal view returns (uint256 val) {\n assembly {\n val := sload(self)\n }\n }\n\n /**\n * @dev Stores a value into the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to be stored.\n */\n function store(TUint256Slot self, uint256 other) internal {\n assembly {\n sstore(self, other)\n }\n }\n\n /**\n * @dev Multiplies the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to multiply by.\n * @return res The resulting value after multiplication.\n */\n function mul(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n if iszero(iszero(storedVal)) {\n res := mul(storedVal, other)\n\n // Overflow check\n if iszero(eq(other, div(res, storedVal))) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n }\n\n /**\n * @dev Divides the TUint256Slot variable by a given value.\n * @param self The TUint256Slot variable.\n * @param other The value to divide by.\n * @return res The resulting value after division.\n */\n function div(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n // revert if divide by zero\n if iszero(other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, DIVISION_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n res := div(storedVal, other)\n }\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction.\n */\n function sub(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n\n // Underflow check\n if lt(storedVal, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n\n res := sub(storedVal, other)\n }\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition.\n */\n function add(TUint256Slot self, uint256 other) internal view returns (uint256 res) {\n assembly {\n let storedVal := sload(self)\n res := add(storedVal, other)\n\n // Overflow check\n if lt(res, other) {\n // Store 4 bytes the function selector of Panic(uint256)\n // Equivalent to revert Panic(uint256)\n mstore(0x00, PANIC_ERROR_SIGNATURE)\n // Store 4 bytes of division error code in the next slot\n mstore(0x20, ARITHMETIC_ERROR_CODE)\n // Revert 36 bytes of error starting from 0x1c\n revert(0x1c, 0x24)\n }\n }\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after incrementing.\n */\n function preIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = addAssign(self, 1);\n }\n\n /**\n * @dev Increments the TUint256Slot variable by 1 and returns the original value.\n * @param self The TUint256Slot variable.\n * @return res The original value before incrementing.\n */\n function postIncrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res + 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value after decrementing.\n */\n function preDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = subAssign(self, 1);\n }\n\n /**\n * @dev Decrements the TUint256Slot variable by 1 and returns the new value.\n * @param self The TUint256Slot variable.\n * @return res The resulting value before decrementing.\n */\n function postDecrement(TUint256Slot self) internal returns (uint256 res) {\n res = load(self);\n store(self, res - 1);\n }\n\n /**\n * @dev Adds a given value to the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to add.\n * @return res The resulting value after addition and storage.\n */\n function addAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = add(self, other));\n }\n\n /**\n * @dev Subtracts a given value from the TUint256Slot variable and stores the result.\n * @param self The TUint256Slot variable.\n * @param other The value to subtract.\n * @return res The resulting value after subtraction and storage.\n */\n function subAssign(TUint256Slot self, uint256 other) internal returns (uint256 res) {\n store(self, res = sub(self, other));\n }\n}\n" + }, + "contracts/types/Types.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.17;\n\nimport { LibTUint256Slot } from \"./operations/LibTUint256Slot.sol\";\n\ntype TUint256Slot is bytes32;\n\nusing {\n LibTUint256Slot.add,\n LibTUint256Slot.sub,\n LibTUint256Slot.mul,\n LibTUint256Slot.div,\n LibTUint256Slot.load,\n LibTUint256Slot.store,\n LibTUint256Slot.addAssign,\n LibTUint256Slot.subAssign,\n LibTUint256Slot.preDecrement,\n LibTUint256Slot.postDecrement,\n LibTUint256Slot.preIncrement,\n LibTUint256Slot.postIncrement\n} for TUint256Slot global;\n" + }, + "contracts/utils/CommonErrors.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { ContractType } from \"./ContractType.sol\";\nimport { RoleAccess } from \"./RoleAccess.sol\";\n\nerror ErrSyncTooFarPeriod(uint256 period, uint256 latestRewardedPeriod);\n/**\n * @dev Error thrown when an address is expected to be an already created externally owned account (EOA).\n * This error indicates that the provided address is invalid for certain contract operations that require already created EOA.\n */\nerror ErrAddressIsNotCreatedEOA(address addr, bytes32 codehash);\n/**\n * @dev Error raised when a bridge operator update operation fails.\n * @param bridgeOperator The address of the bridge operator that failed to update.\n */\nerror ErrBridgeOperatorUpdateFailed(address bridgeOperator);\n/**\n * @dev Error thrown when attempting to add a bridge operator that already exists in the contract.\n * This error indicates that the provided bridge operator address is already registered as a bridge operator in the contract.\n */\nerror ErrBridgeOperatorAlreadyExisted(address bridgeOperator);\n/**\n * @dev The error indicating an unsupported interface.\n * @param interfaceId The bytes4 interface identifier that is not supported.\n * @param addr The address where the unsupported interface was encountered.\n */\nerror ErrUnsupportedInterface(bytes4 interfaceId, address addr);\n/**\n * @dev Error thrown when the return data from a callback function is invalid.\n * @param callbackFnSig The signature of the callback function that returned invalid data.\n * @param register The address of the register where the callback function was invoked.\n * @param returnData The invalid return data received from the callback function.\n */\nerror ErrInvalidReturnData(bytes4 callbackFnSig, address register, bytes returnData);\n/**\n * @dev Error of set to non-contract.\n */\nerror ErrZeroCodeContract(address addr);\n/**\n * @dev Error indicating that arguments are invalid.\n */\nerror ErrInvalidArguments(bytes4 msgSig);\n/**\n * @dev Error indicating that given address is null when it should not.\n */\nerror ErrZeroAddress(bytes4 msgSig);\n/**\n * @dev Error indicating that the provided threshold is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that the invalid threshold applies to.\n */\nerror ErrInvalidThreshold(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a function can only be called by the contract itself.\n * @param msgSig The function signature (bytes4) that can only be called by the contract itself.\n */\nerror ErrOnlySelfCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n * @param expectedRole The role required to perform the function.\n */\nerror ErrUnauthorized(bytes4 msgSig, RoleAccess expectedRole);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4) that the caller is unauthorized to perform.\n */\nerror ErrUnauthorizedCall(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the caller is unauthorized to perform a specific function.\n * @param msgSig The function signature (bytes4).\n * @param expectedContractType The contract type required to perform the function.\n * @param actual The actual address that called to the function.\n */\nerror ErrUnexpectedInternalCall(bytes4 msgSig, ContractType expectedContractType, address actual);\n\n/**\n * @dev Error indicating that an array is empty when it should contain elements.\n */\nerror ErrEmptyArray();\n\n/**\n * @dev Error indicating a mismatch in the length of input parameters or arrays for a specific function.\n * @param msgSig The function signature (bytes4) that has a length mismatch.\n */\nerror ErrLengthMismatch(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a proxy call to an external contract has failed.\n * @param msgSig The function signature (bytes4) of the proxy call that failed.\n * @param extCallSig The function signature (bytes4) of the external contract call that failed.\n */\nerror ErrProxyCallFailed(bytes4 msgSig, bytes4 extCallSig);\n\n/**\n * @dev Error indicating that a function tried to call a precompiled contract that is not allowed.\n * @param msgSig The function signature (bytes4) that attempted to call a precompiled contract.\n */\nerror ErrCallPrecompiled(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a native token transfer has failed.\n * @param msgSig The function signature (bytes4) of the token transfer that failed.\n */\nerror ErrNativeTransferFailed(bytes4 msgSig);\n\n/**\n * @dev Error indicating that an order is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid order.\n */\nerror ErrInvalidOrder(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the chain ID is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid chain ID.\n * @param actual Current chain ID that executing function.\n * @param expected Expected chain ID required for the tx to success.\n */\nerror ErrInvalidChainId(bytes4 msgSig, uint256 actual, uint256 expected);\n\n/**\n * @dev Error indicating that a vote type is not supported.\n * @param msgSig The function signature (bytes4) of the operation that encountered an unsupported vote type.\n */\nerror ErrUnsupportedVoteType(bytes4 msgSig);\n\n/**\n * @dev Error indicating that the proposal nonce is invalid.\n * @param msgSig The function signature (bytes4) of the operation that encountered an invalid proposal nonce.\n */\nerror ErrInvalidProposalNonce(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a voter has already voted.\n * @param voter The address of the voter who has already voted.\n */\nerror ErrAlreadyVoted(address voter);\n\n/**\n * @dev Error indicating that a signature is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid signature.\n */\nerror ErrInvalidSignatures(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a relay call has failed.\n * @param msgSig The function signature (bytes4) of the relay call that failed.\n */\nerror ErrRelayFailed(bytes4 msgSig);\n/**\n * @dev Error indicating that a vote weight is invalid for a specific function signature.\n * @param msgSig The function signature (bytes4) that encountered an invalid vote weight.\n */\nerror ErrInvalidVoteWeight(bytes4 msgSig);\n\n/**\n * @dev Error indicating that a query was made for an outdated bridge operator set.\n */\nerror ErrQueryForOutdatedBridgeOperatorSet();\n\n/**\n * @dev Error indicating that a request is invalid.\n */\nerror ErrInvalidRequest();\n\n/**\n * @dev Error indicating that a token standard is invalid.\n */\nerror ErrInvalidTokenStandard();\n\n/**\n * @dev Error indicating that a token is not supported.\n */\nerror ErrUnsupportedToken();\n\n/**\n * @dev Error indicating that a receipt kind is invalid.\n */\nerror ErrInvalidReceiptKind();\n\n/**\n * @dev Error indicating that a receipt is invalid.\n */\nerror ErrInvalidReceipt();\n\n/**\n * @dev Error indicating that an address is not payable.\n */\nerror ErrNonpayableAddress(address);\n\n/**\n * @dev Error indicating that the period is already processed, i.e. scattered reward.\n */\nerror ErrPeriodAlreadyProcessed(uint256 requestingPeriod, uint256 latestPeriod);\n\n/**\n * @dev Error thrown when an invalid vote hash is provided.\n */\nerror ErrInvalidVoteHash();\n\n/**\n * @dev Error thrown when querying for an empty vote.\n */\nerror ErrQueryForEmptyVote();\n\n/**\n * @dev Error thrown when querying for an expired vote.\n */\nerror ErrQueryForExpiredVote();\n\n/**\n * @dev Error thrown when querying for a non-existent vote.\n */\nerror ErrQueryForNonExistentVote();\n\n/**\n * @dev Error indicating that the method is only called once per block.\n */\nerror ErrOncePerBlock();\n\n/**\n * @dev Error of method caller must be coinbase\n */\nerror ErrCallerMustBeCoinbase();\n" + }, + "contracts/utils/ContractType.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum ContractType {\n /* 0 */ UNKNOWN,\n /* 1 */ PAUSE_ENFORCER,\n /* 2 */ BRIDGE,\n /* 3 */ BRIDGE_TRACKING,\n /* 4 */ GOVERNANCE_ADMIN,\n /* 5 */ MAINTENANCE,\n /* 6 */ SLASH_INDICATOR,\n /* 7 */ STAKING_VESTING,\n /* 8 */ VALIDATOR,\n /* 9 */ STAKING,\n /* 10 */ RONIN_TRUSTED_ORGANIZATION,\n /* 11 */ BRIDGE_MANAGER,\n /* 12 */ BRIDGE_SLASH,\n /* 13 */ BRIDGE_REWARD,\n /* 14 */ FAST_FINALITY_TRACKING,\n /* 15 */ PROFILE\n}\n" + }, + "contracts/utils/DeprecatedSlots.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\n/**\n * @title Deprecated Contracts\n * @dev These abstract contracts are deprecated and should not be used in new implementations.\n * They provide functionality related to various aspects of a smart contract but have been marked\n * as deprecated to indicate that they are no longer actively maintained or recommended for use.\n * The purpose of these contracts is to preserve the slots for already deployed contracts.\n */\ncontract HasSlashIndicatorDeprecated {\n /// @custom:deprecated Previously `_slashIndicatorContract` (non-zero value)\n address internal ______deprecatedSlashIndicator;\n}\n\ncontract HasStakingVestingDeprecated {\n /// @custom:deprecated Previously `_stakingVestingContract` (non-zero value)\n address internal ______deprecatedStakingVesting;\n}\n\ncontract HasBridgeDeprecated {\n /// @custom:deprecated Previously `_bridgeContract` (non-zero value)\n address internal ______deprecatedBridge;\n}\n\ncontract HasValidatorDeprecated {\n /// @custom:deprecated Previously `_validatorContract` (non-zero value)\n address internal ______deprecatedValidator;\n}\n\ncontract HasStakingDeprecated {\n /// @custom:deprecated Previously `_stakingContract` (non-zero value)\n address internal ______deprecatedStakingContract;\n}\n\ncontract HasMaintenanceDeprecated {\n /// @custom:deprecated Previously `_maintenanceContract` (non-zero value)\n address internal ______deprecatedMaintenance;\n}\n\ncontract HasTrustedOrgDeprecated {\n /// @custom:deprecated Previously `_trustedOrgContract` (non-zero value)\n address internal ______deprecatedTrustedOrg;\n}\n\ncontract HasGovernanceAdminDeprecated {\n /// @custom:deprecated Previously `_governanceAdminContract` (non-zero value)\n address internal ______deprecatedGovernanceAdmin;\n}\n\ncontract HasBridgeTrackingDeprecated {\n /// @custom:deprecated Previously `_bridgeTrackingContract` (non-zero value)\n address internal ______deprecatedBridgeTracking;\n}\n" + }, + "contracts/utils/IdentityGuard.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nimport { AddressArrayUtils } from \"../libraries/AddressArrayUtils.sol\";\nimport { IERC165 } from \"@openzeppelin/contracts/utils/introspection/IERC165.sol\";\nimport { TransparentUpgradeableProxyV2 } from \"../extensions/TransparentUpgradeableProxyV2.sol\";\nimport { ErrAddressIsNotCreatedEOA, ErrZeroAddress, ErrOnlySelfCall, ErrZeroCodeContract, ErrUnsupportedInterface } from \"./CommonErrors.sol\";\n\nabstract contract IdentityGuard {\n using AddressArrayUtils for address[];\n\n /// @dev value is equal to keccak256(abi.encode())\n /// @dev see: https://eips.ethereum.org/EIPS/eip-1052\n bytes32 internal constant CREATED_ACCOUNT_HASH = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;\n\n /**\n * @dev Modifier to restrict functions to only be called by this contract.\n * @dev Reverts if the caller is not this contract.\n */\n modifier onlySelfCall() virtual {\n _requireSelfCall();\n _;\n }\n\n /**\n * @dev Modifier to ensure that the elements in the `arr` array are non-duplicates.\n * It calls the internal `_checkDuplicate` function to perform the duplicate check.\n *\n * Requirements:\n * - The elements in the `arr` array must not contain any duplicates.\n */\n modifier nonDuplicate(address[] memory arr) virtual {\n _requireNonDuplicate(arr);\n _;\n }\n\n /**\n * @dev Internal method to check the method caller.\n * @dev Reverts if the method caller is not this contract.\n */\n function _requireSelfCall() internal view virtual {\n if (msg.sender != address(this)) revert ErrOnlySelfCall(msg.sig);\n }\n\n /**\n * @dev Internal function to check if a contract address has code.\n * @param addr The address of the contract to check.\n * @dev Throws an error if the contract address has no code.\n */\n function _requireHasCode(address addr) internal view {\n if (addr.code.length == 0) revert ErrZeroCodeContract(addr);\n }\n\n /**\n * @dev Checks if an address is zero and reverts if it is.\n * @param addr The address to check.\n */\n function _requireNonZeroAddress(address addr) internal pure {\n if (addr == address(0)) revert ErrZeroAddress(msg.sig);\n }\n\n /**\n * @dev Check if arr is empty and revert if it is.\n * Checks if an array contains any duplicate addresses and reverts if duplicates are found.\n * @param arr The array of addresses to check.\n */\n function _requireNonDuplicate(address[] memory arr) internal pure {\n if (arr.hasDuplicate()) revert AddressArrayUtils.ErrDuplicated(msg.sig);\n }\n\n /**\n * @dev Internal function to require that the provided address is a created externally owned account (EOA).\n * This internal function is used to ensure that the provided address is a valid externally owned account (EOA).\n * It checks the codehash of the address against a predefined constant to confirm that the address is a created EOA.\n * @notice This method only works with non-state EOA accounts\n */\n function _requireCreatedEOA(address addr) internal view {\n _requireNonZeroAddress(addr);\n bytes32 codehash = addr.codehash;\n if (codehash != CREATED_ACCOUNT_HASH) revert ErrAddressIsNotCreatedEOA(addr, codehash);\n }\n\n /**\n * @dev Internal function to require that the specified contract supports the given interface. This method handle in\n * both case that the callee is either or not the proxy admin of the caller. If the contract does not support the\n * interface `interfaceId` or EIP165, a revert with the corresponding error message is triggered.\n *\n * @param contractAddr The address of the contract to check for interface support.\n * @param interfaceId The interface ID to check for support.\n */\n function _requireSupportsInterface(address contractAddr, bytes4 interfaceId) internal view {\n bytes memory supportsInterfaceParams = abi.encodeCall(IERC165.supportsInterface, (interfaceId));\n (bool success, bytes memory returnOrRevertData) = contractAddr.staticcall(supportsInterfaceParams);\n if (!success) {\n (success, returnOrRevertData) = contractAddr.staticcall(\n abi.encodeCall(TransparentUpgradeableProxyV2.functionDelegateCall, (supportsInterfaceParams))\n );\n if (!success) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n if (!abi.decode(returnOrRevertData, (bool))) revert ErrUnsupportedInterface(interfaceId, contractAddr);\n }\n}\n" + }, + "contracts/utils/RoleAccess.sol": { + "content": "// SPDX-License-Identifier: MIT\npragma solidity ^0.8.0;\n\nenum RoleAccess {\n /* 0 */ UNKNOWN,\n /* 1 */ ADMIN,\n /* 2 */ COINBASE,\n /* 3 */ GOVERNOR,\n /* 4 */ CANDIDATE_ADMIN,\n /* 5 */ WITHDRAWAL_MIGRATOR,\n /* 6 */ __DEPRECATED_BRIDGE_OPERATOR,\n /* 7 */ BLOCK_PRODUCER,\n /* 8 */ VALIDATOR_CANDIDATE,\n /* 9 */ CONSENSUS,\n /* 10 */ TREASURY\n}\n" + } + }, + "settings": { + "optimizer": { + "enabled": true, + "runs": 200 + }, + "outputSelection": { + "*": { + "*": [ + "abi", + "evm.bytecode", + "evm.deployedBytecode", + "evm.methodIdentifiers", + "metadata", + "devdoc", + "userdoc", + "storageLayout", + "evm.gasEstimates", + "storageLayout" + ], + "": [ + "ast" + ] + } + }, + "metadata": { + "useLiteralContent": true + } + } +} \ No newline at end of file diff --git a/docs/CHEATSHEET.md b/docs/CHEATSHEET.md index 86dacab3c..1fc377d11 100644 --- a/docs/CHEATSHEET.md +++ b/docs/CHEATSHEET.md @@ -7,10 +7,10 @@ 1. Setup & Deploy -- [ ] [`initialize`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/5ef887dba49571c32b7e59e56d8ddde29d1a09c4/contracts/ronin/RoninGatewayV2.sol#L68-L80): this sets initializing data, without validator contract +- [ ] [`initialize`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/5ef887dba49571c32b7e59e56d8ddde29d1a09c4/contracts/ronin/RoninGatewayV3.sol#L68-L80): this sets initializing data, without validator contract - [ ] Deploy proxy: Should deploy with private-key based account as admin, for easily setting up the next step -- [ ] [`setValidatorContract`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/5ef887dba49571c32b7e59e56d8ddde29d1a09c4/contracts/ronin/RoninGatewayV2.sol#L103) -- [ ] [`setBridgeTrackingContract`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/95d7e94dea2d33e1835c51aa104114c18ff8df4c/contracts/ronin/RoninGatewayV2.sol#L118) +- [ ] [`setValidatorContract`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/5ef887dba49571c32b7e59e56d8ddde29d1a09c4/contracts/ronin/RoninGatewayV3.sol#L103) +- [ ] [`setBridgeTrackingContract`](https://github.com/axieinfinity/ronin-dpos-contracts/blob/95d7e94dea2d33e1835c51aa104114c18ff8df4c/contracts/ronin/RoninGatewayV3.sol#L118) - [ ] Transfer admin to GA (optional) 2. Grant role of minter or top-up initial value for gateway \ No newline at end of file diff --git a/docs/README.md b/docs/README.md index aa4751950..8c596180f 100644 --- a/docs/README.md +++ b/docs/README.md @@ -153,7 +153,7 @@ When a deposit event happens on mainchain, the Bridge component in each validato ### Deposits -Users can deposit ETH, ERC20, and ERC721 (NFTs) by sending transactions to `MainchainGatewayV2` and waiting for the deposit to be verified on Ronin. The validator will listen to the event on mainchain and then acknowledge the deposit on Ronin. The gateway should have a mapping between token contracts on Ethereum and on Ronin before the deposit can take place. +Users can deposit ETH, ERC20, and ERC721 (NFTs) by sending transactions to `MainchainGatewayV3` and waiting for the deposit to be verified on Ronin. The validator will listen to the event on mainchain and then acknowledge the deposit on Ronin. The gateway should have a mapping between token contracts on Ethereum and on Ronin before the deposit can take place. For deposit there is no restriction on how large a deposit can be. ![image](./assets/Deposit.png) diff --git a/foundry.toml b/foundry.toml index bbc17c373..877b15662 100644 --- a/foundry.toml +++ b/foundry.toml @@ -9,16 +9,15 @@ libs = [ 'lib', 'node_modules/@openzeppelin', 'node_modules/hardhat', - 'contracts/extensions', - 'contracts/interfaces', - 'contracts/utils' ] # See more config options https://github.com/foundry-rs/foundry/tree/master/config solc = '0.8.21' +extra_output = ["devdoc", "userdoc", "storagelayout"] evm_version = 'istanbul' cache_path = 'cache_foundry' +fs_permissions = [{ access = "read-write", path = "./" }] [fmt] line_length = 120 @@ -43,4 +42,11 @@ solc_version = "0.8.4" runs = 1_000 [profile.min-solc-via-ir.fuzz] -runs = 1_000 \ No newline at end of file +runs = 1_000 + +[rpc_endpoints] +ethereum = "https://eth.llamarpc.com" +goerli = "https://ethereum-goerli.publicnode.com" +ronin-mainnet = "https://api-partner.roninchain.com/rpc" +ronin-testnet = "https://saigon-archive.roninchain.com/rpc" +localhost = "http://localhost:8545" \ No newline at end of file diff --git a/hardhat.config.ts b/hardhat.config.ts index b9b971d8c..1c4719f1a 100644 --- a/hardhat.config.ts +++ b/hardhat.config.ts @@ -125,19 +125,32 @@ const config: HardhatUserConfig = { }, }, }, + 'contracts/ronin/gateway/RoninBridgeManager.sol': { + version: '0.8.17', + settings: { + optimizer: { + enabled: true, + runs: 10, + }, + metadata: { + useLiteralContent: true, + }, + }, + }, }, }, typechain: { outDir: 'src/types', }, paths: { - deploy: ['src/deploy', 'src/upgrades'], + deploy: ['src/deploy', 'src/upgrades', 'src/dashboard'], tests: 'test/hardhat_test', }, namedAccounts: { deployer: 0, governor: 0, // governor: '0x00000000000000000000000000000000deadbeef', + // governor: 'privatekey://0x00000000000000000000000000000000deadbeef000000000000000000sample', // governor: 'trezor://0x0000000000000000000000000000000000000000', }, networks: { diff --git a/lib/forge-std b/lib/forge-std index e8a047e3f..4d9985c9f 160000 --- a/lib/forge-std +++ b/lib/forge-std @@ -1 +1 @@ -Subproject commit e8a047e3f40f13fa37af6fe14e6e06283d9a060e +Subproject commit 4d9985c9fb046e5c8572bb173662109aae09d7de diff --git a/lib/prb-test b/lib/prb-test index 8d76ad63d..bda8b6b18 160000 --- a/lib/prb-test +++ b/lib/prb-test @@ -1 +1 @@ -Subproject commit 8d76ad63d1bfa0b16bb880cfe4620a9e7e6aaa19 +Subproject commit bda8b6b18eb50c5cf6142dcce52ce483d5b5043a diff --git a/lib/solady b/lib/solady new file mode 160000 index 000000000..d6b02fd7d --- /dev/null +++ b/lib/solady @@ -0,0 +1 @@ +Subproject commit d6b02fd7dcbaebc6c32004c1fbe0c2c91dddfa82 diff --git a/logs/contract_code_sizes.log b/logs/contract_code_sizes.log index 13e10e88d..1606b70e9 100644 --- a/logs/contract_code_sizes.log +++ b/logs/contract_code_sizes.log @@ -11,11 +11,11 @@ ············································|···························|················· | BridgeOperatorsBallot · 0.162 · │ ············································|···························|················· - | BridgeReward · 5.687 · │ + | BridgeReward · 5.890 · │ ············································|···························|················· - | BridgeSlash · 5.252 · │ + | BridgeSlash · 5.503 · │ ············································|···························|················· - | BridgeTracking · 6.570 · │ + | BridgeTracking · 6.712 · │ ············································|···························|················· | ECDSA · 0.084 · │ ············································|···························|················· @@ -61,9 +61,9 @@ ············································|···························|················· | LibTUint256Slot · 0.084 · │ ············································|···························|················· - | MainchainBridgeManager · 18.885 · │ + | MainchainBridgeManager · 18.883 · │ ············································|···························|················· - | MainchainGatewayV2 · 17.804 · │ + | MainchainGatewayV3 · 17.804 · │ ············································|···························|················· | Maintenance · 5.359 · │ ············································|···························|················· @@ -75,11 +75,11 @@ ············································|···························|················· | MockBridgeManager · 10.542 · │ ············································|···························|················· - | MockBridgeReward · 6.408 · │ + | MockBridgeReward · 6.611 · │ ············································|···························|················· - | MockBridgeSlash · 5.405 · │ + | MockBridgeSlash · 5.656 · │ ············································|···························|················· - | MockConditionalImplementControl · 1.377 · │ + | MockConditionalImplementControl · 3.278 · │ ············································|···························|················· | MockForwarderTarget · 1.312 · │ ············································|···························|················· @@ -107,9 +107,9 @@ ············································|···························|················· | MockPrecompile · 4.054 · │ ············································|···························|················· - | MockRoninBridgeManager · 24.006 · │ + | MockRoninBridgeManager · 24.007 · │ ············································|···························|················· - | MockRoninGatewayV2Extended · 20.478 · │ + | MockRoninGatewayV3Extended · 19.568 · │ ············································|···························|················· | MockRoninValidatorSetExtended · 23.961 · │ ············································|···························|················· @@ -129,19 +129,19 @@ ············································|···························|················· | MockValidatorSet · 7.823 · │ ············································|···························|················· - | NotifiedMigrator · 1.162 · │ + | NotifiedMigrator · 3.056 · │ ············································|···························|················· | PauseEnforcer · 4.441 · │ ············································|···························|················· - | Profile · 5.446 · │ + | Profile · 5.095 · │ ············································|···························|················· | Proposal · 0.162 · │ ············································|···························|················· | ProxyAdmin · 1.644 · │ ············································|···························|················· - | RoninBridgeManager · 24.006 · │ + | RoninBridgeManager · 23.714 · │ ············································|···························|················· - | RoninGatewayV2 · 20.170 · │ + | RoninGatewayV3 · 19.292 · │ ············································|···························|················· | RoninGovernanceAdmin · 14.471 · │ ············································|···························|················· @@ -149,7 +149,7 @@ ············································|···························|················· | RoninValidatorSet · 19.215 · │ ············································|···························|················· - | RoninValidatorSetTimedMigrator · 2.503 · │ + | RoninValidatorSetTimedMigrator · 3.742 · │ ············································|···························|················· | SlashIndicator · 12.991 · │ ············································|···························|················· diff --git a/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON.log b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON.log new file mode 100644 index 000000000..3a4ad8139 --- /dev/null +++ b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON.log @@ -0,0 +1,1003 @@ +- skipping the remapping +Compiling 1 files with 0.8.21 +Solc 0.8.21 finished in 7.43s +Compiler run successful! +Traces: + [9223372036854775807] Simulation__20231003_UpgradeREP002AndREP003_RON::run()  + ├─ [0] GeneralConfig::getContractName(7) [staticcall] + │ └─ ← MockPrecompile + ├─ [0] GeneralConfig::getContractFileName(7) [staticcall] + │ └─ ← MockPrecompile.sol:MockPrecompile + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000000 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(MockPrecompile.sol:MockPrecompile) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001070608060405234801561001057600080fd5b50611050806100206000396000f3fe608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c6343000815003300000000000000000000000000000000 + ├─ [836070] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + │ └─ ← 4176 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] VM::label(MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile)  + │ └─ ← () + ├─ [0] GeneralConfig::setAddress(3, 7, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1])  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile, MockPrecompile, 0x, 0)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, MockPrecompile) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::etch(0x0000000000000000000000000000000000000068, 0x608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c63430008150033)  + │ └─ ← () + ├─ [0] VM::makePersistent(0x0000000000000000000000000000000000000068)  + │ └─ ← () + ├─ [13522000] → new RoninValidatorSetTimedMigratorUpgrade@0x238213078DbD09f2D15F4c14c02300FA1b2A81BB + │ └─ ← 67610 bytes of code + ├─ [0] RoninValidatorSetTimedMigratorUpgrade::run()  + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::makePersistent(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] VM::allowCheatcodes(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getCurrentNetwork() [staticcall] + │ │ └─ ← 3 + │ ├─ [1674000] → new LogGenerator@0xF07F458B98049268F3c9f8726Fc5FbdB075fD403 + │ │ └─ ← 8370 bytes of code + │ ├─ [6700000] → new FastFinalityTrackingDeploy@0x348ba0a6303D9142b1Bd04F2b53aD5877E7C3bf7 + │ │ └─ ← 33500 bytes of code + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + │ ├─ [0] VM::load(ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + │ ├─ [0] VM::load(ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc) [staticcall] + │ │ └─ ← 0x000000000000000000000000ab2985fa821caae0524f6c5657ae40dabdf2eae0 + │ ├─ [0] GeneralConfig::getContractName(1) [staticcall] + │ │ └─ ← RoninValidatorSet + │ ├─ [0] GeneralConfig::getContractFileName(1) [staticcall] + │ │ └─ ← RoninValidatorSet.sol:RoninValidatorSet + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000001 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(RoninValidatorSet.sol:RoninValidatorSet) [staticcall] + │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000053f960806040523480156200001157600080fd5b506200001c62000022565b620000e4565b600054610100900460ff16156200008f5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff9081161015620000e2576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61530580620000f46000396000f3fe6080604052600436106103855760003560e01c806365244ece116101d1578063a3d545f511610102578063c94aaa02116100a0578063e5125a1d1161006f578063e5125a1d14610a00578063edb194bb14610a20578063eeb629a814610a82578063f883afaf14610a9757610394565b8063c94aaa021461098b578063d09f1ab4146109ab578063dd716ad3146109c0578063de981f1b146109e057610394565b8063afc69d73116100dc578063afc69d731461092c578063b7ab4db514610941578063ba77b06c14610956578063c3c8b5d61461096b57610394565b8063a3d545f5146108d7578063a66c0f77146108f7578063a7c2f1191461090c57610394565b8063823a7b9c1161016f57806387c891bd1161014957806387c891bd146108565780638d559c381461086b57806396585fc21461087f578063a0c3f2d21461089f57610394565b8063823a7b9c146107f6578063865e6fd314610816578063873a5a701461083657610394565b8063690b7536116101ab578063690b7536146107a45780636aa1c2ef146107b957806372e46810146107ce5780637593ff71146107d657610394565b806365244ece1461074d5780636558954f1461076d5780636611f8431461078457610394565b80633101cfcb116102b65780634de2b735116102545780635248184a116102235780635248184a146106ec5780635cd8a76b1461070e578063605239a114610723578063612c8d981461073857610394565b80634de2b735146106825780634ee4d72b146106af5780634f2a693f146106c457806352091f17146106e457610394565b80633b3159b6116102905780633b3159b6146105e1578063468c96ae1461060957806349096d26146106405780634d8df0631461066257610394565b80633101cfcb1461058157806331a8aef5146105a1578063367ec12b146105c157610394565b8063217f35c2116103235780632924de71116102fd5780632924de71146104ff578063297a8fca1461051f5780632d784a98146105345780632f78204c1461056157610394565b8063217f35c21461049d57806323c65eb0146104b257806328bde1e1146104d257610394565b80630f43a6771161035f5780630f43a6771461040a57806311662dc2146104205780631196ab661461045d57806315b5ebde1461047d57610394565b8063038278841461039c57806304d971ab146103c557806306040618146103f557610394565b3661039457610392610ab7565b005b610392610ab7565b3480156103a857600080fd5b506103b26104b081565b6040519081526020015b60405180910390f35b3480156103d157600080fd5b506103e56103e0366004614863565b610b36565b60405190151581526020016103bc565b34801561040157600080fd5b506103b2610b5d565b34801561041657600080fd5b506103b260aa5481565b34801561042c57600080fd5b5061044061043b36600461489c565b610b6d565b6040805193151584526020840192909252908201526060016103bc565b34801561046957600080fd5b506103926104783660046148c8565b610bf0565b34801561048957600080fd5b5061039261049836600461489c565b610c04565b3480156104a957600080fd5b506103e5610d23565b3480156104be57600080fd5b506103e56104cd36600461489c565b610d38565b3480156104de57600080fd5b506104f26104ed3660046148e1565b610d5c565b6040516103bc91906148fe565b34801561050b57600080fd5b506103e561051a3660046148e1565b610e3c565b34801561052b57600080fd5b506004546103b2565b34801561054057600080fd5b5061055461054f3660046148e1565b610e48565b6040516103bc919061495c565b34801561056d57600080fd5b5061039261057c366004614981565b610ec3565b34801561058d57600080fd5b5061039261059c3660046148e1565b6110e3565b3480156105ad57600080fd5b506103e56105bc36600461489c565b6111cc565b3480156105cd57600080fd5b506103926105dc3660046149dc565b6111f8565b3480156105ed57600080fd5b5060685b6040516001600160a01b0390911681526020016103bc565b34801561061557600080fd5b506106296106243660046148c8565b611384565b6040805192151583526020830191909152016103bc565b34801561064c57600080fd5b506106556113c2565b6040516103bc9190614ae6565b34801561066e57600080fd5b5061039261067d3660046148c8565b6114a2565b34801561068e57600080fd5b506106a261069d366004614af9565b6114b3565b6040516103bc9190614b6e565b3480156106bb57600080fd5b5060e4546103b2565b3480156106d057600080fd5b506103926106df3660046148c8565b611565565b610392611576565b3480156106f857600080fd5b5061070161199c565b6040516103bc9190614bb4565b34801561071a57600080fd5b50610392611af0565b34801561072f57600080fd5b506072546103b2565b34801561074457600080fd5b506076546103b2565b34801561075957600080fd5b506103e56107683660046148e1565b611c9a565b34801561077957600080fd5b506103b26201518081565b34801561079057600080fd5b5061039261079f3660046148c8565b611cd4565b3480156107b057600080fd5b5060e5546103b2565b3480156107c557600080fd5b506001546103b2565b610392611ce5565b3480156107e257600080fd5b506103e56107f13660046148c8565b611f97565b34801561080257600080fd5b506103926108113660046148c8565b611fbb565b34801561082257600080fd5b50610392610831366004614c55565b611fcc565b34801561084257600080fd5b506103e56108513660046148e1565b611feb565b34801561086257600080fd5b506002546103b2565b34801561087757600080fd5b5060666105f1565b34801561088b57600080fd5b5061044061089a3660046148e1565b612025565b3480156108ab57600080fd5b506103e56108ba3660046148e1565b6001600160a01b0316600090815260746020526040902054151590565b3480156108e357600080fd5b506103b26108f23660046148c8565b612041565b34801561090357600080fd5b5060e6546103b2565b34801561091857600080fd5b5061039261092736600461489c565b61204c565b34801561093857600080fd5b506103b26122ed565b34801561094d57600080fd5b50610655612330565b34801561096257600080fd5b506106556123d7565b34801561097757600080fd5b50610392610986366004614863565b612439565b34801561099757600080fd5b506103926109a63660046148c8565b612690565b3480156109b757600080fd5b5060a9546103b2565b3480156109cc57600080fd5b506103926109db36600461489c565b6126a1565b3480156109ec57600080fd5b506105f16109fb366004614c71565b612759565b348015610a0c57600080fd5b50610392610a1b366004614c8c565b6127e8565b348015610a2c57600080fd5b50610554610a3b3660046148e1565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b348015610a8e57600080fd5b5060ad546103b2565b348015610aa357600080fd5b50610392610ab2366004614cc1565b61292c565b610ac16007612759565b6001600160a01b0316336001600160a01b031614158015610afd5750610ae76009612759565b6001600160a01b0316336001600160a01b031614155b15610b34576040517fffcb451300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610b6860035490565b905090565b6001600160a01b0382166000908152603a60205260408120548190819084811015610ba357600080600093509350935050610be9565b60019350610bb18582614d28565b610bbc906001614d3b565b9250610bc785612041565b610bd082612041565b610bda9190614d28565b610be5906001614d3b565b9150505b9250925092565b610bf8612bb2565b610c0181612c26565b50565b6006610c0f81612c96565b6001600160a01b0383166000908152603c60205260409020544311610c70576040517f53e0424d0000000000000000000000000000000000000000000000000000000081526001600160a01b03841660048201526024015b60405180910390fd5b6001600160a01b038316600081815260386020908152604080832086845282528083208054600160ff199182168117909255948452603783528184208785529092529091208054909216909155610cc79043614d28565b6001600160a01b0384166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e90610d169085815260200190565b60405180910390a2505050565b6000610b68610d3142612cfb565b6003541090565b6001600160a01b0382166000908152603a60205260408120548211155b9392505050565b6040805160e08101825260008082526020808301829052828401829052606083018290526080830182905260a0830182905260c083018290526001600160a01b0385168252607490529190912054610dc75760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610b578243610d38565b604080518082018252600080825260209182018190526001600160a01b038416815260e882528281208351808501909452805484526001015491830182905203610ebe576040517fe1fba9e200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b6006610ece81612c96565b6000610ed8610b5d565b6001600160a01b03871660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e090915291902054919250610f2691614d3b565b60e46000828254610f379190614d3b565b90915550506001600160a01b038616600090815260e06020908152604080832083905560e18252808320839055603a909152902054610f77908690612d0a565b6001600160a01b0387166000908152603a60205260409020558315611032576000610fa26009612759565b60405163138ac02f60e11b81526001600160a01b038981166004830152602482018890529190911690632715805e906044016020604051808303816000875af1158015610ff3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110179190614d4e565b90508060e4600082825461102b9190614d3b565b9091555050505b8215611076576001600160a01b0386166000908152603c602052604090205461105c908690612d0a565b6001600160a01b0387166000908152603c60205260409020555b6001600160a01b0386166000818152603a6020908152604080832054815190815291820188905260019082015260608101919091528291907f54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68a9060800160405180910390a3505050505050565b600054600390610100900460ff16158015611105575060005460ff8083169116105b6111685760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055611187600e83612d21565b6000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b6001600160a01b038216600090815260376020908152604080832084845290915281205460ff16610d55565b600054610100900460ff16158080156112185750600054600160ff909116105b806112325750303b158015611232575060005460ff166001145b6112955760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805460ff1916600117905580156112b8576000805461ff0019166101001790555b6112c360068e612d21565b6112ce60098d612d21565b6112d960078c612d21565b6112e460058b612d21565b6112ef600a8a612d21565b6112f887612dc5565b61130186612dfa565b61130a85612e2f565b61131384612c26565b61131d8235612ea0565b61132a6020830135612ed5565b60018390558015611375576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050505050565b60008061139043612041565b831115806113ab575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b606060aa5467ffffffffffffffff8111156113df576113df614d7d565b604051908082528060200260200182016040528015611408578160200160208202803683370190505b5090506000805b825181101561149c57600081815260ab6020526040902054611439906001600160a01b0316611c9a565b1561149457600081815260ab60205260409020546001600160a01b0316838361146181614d93565b94508151811061147357611473614d67565b60200260200101906001600160a01b031690816001600160a01b0316815250505b60010161140f565b50815290565b6114aa612bb2565b610c0181612ed5565b60608167ffffffffffffffff8111156114ce576114ce614d7d565b6040519080825280602002602001820160405280156114f7578160200160208202803683370190505b50905060005b8281101561155e5761153484848381811061151a5761151a614d67565b905060200201602081019061152f91906148e1565b612f0a565b82828151811061154657611546614d67565b911515602092830291909101909101526001016114fd565b5092915050565b61156d612bb2565b610c0181612dfa565b61157e612f2b565b600061158933611c9a565b801561159b575061159933612f0a565b155b80156115db57506115d9336115ae610b5d565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b155b90506000806115ea6007612759565b6040517f0634f5b90000000000000000000000000000000000000000000000000000000081528415156004820152600060248201526001600160a01b039190911690630634f5b9906044016080604051808303816000875af1158015611654573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116789190614dac565b935050925050826116cf573460e460008282546116959190614d3b565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90610d16903490600190614e01565b604080513481526020810184905233917f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b1910160405180910390a26000611714610b5d565b905060006117228434614d3b565b905060006127106117338584614e25565b61173d9190614e52565b9050600061174b8284614d28565b905060008260e260008282546117619190614d3b565b909155505033600090815260386020908152604080832088845290915290205460ff161561186c5760006117956006612759565b6001600160a01b031663c6391fa26040518163ffffffff1660e01b8152600401608060405180830381865afa1580156117d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117f69190614e66565b9350505050612710818461180a9190614e25565b6118149190614e52565b91508160e460008282546118289190614d3b565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90611862908590600290614e01565b60405180910390a2505b6118768183614d28565b91506000806118856009612759565b6001600160a01b0316634530d2026040518163ffffffff1660e01b81526004016040805180830381865afa1580156118c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118e59190614e9c565b33600090815260756020526040812060040154929450909250906119139061190d9084612f64565b84612d0a565b905060006127106119248784614e25565b61192e9190614e52565b33600090815260e06020526040812080549293508392909190611952908490614d3b565b90915550600090506119648288614d28565b33600090815260e16020526040812080549293508392909190611988908490614d3b565b909155505050505050505050505050505050565b60735460609067ffffffffffffffff8111156119ba576119ba614d7d565b604051908082528060200260200182016040528015611a2157816020015b6040805160e08101825260008082526020808301829052928201819052606082018190526080820181905260a0820181905260c082015282526000199092019101816119d85790505b50905060005b8151811015611aec576075600060738381548110611a4757611a47614d67565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c08201528251839083908110611ad957611ad9614d67565b6020908102919091010152600101611a27565b5090565b600054600290610100900460ff16158015611b12575060005460ff8083169116105b611b755760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055607154611ba1906009906001600160a01b0316612d21565b606f54611bb9906005906001600160a01b0316612d21565b607054611bd1906006906001600160a01b0316612d21565b606d54611be9906007906001600160a01b0316612d21565b60a854611c0190600a906001600160a01b0316612d21565b606e54611c19906003906001600160a01b0316612d21565b607180546001600160a01b0319908116909155606f8054821690556070805482169055606d805482169055606e80548216905560a8805490911690556000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6001600160a01b038116600090815260ac6020526040812054610b579060019060ff166003811115611cce57611cce614deb565b90612f73565b611cdc612bb2565b610c0181612ea0565b611ced612f2b565b611cf643611f97565b611d2c576040517f6c74eecf00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611d3543612041565b611d40600254612041565b10611d77576040517f2458f64100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b436002556000611d8642612cfb565b90506000611d95826003541090565b90506000611da1612330565b905060606000611db043612041565b90506000611dbf826001614d3b565b90506000611dcb610b5d565b9050611dd78386612fa6565b8515611f3157600080611dea8388613115565b91509150611dfa83888484613301565b611e02613424565b611e0a613578565b6000611e166006612759565b6040517f7680850c0000000000000000000000000000000000000000000000000000000081529091506001600160a01b03821690637680850c90611e60908b908890600401614ec0565b600060405180830381600087803b158015611e7a57600080fd5b505af1158015611e8e573d6000803e3d6000fd5b50505050611e9b8a6136d4565b8051919950975015611f1f576040517f07c2d2f60000000000000000000000000000000000000000000000000000000081526001600160a01b038216906307c2d2f690611eec908a90600401614ae6565b600060405180830381600087803b158015611f0657600080fd5b505af1158015611f1a573d6000803e3d6000fd5b505050505b611f2a436001614d3b565b6004555050505b611f3c878387613865565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce788604051611f71911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b600060018054611fa79190614d28565b600154611fb49084614ee2565b1492915050565b611fc3612bb2565b610c0181612dc5565b611fd4612bb2565b611fdd81613b01565b611fe78282612d21565b5050565b600080611ff6610b5d565b6001600160a01b038416600090815260376020908152604080832084845290915290205490915060ff16610d55565b60008060006120348443610b6d565b9250925092509193909250565b6000610b5782613b50565b600961205781612c96565b6001600160a01b038316600090815260e8602052604090206001810154156120ab576040517f2bd5598800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60006120b78442614d3b565b6001600160a01b03861660009081526075602052604090209091506120dc9082613b6b565b6001600160a01b0385166000818152603b602052604080822084905560e554905163138ac02f60e11b815260048101939093526024830152903390632715805e906044016020604051808303816000875af115801561213f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906121639190614d4e565b905080156122a257600060e6544261217b9190614d3b565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038b16179055838655850181905590506122027fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b6001600160a01b03888116600081815260756020526040908190206002015490517fa2fae5700000000000000000000000000000000000000000000000000000000081526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b15801561228857600080fd5b505af115801561229c573d6000803e3d6000fd5b50505050505b856001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c4826040516122dd91815260200190565b60405180910390a2505050505050565b6000805b60aa54811015611aec57600081815260ab602052604090205461231c906001600160a01b0316611c9a565b15612328576001909101905b6001016122f1565b606060aa5467ffffffffffffffff81111561234d5761234d614d7d565b604051908082528060200260200182016040528015612376578160200160208202803683370190505b50905060005b8151811015611aec57600081815260ab602052604090205482516001600160a01b039091169081908490849081106123b6576123b6614d67565b6001600160a01b03909216602092830291909101909101525060010161237c565b6060607380548060200260200160405190810160405280929190818152602001828054801561242f57602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311612411575b5050505050905090565b612441612bb2565b6001600160a01b038216600090815260e8602052604090206001015415611fe75760e7548060005b828110156124b857846001600160a01b031660e7828154811061248e5761248e614d67565b6000918252602090912001546001600160a01b0316036124b0578091506124b8565b600101612469565b508181036124c65750505050565b6001600160a01b038416600090815260e860205260409020548015612689576001600160a01b038516600090815260e8602052604081208181556001908101919091558311156125885760e761251d600185614d28565b8154811061252d5761252d614d67565b60009182526020909120015460e780546001600160a01b03909216918490811061255957612559614d67565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061259957612599614ef6565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff191660011790556125eb84826104b0613bf4565b1561264457836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e48360405161263591815260200190565b60405180910390a35050505050565b604080518281524760208201526001600160a01b0380871692908816917f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a19101612635565b5050505050565b612698612bb2565b610c0181612e2f565b60096126ac81612c96565b6126b583613c54565b156126ec576040517f030081e700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152607560205260409020600581015415612740576040517ffab9167300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127538161274e8542614d3b565b613b6b565b50505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561279057612790614deb565b60ff1681526020810191909152604001600020546001600160a01b0316905080610ebe57816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c679190614f20565b60096127f381612c96565b6001600160a01b03841660009081526077602052604090205415612843576040517f5e65b9ba00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61271082111561286657604051631b8454a360e21b815260040160405180910390fd5b6076548310156128a2576040517ffa0ae69300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b03841660009081526077602052604081209062015180856128ca8242614e52565b6128d49190614d3b565b6128de9190614e25565b8083556001830185905560408051828152602081018790529192506001600160a01b038816917f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f2191016122dd565b600961293781612c96565b6073546072548110612975576040517f8616841b00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260746020526040902054156129c5576040517f8ad9cdf900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108311156129e857604051631b8454a360e21b815260040160405180910390fd5b60005b607354811015612ae15760006075600060738481548110612a0e57612a0e614d67565b60009182526020808320909101546001600160a01b03908116845290830193909352604090910190208054909250811690891603612a83576040517ffc3d8c750000000000000000000000000000000000000000000000000000000081526001600160a01b0389166004820152602401610c67565b60028101546001600160a01b0390811690871603612ad8576040517f5a674fce0000000000000000000000000000000000000000000000000000000081526001600160a01b0387166004820152602401610c67565b506001016129eb565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b031990811687179091556075909352818420805484168d881690811782559181018054851687179055600281018054909416968b1696871790935560048301899055905191949093909290917f1ca451a9920472b99355a9cf74185bf017604a7849c113f020888ecec9db93669190a450505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610b34576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610c67929190614f2e565b6001811015612c61576040517f17b8970f00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a2526790602001611c8f565b612c9f81612759565b6001600160a01b0316336001600160a01b031614610c01576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c6793929190614f4f565b6000610b576201518083614e52565b600081831015612d1a5781610d55565b5090919050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115612d5757612d57614deb565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115612d9857612d98614deb565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b590602001611c8f565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab490602001611c8f565b60a954811115612e6b576040517faa8119d200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e90602001611c8f565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a90602001611c8f565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b90602001611c8f565b6001600160a01b0381166000908152603a6020526040812054431115610b57565b334114610b34576040517f09f358fd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000818310612d1a5781610d55565b6000816003811115612f8757612f87614deb565b836003811115612f9957612f99614deb565b1660ff1615159392505050565b6000612fb2600e612759565b6001600160a01b031663468d24be84846040518363ffffffff1660e01b8152600401612fdf929190614f84565b600060405180830381865afa158015612ffc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526130249190810190614ffa565b9050600082516001546130379190614e25565b60e25490915060009081805b86518110156130e6578486828151811061305f5761305f614d67565b6020026020010151846130729190614e25565b61307c9190614e52565b93508360e3600089848151811061309557613095614d67565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060008282546130cc9190614d3b565b909155506130dc90508483614d3b565b9150600101613043565b506130f18183614d28565b60e460008282546131029190614d3b565b9091555050600060e25550505050505050565b60006060600080845167ffffffffffffffff81111561313657613136614d7d565b60405190808252806020026020018201604052801561315f578160200160208202803683370190505b50925060005b85518110156132f75785818151811061318057613180614d67565b6020908102919091018101516001600160a01b03808216600090815260759093526040909220600201549094501691506131b983612f0a565b1580156131ea57506001600160a01b03831660009081526037602090815260408083208a845290915290205460ff16155b15613268576001600160a01b038316600090815260e160205260409020546132129086614d3b565b6001600160a01b038416600090815260e1602052604090205485519196509085908390811061324357613243614d67565b6020026020010181815250506132598383613ced565b6132638383613db5565b6132bf565b6001600160a01b038316600090815260e3602090815260408083205460e183528184205460e090935292205461329e9190614d3b565b6132a89190614d3b565b60e460008282546132b99190614d3b565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e3909152812055600101613165565b5050509250929050565b600061330d6009612759565b905082156126895761331f8184613e70565b156133e0576040517facd79c460000000000000000000000000000000000000000000000000000000081526001600160a01b0382169063acd79c469061336d90879086908a906004016150c0565b600060405180830381600087803b15801561338757600080fd5b505af115801561339b573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d0878385846040516133d2939291906150f6565b60405180910390a150612753565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f8983858447604051613415949392919061512b565b60405180910390a15050505050565b60e754600080805b838310156127535760e7838154811061344757613447614d67565b60009182526020808320909101546001600160a01b031680835260e8909152604090912060018101549193509150421061356d57805460e4805460009061348f908490614d3b565b90915550506001600160a01b038216600090815260e8602052604081208181556001018190556134be85615168565b94508411156135355760e784815481106134da576134da614d67565b60009182526020909120015460e780546001600160a01b03909216918590811061350657613506614d67565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061354657613546614ef6565b600082815260209020810160001990810180546001600160a01b031916905501905561342c565b60019092019161342c565b60e4548015610c0157600061358d6007612759565b600060e481905560408051600481526024810182526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f59f778df00000000000000000000000000000000000000000000000000000000179052905192935090916001600160a01b038416918591613608919061517f565b60006040518083038185875af1925050503d8060008114613645576040519150601f19603f3d011682016040523d82523d6000602084013e61364a565b606091505b50509050801561368f57816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051610d1691815260200190565b604080518481524760208201526001600160a01b038416917fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b739101610d16565b505050565b6060806136e083613ecc565b905060006136ee6009612759565b6001600160a01b03166391f8723f60736040518263ffffffff1660e01b815260040161371a91906151ae565b600060405180830381865afa158015613737573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261375f9190810190614ffa565b9050600061376d600a612759565b6001600160a01b031663520fce6260736040518263ffffffff1660e01b815260040161379991906151ae565b600060405180830381865afa1580156137b6573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526137de9190810190614ffa565b9050600061384d607380548060200260200160405190810160405280929190818152602001828054801561383b57602002820191906000526020600020905b81546001600160a01b0316815260019091019060200180831161381d575b5050505050848460a95460ad546143f4565b909550905061385d858288614505565b505050915091565b60006138716005612759565b6001600160a01b031663fdadda818361388b436001614d3b565b6040518363ffffffff1660e01b81526004016138a8929190614ec0565b600060405180830381865afa1580156138c5573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526138ed91908101906151f2565b905060005b8251811015613aba57600083828151811061390f5761390f614d67565b6020908102919091018101516001600160a01b0381166000908152603b90925260408220549092504211159061394483611c9a565b9050600061397784613957436001614d3b565b6001600160a01b03919091166000908152603a6020526040902054101590565b80613998575085858151811061398f5761398f614d67565b60200260200101515b806139a05750825b159050811580156139ae5750805b15613a29576001600160a01b038416600090815260ac60205260409020546139ed9060019060ff1660038111156139e7576139e7614deb565b90614645565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613a1f57613a1f614deb565b0217905550613aab565b818015613a34575080155b15613aab576001600160a01b038416600090815260ac6020526040902054613a739060019060ff166003811115613a6d57613a6d614deb565b90614680565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613aa557613aa5614deb565b02179055505b846001019450505050506138f2565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b82613ae66113c2565b604051613af39190614ae6565b60405180910390a350505050565b806001600160a01b03163b600003610c01576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c67565b600060015482613b609190614e52565b610b57906001614d3b565b60018201546001600160a01b0316600090815260746020526040902054613ba55760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e79060200160405180910390a25050565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613c44576040519150601f19603f3d011682016040523d82523d6000602084013e613c49565b606091505b509095945050505050565b600080613c61600a612759565b6040517f41feed1c0000000000000000000000000000000000000000000000000000000081526001600160a01b03858116600483015291909116906341feed1c90602401602060405180830381865afa158015613cc2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613ce69190614d4e565b1192915050565b6001600160a01b038216600090815260e0602052604090205480156136cf57613d1982826104b0613bf4565b15613d7057816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec83604051613d6391815260200190565b60405180910390a3505050565b604080518281524760208201526001600160a01b0380851692908616917f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e9101613d63565b6001600160a01b038216600090815260e3602052604090205480156136cf57613de182826104b0613bf4565b15613e2b57816001600160a01b0316836001600160a01b03167f0c4d6a43fc8470dee97db74874b5685e412cc517d9bdecfde1623c5e835b18e483604051613d6391815260200190565b604080518281524760208201526001600160a01b0380851692908616917f98697ee35f04a599a814432016fff3968c483d2d88dacb484926b9358f8e7cf99101613d63565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114613ebd576040519150601f19603f3d011682016040523d82523d6000602084013e613ec2565b606091505b5090949350505050565b60606000613eda6009612759565b90506000816001600160a01b031663af2454296040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f1c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f409190614d4e565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f82573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613fa69190614d4e565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b8152600401613fd791906151ae565b600060405180830381865afa158015613ff4573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261401c9190810190614ffa565b60735490915060008167ffffffffffffffff81111561403d5761403d614d7d565b604051908082528060200260200182016040528015614066578160200160208202803683370190505b50965060008060005b8483101561432c576073838154811061408a5761408a614d67565b60009182526020808320909101546001600160a01b0316808352607590915260409091206006810154885192945090925015159088908890869081106140d2576140d2614d67565b60200260200101511015614140578061413b5760006140f18a42614d3b565b600684018190556040518181529091506001600160a01b038516907f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342759060200160405180910390a2505b614193565b8015614193578160060160009055826001600160a01b03167f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a34275600060405161418a91815260200190565b60405180910390a25b600082600501546000141580156141ae575042836005015411155b806141d157506001600160a01b038416600090815260e9602052604090205460ff165b9050600083600601546000141580156141ee575042846006015411155b905081806141f95750805b1561428b578861420889615168565b9850888151811061421b5761421b614d67565b602002602001015189878151811061423557614235614d67565b602002602001018181525050848d888060010199508151811061425a5761425a614d67565b60200260200101906001600160a01b031690816001600160a01b031681525050614283856146bc565b50505061406f565b6001600160a01b03851660009081526077602052604090205480158015906142b35750428111155b1561431c576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b50506001909401935061406f9050565b50505080875280156143e9577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c91876040516143679190614ae6565b60405180910390a16040517fe22d1c9d0000000000000000000000000000000000000000000000000000000081526001600160a01b0387169063e22d1c9d906143b6908a908c90600401614ec0565b600060405180830381600087803b1580156143d057600080fd5b505af11580156143e4573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401614418959493929190615281565b60408051601f19818403018152919052602080820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f779415120000000000000000000000000000000000000000000000000000000017905281518b51929350600192909160009161448991614e25565b614494906040614d3b565b90506020840181888483895afa6144aa57600093505b503d6144b557600092505b602087019650826144f2576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa5481101561455957600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b0319169055600101614507565b5060005b8281101561459957600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff1916905560010161455d565b5060005b8281101561460d5760008482815181106145b9576145b9614d67565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b03191690911790555060010161459d565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051610d169190614ae6565b600081600381111561465957614659614deb565b83600381111561466b5761466b614deb565b1760ff166003811115610d5557610d55614deb565b600081600381111561469457614694614deb565b198360038111156146a7576146a7614deb565b1660ff166003811115610d5557610d55614deb565b6001600160a01b038116600090815260e960209081526040808320805460ff191690556074909152812054610c01918391908190036146f9575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b03199081168255600180830180548316905560028301805483169055600383018054909216909155600482018590556005820185905560069091018490556074835281842084905560779092528220828155810182905560738054909161478391614d28565b8154811061479357614793614d67565b6000918252602090912001546001600160a01b03908116915083168114614816576001600160a01b03811660009081526074602052604090208290556073805482919084199081106147e7576147e7614d67565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b607380548061482757614827614ef6565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6001600160a01b0381168114610c0157600080fd5b6000806040838503121561487657600080fd5b82356148818161484e565b915060208301356148918161484e565b809150509250929050565b600080604083850312156148af57600080fd5b82356148ba8161484e565b946020939093013593505050565b6000602082840312156148da57600080fd5b5035919050565b6000602082840312156148f357600080fd5b8135610d558161484e565b60e08101610b5782846001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b815181526020808301519082015260408101610b57565b8015158114610c0157600080fd5b6000806000806080858703121561499757600080fd5b84356149a28161484e565b9350602085013592506040850135915060608501356149c081614973565b939692955090935050565b8060408101831015610b5757600080fd5b6000806000806000806000806000806000806101a08d8f0312156149ff57600080fd5b8c35614a0a8161484e565b9b5060208d0135614a1a8161484e565b9a5060408d0135614a2a8161484e565b995060608d0135614a3a8161484e565b985060808d0135614a4a8161484e565b975060a08d0135614a5a8161484e565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d01359150614a908e6101608f016149cb565b90509295989b509295989b509295989b565b600081518084526020808501945080840160005b83811015614adb5781516001600160a01b031687529582019590820190600101614ab6565b509495945050505050565b602081526000610d556020830184614aa2565b60008060208385031215614b0c57600080fd5b823567ffffffffffffffff80821115614b2457600080fd5b818501915085601f830112614b3857600080fd5b813581811115614b4757600080fd5b8660208260051b8501011115614b5c57600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015614ba8578351151583529284019291840191600101614b8a565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b81811015614ba857614c338385516001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b9284019260e09290920191600101614bd0565b803560108110610ebe57600080fd5b60008060408385031215614c6857600080fd5b61488183614c46565b600060208284031215614c8357600080fd5b610d5582614c46565b600080600060608486031215614ca157600080fd5b8335614cac8161484e565b95602085013595506040909401359392505050565b60008060008060808587031215614cd757600080fd5b8435614ce28161484e565b93506020850135614cf28161484e565b92506040850135614d028161484e565b9396929550929360600135925050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610b5757610b57614d12565b80820180821115610b5757610b57614d12565b600060208284031215614d6057600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b600060018201614da557614da5614d12565b5060010190565b60008060008060808587031215614dc257600080fd5b8451614dcd81614973565b60208601516040870151606090970151919890975090945092505050565b634e487b7160e01b600052602160045260246000fd5b8281526040810160038310614e1857614e18614deb565b8260208301529392505050565b8082028115828204841417610b5757610b57614d12565b634e487b7160e01b600052601260045260246000fd5b600082614e6157614e61614e3c565b500490565b60008060008060808587031215614e7c57600080fd5b505082516020840151604085015160609095015191969095509092509050565b60008060408385031215614eaf57600080fd5b505080516020909101519092909150565b604081526000614ed36040830185614aa2565b90508260208301529392505050565b600082614ef157614ef1614e3c565b500690565b634e487b7160e01b600052603160045260246000fd5b60108110614f1c57614f1c614deb565b9052565b60208101610b578284614f0c565b6001600160e01b03198316815260408101600b8310614e1857614e18614deb565b6001600160e01b03198416815260608101614f6d6020830185614f0c565b6001600160a01b0383166040830152949350505050565b828152604060208201526000614f9d6040830184614aa2565b949350505050565b604051601f8201601f1916810167ffffffffffffffff81118282101715614fce57614fce614d7d565b604052919050565b600067ffffffffffffffff821115614ff057614ff0614d7d565b5060051b60200190565b6000602080838503121561500d57600080fd5b825167ffffffffffffffff81111561502457600080fd5b8301601f8101851361503557600080fd5b805161504861504382614fd6565b614fa5565b81815260059190911b8201830190838101908783111561506757600080fd5b928401925b828410156150855783518252928401929084019061506c565b979650505050505050565b600081518084526020808501945080840160005b83811015614adb578151875295820195908201906001016150a4565b6060815260006150d36060830186614aa2565b82810360208401526150e58186615090565b915050826040830152949350505050565b83815260606020820152600061510f6060830185614aa2565b82810360408401526151218185615090565b9695505050505050565b8481526080602082015260006151446080830186614aa2565b82810360408401526151568186615090565b91505082606083015295945050505050565b60008161517757615177614d12565b506000190190565b6000825160005b818110156151a05760208186018101518583015201615186565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b81811015614ba85783546001600160a01b0316835260019384019392850192016151cd565b6000602080838503121561520557600080fd5b825167ffffffffffffffff81111561521c57600080fd5b8301601f8101851361522d57600080fd5b805161523b61504382614fd6565b81815260059190911b8201830190838101908783111561525a57600080fd5b928401925b8284101561508557835161527281614973565b8252928401929084019061525f565b60a08152600061529460a0830188614aa2565b82810360208401526152a68188615090565b905082810360408401526152ba8187615090565b6060840195909552505060800152939250505056fea264697066735822122063da2fbf734436176a1f4c39e0da627b6b05b82c364d77203c7502cf3b58817264736f6c6343000815003300000000000000 + │ ├─ [4279096] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + │ │ ├─ emit Initialized(version: 255) + │ │ └─ ← 21253 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], RoninValidatorSet, RoninValidatorSetLogic, 0x, 1)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, RoninValidatorSetLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getContractName(12) [staticcall] + │ │ └─ ← RoninValidatorSetTimedMigrator + │ ├─ [0] GeneralConfig::getContractFileName(12) [staticcall] + │ │ └─ ← RoninValidatorSetTimedMigrator.sol:RoninValidatorSetTimedMigrator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000002 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(RoninValidatorSetTimedMigrator.sol:RoninValidatorSetTimedMigrator) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000122c60e06040523480156200001157600080fd5b506040516200122c3803806200122c83398101604081905262000034916200027a565b828282620000428162000177565b6200004d8262000177565b620000588362000177565b60408051600380825260808201909252600091602082016060803683370190505090508381600081518110620000925762000092620002c4565b60200260200101906001600160a01b031690816001600160a01b0316815250508281600181518110620000c957620000c9620002c4565b60200260200101906001600160a01b031690816001600160a01b0316815250508181600281518110620001005762000100620002c4565b6001600160a01b03909216602092830291909101909101526200012381620001b2565b156200015557604051630d697db160e11b81526001600160e01b03196000351660048201526024015b60405180910390fd5b506001600160a01b03928316608052821660a0521660c05250620002da915050565b806001600160a01b03163b600003620001af57604051630bfc64a360e21b81526001600160a01b03821660048201526024016200014c565b50565b60008151600003620001c657506000919050565b60005b60018351038110156200025457600181015b83518110156200024a57838181518110620001fa57620001fa620002c4565b60200260200101516001600160a01b0316848381518110620002205762000220620002c4565b60200260200101516001600160a01b03160362000241575060019392505050565b600101620001db565b50600101620001c9565b50600092915050565b80516001600160a01b03811681146200027557600080fd5b919050565b6000806000606084860312156200029057600080fd5b6200029b846200025d565b9250620002ab602085016200025d565b9150620002bb604085016200025d565b90509250925092565b634e487b7160e01b600052603260045260246000fd5b60805160a05160c051610f08620003246000396000818160a5015261023201526000818160f5015261032601526000818161019e015281816101cb0152610a830152610f086000f3fe6080604052600436106100745760003560e01c80638f61eea61161004e5780638f61eea614610137578063d39f567714610157578063de981f1b1461016c578063f89360c21461018c5761008b565b8063014fdae61461009357806330b53157146100e3578063865e6fd3146101175761008b565b3661008b576100816101c0565b61008961022b565b005b6100816101c0565b34801561009f57600080fd5b506100c77f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200160405180910390f35b3480156100ef57600080fd5b506100c77f000000000000000000000000000000000000000000000000000000000000000081565b34801561012357600080fd5b50610089610132366004610af7565b610260565b34801561014357600080fd5b50610089610152366004610b3a565b61027f565b34801561016357600080fd5b50610089610311565b34801561017857600080fd5b506100c7610187366004610baf565b6104bc565b34801561019857600080fd5b506100c77f000000000000000000000000000000000000000000000000000000000000000081565b306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610229576040517f145be2450000000000000000000000000000000000000000000000000000000081523060048201526024015b60405180910390fd5b565b60006102567f0000000000000000000000000000000000000000000000000000000000000000610550565b9050805160208201f35b6102686106fe565b61027181610772565b61027b82826107c4565b5050565b6102876106fe565b61028f6101c0565b7f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae026338160005b8181101561030a57828585838181106102cf576102cf610bca565b90506020028101906102e19190610be0565b825460018101845560009384526020909320909201916103019183610cc3565b506001016102b4565b5050505050565b6103196101c0565b610321610880565b61034a7f0000000000000000000000000000000000000000000000000000000000000000610888565b61035460096104bc565b6001600160a01b031663d39f56776040518163ffffffff1660e01b8152600401600060405180830381600087803b15801561038e57600080fd5b505af11580156103a2573d6000803e3d6000fd5b505050506103b060066104bc565b6001600160a01b031663d39f56776040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156103ea57600080fd5b505af11580156103fe573d6000803e3d6000fd5b5050505061040c600a6104bc565b6001600160a01b031663d39f56776040518163ffffffff1660e01b8152600401600060405180830381600087803b15801561044657600080fd5b505af115801561045a573d6000803e3d6000fd5b5050505061046860036104bc565b6001600160a01b031663d39f56776040518163ffffffff1660e01b8152600401600060405180830381600087803b1580156104a257600080fd5b505af11580156104b6573d6000803e3d6000fd5b50505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156104f3576104f3610d83565b60ff1681526020810191909152604001600020546001600160a01b031690508061054b57816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016102209190610d99565b919050565b60607f8d1b97f0000000000000000000000000000000000000000000000000000000006000356001600160e01b0319160161067a57600061058f6109cf565b9050600080846001600160a01b03166000366040516105af929190610db3565b600060405180830381855af49150503d80600081146105ea576040519150601f19603f3d011682016040523d82523d6000602084013e6105ef565b606091505b50909250905061060e8215156001600160e01b03196000351683610a38565b925061061a90506109cf565b811461067457306001600160a01b031663d39f56776040518163ffffffff1660e01b8152600401600060405180830381600087803b15801561065b57600080fd5b505af115801561066f573d6000803e3d6000fd5b505050505b50919050565b600080836001600160a01b0316600036604051610698929190610db3565b600060405180830381855af49150503d80600081146106d3576040519150601f19603f3d011682016040523d82523d6000602084013e6106d8565b606091505b5090925090506106f78215156001600160e01b03196000351683610a38565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610229576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610220929190610dc3565b806001600160a01b03163b6000036107c1576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610220565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156107fa576107fa610d83565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f81111561085357610853610d83565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610229610a78565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc8190556040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a27f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633805460006060815b838110156109c757856001600160a01b031685828154811061092d5761092d610bca565b906000526020600020016040516109449190610df1565b600060405180830381855af49150503d806000811461097f576040519150601f19603f3d011682016040523d82523d6000602084013e610984565b606091505b5080935081945050506109bf8582815481106109a2576109a2610bca565b906000526020600020016109b590610e67565b8415159084610a38565b600101610909565b505050505050565b6000306001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a0f573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a339190610eb9565b905090565b6001600160e01b031960003516836104b65781518015610a59578060208401fd5b50604051638e3eda2b81528160208201528360408201526044601c8201fd5b336001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610229576040517f7337e1900000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610220565b80356010811061054b57600080fd5b60008060408385031215610b0a57600080fd5b610b1383610ae8565b915060208301356001600160a01b0381168114610b2f57600080fd5b809150509250929050565b60008060208385031215610b4d57600080fd5b823567ffffffffffffffff80821115610b6557600080fd5b818501915085601f830112610b7957600080fd5b813581811115610b8857600080fd5b8660208260051b8501011115610b9d57600080fd5b60209290920196919550909350505050565b600060208284031215610bc157600080fd5b6106f782610ae8565b634e487b7160e01b600052603260045260246000fd5b6000808335601e19843603018112610bf757600080fd5b83018035915067ffffffffffffffff821115610c1257600080fd5b602001915036819003821315610c2757600080fd5b9250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680610c5857607f821691505b60208210810361067457634e487b7160e01b600052602260045260246000fd5b601f821115610cbe57600081815260208120601f850160051c81016020861015610c9f5750805b601f850160051c820191505b818110156109c757828155600101610cab565b505050565b67ffffffffffffffff831115610cdb57610cdb610c2e565b610cef83610ce98354610c44565b83610c78565b6000601f841160018114610d235760008515610d0b5750838201355b600019600387901b1c1916600186901b17835561030a565b600083815260209020601f19861690835b82811015610d545786850135825560209485019460019092019101610d34565b5086821015610d715760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610dad57610dad610d83565b91905290565b8183823760009101908152919050565b6001600160e01b03198316815260408101600b8310610de457610de4610d83565b8260208301529392505050565b6000808354610dff81610c44565b60018281168015610e175760018114610e2c57610e5b565b60ff1984168752821515830287019450610e5b565b8760005260208060002060005b85811015610e525781548a820152908401908201610e39565b50505082870194505b50929695505050505050565b6000610e738254610c44565b82601f821115610e895783600052602060002090505b546001600160e01b031980821693506004831015610eb15780818460040360031b1b83161693505b505050919050565b600060208284031215610ecb57600080fd5b505191905056fea2646970667358221220995e4395a23418008b82cf881d0aa621d0857634ed5ef594c4548bb756b3b38164736f6c634300081500330000000000000000000000000000000000000000 + │ ├─ [774644] → new RoninValidatorSetTimedMigrator@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + │ │ └─ ← 3848 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninValidatorSetTimedMigrator: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], RoninValidatorSetTimedMigrator, RoninValidatorSetTimedMigratorLogic, 0x, 2)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, RoninValidatorSetTimedMigratorLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getContractName(10) [staticcall] + │ │ └─ ← FastFinalityTracking + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(10) [staticcall] + │ │ └─ ← ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576] + │ ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ │ └─ ← () + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [119371] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSetTimedMigrator: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x8f61eea6000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000045cd8a76b0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da57600000000000000000000000000000000000000000000000000000000)  + │ │ ├─ emit Upgraded(implementation: RoninValidatorSetTimedMigrator: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + │ │ ├─ [107045] RoninValidatorSetTimedMigrator::setCallDatas([0x5cd8a76b, 0x3101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da576]) [delegatecall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ └─ ← 0x000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f + ├─ [6942400] → new NotifiedMigratorUpgrade@0xd85BdcdaE4db1FAEB8eF93331525FE68D7C8B3f0 + │ └─ ← 34712 bytes of code + ├─ [0] NotifiedMigratorUpgrade::run(5, [0x5cd8a76b])  + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::makePersistent(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] VM::allowCheatcodes(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getCurrentNetwork() [staticcall] + │ │ └─ ← 3 + │ ├─ [1674000] → new LogGenerator@0x5EfD028dd0751F9Ed1b3c8B058B02E47f3fbd80b + │ │ └─ ← 8370 bytes of code + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(5) [staticcall] + │ │ └─ ← ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758] + │ ├─ [0] VM::load(ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + │ ├─ [0] VM::load(ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758], 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc) [staticcall] + │ │ └─ ← 0x0000000000000000000000009b0e61e629eb44875cff534de0c176078cac502f + │ ├─ [0] GeneralConfig::getContractName(5) [staticcall] + │ │ └─ ← Staking + │ ├─ [0] GeneralConfig::getContractFileName(5) [staticcall] + │ │ └─ ← Staking.sol:Staking + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000003 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(Staking.sol:Staking) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000401360806040523480156200001157600080fd5b5060016000556200002162000027565b620000e9565b60d154610100900460ff1615620000945760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60d15460ff9081161015620000e75760d1805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b613f1a80620000f96000396000f3fe6080604052600436106102bf5760003560e01c80636bd8f8041161016e578063aa15a6fd116100cb578063d01b8eed1161007f578063e22d1c9d11610064578063e22d1c9d14610821578063f92ad21914610841578063f9f031df14610861576102d1565b8063d01b8eed14610790578063de981f1b14610801576102d1565b8063af245429116100b0578063af2454291461070a578063c2a672e01461071f578063c50870031461073f576102d1565b8063aa15a6fd146106d7578063acd79c46146106f7576102d1565b8063909791dd11610122578063924f081e11610107578063924f081e146106775780639488e4e914610697578063969ffc14146106b7576102d1565b8063909791dd1461064257806391f8723f14610657576102d1565b8063865e6fd311610153578063865e6fd3146105c9578063888b9ae9146105e9578063895ab74214610609576102d1565b80636bd8f8041461055f57806376664b651461057f576102d1565b806342e0c4081161021c5780635c19a95c116101d05780636558954f116101b55780636558954f14610508578063679a6e431461051f5780636b0916951461053f576102d1565b80635c19a95c146104e05780635cd8a76b146104f3576102d1565b80634530d202116102015780634530d202146104785780634d99dd16146104a057806357473447146104c0576102d1565b806342e0c4081461040d57806342ef3c3414610458576102d1565b80631658c86e116102735780632715805e116102585780632715805e146103ba5780632baae125146103da5780633d8e846e146103ed576102d1565b80631658c86e1461038757806326476204146103a7576102d1565b8063095f6475116102a4578063095f64751461031a578063097e4a9d146103475780630dccaf4614610367576102d1565b806303827884146102dc5780630682e8fa14610305576102d1565b366102d15760086102cf81610881565b005b60086102cf81610881565b3480156102e857600080fd5b506102f26104b081565b6040519081526020015b60405180910390f35b34801561031157600080fd5b506038546102f2565b34801561032657600080fd5b5061033a6103353660046136cb565b6108f2565b6040516102fc9190613772565b34801561035357600080fd5b506102f261036236600461379a565b610a2b565b34801561037357600080fd5b506102cf6103823660046137f1565b610ae1565b34801561039357600080fd5b506102cf6103a2366004613842565b610c1a565b6102cf6103b5366004613842565b610ca3565b3480156103c657600080fd5b506102f26103d5366004613866565b610cdc565b6102cf6103e83660046137f1565b610d6d565b3480156103f957600080fd5b5061033a610408366004613892565b610ef8565b34801561041957600080fd5b50610448610428366004613842565b6001600160a01b039081166000908152603a602052604090205416151590565b60405190151581526020016102fc565b34801561046457600080fd5b5061033a6104733660046138e7565b611051565b34801561048457600080fd5b50606e54606d54604080519283526020830191909152016102fc565b3480156104ac57600080fd5b506102cf6104bb366004613866565b61111e565b3480156104cc57600080fd5b506102cf6104db366004613929565b6111ca565b6102cf6104ee366004613842565b6111dc565b3480156104ff57600080fd5b506102cf61124a565b34801561051457600080fd5b506102f26201518081565b34801561052b57600080fd5b506102cf61053a36600461394b565b61136c565b34801561054b57600080fd5b506102f261055a366004613964565b61137d565b34801561056b57600080fd5b506102cf61057a36600461399d565b6113c4565b34801561058b57600080fd5b506102f261059a366004613964565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b3480156105d557600080fd5b506102cf6105e43660046139ed565b611479565b3480156105f557600080fd5b506102cf61060436600461394b565b611494565b34801561061557600080fd5b506102f2610624366004613842565b6001600160a01b031660009081526037602052604090206003015490565b34801561064e57600080fd5b50606c546102f2565b34801561066357600080fd5b5061033a6106723660046138e7565b6114a5565b34801561068357600080fd5b506102cf610692366004613a09565b611546565b3480156106a357600080fd5b506102cf6106b23660046136cb565b611639565b3480156106c357600080fd5b506102cf6106d236600461394b565b611798565b3480156106e357600080fd5b506102cf6106f2366004613842565b6117a9565b6102cf610705366004613a3e565b611832565b34801561071657600080fd5b506039546102f2565b34801561072b57600080fd5b506102cf61073a366004613866565b611886565b34801561074b57600080fd5b5061077861075a366004613842565b6001600160a01b039081166000908152603a60205260409020541690565b6040516001600160a01b0390911681526020016102fc565b34801561079c57600080fd5b506107dc6107ab366004613842565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604080516001600160a01b0390941684526020840192909252908201526060016102fc565b34801561080d57600080fd5b5061077861081c366004613ab2565b6119a2565b34801561082d57600080fd5b506102cf61083c366004613acd565b611a36565b34801561084d57600080fd5b506102cf61085c366004613b19565b611c07565b34801561086d57600080fd5b506102f261087c3660046138e7565b611d54565b61088a816119a2565b6001600160a01b0316336001600160a01b0316146108ef576000356001600160e01b03191681336040517f8383e6340000000000000000000000000000000000000000000000000000000081526004016108e693929190613b87565b60405180910390fd5b50565b6060838214610914576040516376081a7b60e11b815260040160405180910390fd5b8367ffffffffffffffff81111561092d5761092d613bbc565b604051908082528060200260200182016040528015610956578160200160208202803683370190505b50905060005b8151811015610a22576037600087878481811061097b5761097b613bd2565b90506020020160208101906109909190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002060040160008585848181106109c7576109c7613bd2565b90506020020160208101906109dc9190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610a0f57610a0f613bd2565b602090810291909101015260010161095c565b50949350505050565b6000600260005403610a7f5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005581610a8e81611e04565b336000908152603a60205260409020546001600160a01b031615610ac757604051632fc6bfb160e21b81523360048201526024016108e6565b610ad333868686611ebb565b600160005595945050505050565b466107e514610b325760405162461bcd60e51b815260206004820152600260248201527f453100000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b7357832a94810e18c84a5a5e2c4dd67d012ade574f3314610b955760405162461bcd60e51b815260206004820152600260248201527f453200000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b610b9f60086119a2565b60405163f883afaf60e01b81526001600160a01b0386811660048301528581166024830152848116604483015260648201849052919091169063f883afaf906084015b600060405180830381600087803b158015610bfc57600080fd5b505af1158015610c10573d6000803e3d6000fd5b5050505050505050565b80610c2481611e04565b6001600160a01b038216600090815260376020526040902033610c478282611f28565b610c5160086119a2565b6039546040517fdd716ad30000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063dd716ad390604401610be2565b610cab611f71565b80610cb581611e04565b6001600160a01b0382166000908152603760205260409020610cd8903334611fad565b5050565b60006008610ce981610881565b6001600160a01b0384166000908152603760205260409020610d0b9084612058565b915033610d1881846120f5565b610d6557604080518481524760208201526001600160a01b0380841692908816917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b505092915050565b600260005403610dbf5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000908155338152603a60205260409020546001600160a01b031615610dfc57604051632fc6bfb160e21b81523360048201526024016108e6565b606d54811180610e0d5750606e5481105b15610e2b57604051631b8454a360e21b815260040160405180910390fd5b3433610e3b818787878787612151565b6001600160a01b03808616600081815260376020818152604080842060018101805497891673ffffffffffffffffffffffffffffffffffffffff19988916811790915581548816871782558552603a835290842080549096168517909555929091529052610eaa818385611fad565b816001600160a01b0316866001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a3505060016000555050505050565b6060600080610f0760086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f44573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f689190613be8565b90508367ffffffffffffffff811115610f8357610f83613bbc565b604051908082528060200260200182016040528015610fac578160200160208202803683370190505b50925060005b8481101561104757858582818110610fcc57610fcc613bd2565b9050602002016020810190610fe19190613842565b925061102283888461101d878c6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b6123df565b84828151811061103457611034613bd2565b6020908102919091010152600101610fb2565b5050509392505050565b60608167ffffffffffffffff81111561106c5761106c613bbc565b604051908082528060200260200182016040528015611095578160200160208202803683370190505b50905060005b8281101561111757603760008585848181106110b9576110b9613bd2565b90506020020160208101906110ce9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000206002015482828151811061110457611104613bd2565b602090810291909101015260010161109b565b5092915050565b6002600054036111705760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260009081556001600160a01b038316815260376020526040902033906111999082846124db565b6111a38183612777565b6111c057604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b6111d26127d8565b610cd8828261284c565b6111e4611f71565b806111ee81611e04565b336000908152603a60205260409020546001600160a01b03161561122757604051632fc6bfb160e21b81523360048201526024016108e6565b6001600160a01b0382166000908152603760205260409020610cd89033346128c0565b60d154600290610100900460ff1615801561126c575060d15460ff8083169116105b6112de5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805461ffff191660ff83161761010017905560365461130a906008906001600160a01b031661296f565b6036805473ffffffffffffffffffffffffffffffffffffffff1916905560d1805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6113746127d8565b6108ef81612a20565b60006113bb838361138c612a55565b6001600160a01b038088166000908152603760209081526040808320938a1683526004909301905220546123df565b90505b92915050565b6002600054036114165760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000558161142581611e04565b6001600160a01b0384166000908152603760205260409020339061144a9082856124db565b6001600160a01b038416600090815260376020526040902061146d9082856128c0565b50506001600055505050565b6114816127d8565b61148a81612ac7565b610cd8828261296f565b61149c6127d8565b6108ef81612b16565b60608167ffffffffffffffff8111156114c0576114c0613bbc565b6040519080825280602002602001820160405280156114e9578160200160208202803683370190505b50905060005b828110156111175761152184848381811061150c5761150c613bd2565b90506020020160208101906106249190613842565b82828151811061153357611533613bd2565b60209081029190910101526001016114ef565b8261155081611e04565b6001600160a01b0384166000908152603760205260409020336115738282611f28565b606d548411806115845750606e5484105b156115a257604051631b8454a360e21b815260040160405180910390fd5b6115ac60086119a2565b6040517fe5125a1d0000000000000000000000000000000000000000000000000000000081526001600160a01b0388811660048301526024820188905260448201879052919091169063e5125a1d906064015b600060405180830381600087803b15801561161957600080fd5b505af115801561162d573d6000803e3d6000fd5b50505050505050505050565b60026000540361168b5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005582158061169d5750828114155b156116bb576040516376081a7b60e11b815260040160405180910390fd5b336000805b85811015611763578484828181106116da576116da613bd2565b90506020020135826116ec9190613c17565b915061175b6037600089898581811061170757611707613bd2565b905060200201602081019061171c9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000208487878581811061174f5761174f613bd2565b905060200201356124db565b6001016116c0565b5061176e8282612777565b61178b57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b6117a06127d8565b6108ef81612b4b565b806117b381611e04565b6001600160a01b0382166000908152603760205260409020336117d68282611f28565b6117e060086119a2565b6039546040517fa7c2f1190000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063a7c2f11990604401610be2565b600861183d81610881565b61187e868680806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250889250879150869050612b80565b505050505050565b6002600054036118d85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600055816118e781611e04565b81600003611921576040517f31d9f7d700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061194c908690613c2a565b9050606c5481101561198a576040517fef0a995700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611995828487612fb1565b61176e83866104b06130b6565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156119d9576119d9613b5d565b60ff1681526020810191909152604001600020546001600160a01b0316905080611a3157816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016108e69190613c3d565b919050565b6008611a4181610881565b8215611c015760005b83811015611bc657600060376000878785818110611a6a57611a6a613bd2565b9050602002016020810190611a7f9190613842565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a9093529120805473ffffffffffffffffffffffffffffffffffffffff1916905560028101549091508015611b5357611ae38282612058565b506001820154611aff906001600160a01b0316826104b06130b6565b611b535760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b6000611b93888886818110611b6a57611b6a613bd2565b9050602002016020810190611b7f9190613842565b60018501546001600160a01b031688613116565b90508015611bb8576001830154611bb6906001600160a01b0316826104b06130b6565b505b836001019350505050611a4a565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d88484604051611bf8929190613c4b565b60405180910390a15b50505050565b60d154610100900460ff1615808015611c27575060d154600160ff909116105b80611c415750303b158015611c41575060d15460ff166001145b611cb35760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805460ff191660011790558015611cd65760d1805461ff0019166101001790555b611ce160088761296f565b611cea85612a20565b611cf560008561284c565b611cfe83612b16565b611d0782612b4b565b801561187e5760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a1505050505050565b6000600260005403611da85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600081905550611ded3384848080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b9050611df93382613296565b600160005592915050565b611e0e60086119a2565b604051635061f96960e11b81526001600160a01b038381166004830152919091169063a0c3f2d290602401602060405180830381865afa158015611e56573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e7a9190613c99565b6108ef576040517f1fa18c8a0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b6000611efa8585858080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b6001600160a01b0383166000908152603760205260409020909150611f209086836128c0565b949350505050565b60018201546001600160a01b03828116911614610cd8576040517ff78cb7ae00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b34600003611fab576040517fdbf97bca00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b8282611fb98282611f28565b82856002016000828254611fcd9190613c17565b92505081905550611ff385858760020154868960030154611fee9190613c17565b6132e4565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d906120499086815260200190565b60405180910390a25050505050565b600061206883600201548361331f565b90508083600201600082825461207e9190613c2a565b90915550506001830154600284015460038501546120ae9286926001600160a01b0390911691611fee9086613335565b82546040518281526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f759060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612142576040519150601f19603f3d011682016040523d82523d6000602084013e612147565b606091505b5090949350505050565b61215f8660006104b06130b6565b6121bd576040805163338f030160e01b81526001600160a01b03881660048201526024810191909152600a60448201527f706f6f6c2061646d696e0000000000000000000000000000000000000000000060648201526084016108e6565b6121cb8360006104b06130b6565b612229576040805163338f030160e01b81526001600160a01b03851660048201526024810191909152600860448201527f747265617375727900000000000000000000000000000000000000000000000060648201526084016108e6565b606c5481101561224c57604051630a8d7fa760e21b815260040160405180910390fd5b846001600160a01b0316866001600160a01b031614158061227f5750826001600160a01b0316856001600160a01b031614155b156122b6576040517fdc1d04ff00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60408051600280825260608201835260009260208301908036833701905050905086816000815181106122eb576122eb613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050848160018151811061231f5761231f613bd2565b60200260200101906001600160a01b031690816001600160a01b0316815250506123488161334f565b1561238d576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b5061239860086119a2565b60405163f883afaf60e01b81526001600160a01b0387811660048301528681166024830152858116604483015260648201859052919091169063f883afaf906084016115ff565b6001600160a01b0380851660009081526002602090815260408083209387168352929052908120600381015484900361241a57549050611f20565b6001600160a01b03861660009081526003602081815260408084206001808452828620948701548652939092528320918201548392901561247f57805460018601549094506124699085613c2a565b85600201546124789190613cbb565b9250612487565b846001015493505b8154600090612497908690613c2a565b6124a19089613cbb565b9050670de0b6b3a76400006124b68286613c17565b6124c09190613cd2565b86546124cc9190613c17565b9b9a5050505050505050505050565b82826124e782826133ee565b82600003612521576040517ff5618d5a00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0384166000908152600486016020526040902054831115612575576040517f34aa9a2800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600061258160086119a2565b8654604051635061f96960e11b81526001600160a01b03918216600482015291925082169063a0c3f2d290602401602060405180830381865afa1580156125cc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125f09190613c99565b8015612683575085546040517f28bde1e10000000000000000000000000000000000000000000000000000000081526001600160a01b039182166004820152908216906328bde1e19060240160e060405180830381865afa158015612659573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061267d9190613cff565b60a00151155b80156126b657506038546001600160a01b038616600090815260058801602052604090205442916126b391613c17565b10155b156126ed576040517ff19f52bd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260048701602052604090205461272b908790879061271b908890613c2a565b878a60030154611fee9190613c2a565b85546040518581526001600160a01b03918216918716907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c9060200160405180910390a3505050505050565b6000814710156127ce576040517f98c713c00000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152476024820152604481018390526064016108e6565b6113bb83836120f5565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611fab576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108e6929190613dab565b61271081118061285b57508082115b1561287957604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b82826128cc82826133ee565b6001600160a01b038416600090815260048601602052604090205461290a90869086906128fa908790613c17565b868960030154611fee9190613c17565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b906129609087815260200190565b60405180910390a35050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156129a5576129a5613b5d565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f8111156129f3576129f3613b5d565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be290602001611361565b6000612a6160086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015612a9e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612ac29190613be8565b905090565b806001600160a01b03163b6000036108ef576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a90602001611361565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c67890602001611361565b83518214612bc957807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a5858585604051612bbc93929190613e12565b60405180910390a2611c01565b6000806000806000885167ffffffffffffffff811115612beb57612beb613bbc565b604051908082528060200260200182016040528015612c14578160200160208202803683370190505b5090506000895167ffffffffffffffff811115612c3357612c33613bbc565b604051908082528060200260200182016040528015612c5c578160200160208202803683370190505b50905060008a5167ffffffffffffffff811115612c7b57612c7b613bbc565b604051908082528060200260200182016040528015612ca4578160200160208202803683370190505b50905060005b8b51811015612f17578b8181518110612cc557612cc5613bd2565b6020908102919091018101516001600160a01b038116600090815260038084526040808320603790955290912001549097506001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a9003612d6657868389806001019a5081518110612d4057612d40613bd2565b60200260200101906001600160a01b031690816001600160a01b03168152505050612f05565b60028101548a1115612d9457604080518082019091528681526020018a905260018101869055600281018a90555b600181015415612dde5760018101548c8c84818110612db557612db5613bd2565b90506020020135670de0b6b3a7640000612dcf9190613cbb565b612dd99190613cd2565b612de1565b60005b985088816000016000828254612df79190613c17565b9182905550905085612e098a85613c2a565b81518110612e1957612e19613bd2565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c815260200190815260200160002060008201518160000155602082015181600101559050508581600101600001819055508060010160000154848984612eac9190613c2a565b81518110612ebc57612ebc613bd2565b6020908102919091010152868d612ed38a85613c2a565b81518110612ee357612ee3613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050505b80612f0f81613e75565b915050612caa565b508515612f6057858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a382604051612f579190613e8e565b60405180910390a25b8a5115612fa457877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c8585604051612f9b93929190613ea1565b60405180910390a25b5050505050505050505050565b8282612fbd8282611f28565b8460020154831115612fe257604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b0385166000908152600587016020526040902054429161300b91613c17565b1115613043576040517f07b6105200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828560020160008282546130579190613c2a565b9250508190555061307885858760020154868960030154611fee9190613c2a565b84546040518481526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f7590602001612049565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613106576040519150601f19603f3d011682016040523d82523d6000602084013e61310b565b606091505b509095945050505050565b6001600160a01b0380841660009081526037602090815260408083209386168352600490930190529081205461314e858585846123df565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b78460405161319591815260200190565b60405180910390a36001600160a01b038086166000818152600260209081526040808320948916835293815283822082815592825260039052919091206131df9082868580613437565b60038181018590556001600160a01b03878116600081815260209384526040808220546001870155519081529188169290917faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad910160405180910390a350509392505050565b600080613250612a55565b905060005b8351811015610d655761328284828151811061327357613273613bd2565b60200260200101518684613116565b61328c9084613c17565b9250600101613255565b6132a08282612777565b610cd8576040517f3b97b7700000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b83546132fa906001600160a01b031684846134e2565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b600081831061332e57816113bb565b5090919050565b60008183116133455760006113bb565b6113bb8284613c2a565b6000815160000361336257506000919050565b60005b60018351038110156133e557600181015b83518110156133dc5783818151811061339157613391613bd2565b60200260200101516001600160a01b03168483815181106133b4576133b4613bd2565b60200260200101516001600160a01b0316036133d4575060019392505050565b600101613376565b50600101613365565b50600092915050565b60018201546001600160a01b03808316911603610cd8576040517f9feb934700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828460030154101561344b57600284018190555b600061345b85600201548461331f565b9050600081866002015461346f9190613c2a565b905080156134d9576002860182905560018701548111156134bc576040517fa5ca437e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808760010160000160008282546134d39190613c2a565b90915550505b50505050505050565b60006134ec612a55565b6001600160a01b0385166000908152600360205260409020600181015460028201549293509091831115613560576040518060400160405280613547886001600160a01b031660009081526037602052604090206003015490565b8152602090810185905281516001850155015160028301555b6001600160a01b038681166000818152600260209081526040808320948a1680845294825280832093835260378252808320948352600490940190529182205490916135ae898988856123df565b83549091508114613600578083556040518181526001600160a01b0389811691908b16907faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad9060200160405180910390a35b61360d8584888a86613437565b845460018085019190915560038401879055850154841461367457886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c876001016000015460405161366b91815260200190565b60405180910390a35b505050505050505050565b60008083601f84011261369157600080fd5b50813567ffffffffffffffff8111156136a957600080fd5b6020830191508360208260051b85010111156136c457600080fd5b9250929050565b600080600080604085870312156136e157600080fd5b843567ffffffffffffffff808211156136f957600080fd5b6137058883890161367f565b9096509450602087013591508082111561371e57600080fd5b5061372b8782880161367f565b95989497509550505050565b600081518084526020808501945080840160005b838110156137675781518752958201959082019060010161374b565b509495945050505050565b6020815260006113bb6020830184613737565b6001600160a01b03811681146108ef57600080fd5b6000806000604084860312156137af57600080fd5b833567ffffffffffffffff8111156137c657600080fd5b6137d28682870161367f565b90945092505060208401356137e681613785565b809150509250925092565b6000806000806080858703121561380757600080fd5b843561381281613785565b9350602085013561382281613785565b9250604085013561383281613785565b9396929550929360600135925050565b60006020828403121561385457600080fd5b813561385f81613785565b9392505050565b6000806040838503121561387957600080fd5b823561388481613785565b946020939093013593505050565b6000806000604084860312156138a757600080fd5b83356138b281613785565b9250602084013567ffffffffffffffff8111156138ce57600080fd5b6138da8682870161367f565b9497909650939450505050565b600080602083850312156138fa57600080fd5b823567ffffffffffffffff81111561391157600080fd5b61391d8582860161367f565b90969095509350505050565b6000806040838503121561393c57600080fd5b50508035926020909101359150565b60006020828403121561395d57600080fd5b5035919050565b6000806040838503121561397757600080fd5b823561398281613785565b9150602083013561399281613785565b809150509250929050565b6000806000606084860312156139b257600080fd5b83356139bd81613785565b925060208401356139cd81613785565b929592945050506040919091013590565b803560108110611a3157600080fd5b60008060408385031215613a0057600080fd5b613982836139de565b600080600060608486031215613a1e57600080fd5b8335613a2981613785565b95602085013595506040909401359392505050565b600080600080600060608688031215613a5657600080fd5b853567ffffffffffffffff80821115613a6e57600080fd5b613a7a89838a0161367f565b90975095506020880135915080821115613a9357600080fd5b50613aa08882890161367f565b96999598509660400135949350505050565b600060208284031215613ac457600080fd5b6113bb826139de565b600080600060408486031215613ae257600080fd5b833567ffffffffffffffff811115613af957600080fd5b613b058682870161367f565b909790965060209590950135949350505050565b600080600080600060a08688031215613b3157600080fd5b8535613b3c81613785565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052602160045260246000fd5b60108110613b8357613b83613b5d565b9052565b6001600160e01b03198416815260608101613ba56020830185613b73565b6001600160a01b0383166040830152949350505050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b600060208284031215613bfa57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b808201808211156113be576113be613c01565b818103818111156113be576113be613c01565b602081016113be8284613b73565b60208082528181018390526000908460408401835b86811015613c8e578235613c7381613785565b6001600160a01b031682529183019190830190600101613c60565b509695505050505050565b600060208284031215613cab57600080fd5b8151801515811461385f57600080fd5b80820281158282048414176113be576113be613c01565b600082613cef57634e487b7160e01b600052601260045260246000fd5b500490565b8051611a3181613785565b600060e08284031215613d1157600080fd5b60405160e0810181811067ffffffffffffffff82111715613d4257634e487b7160e01b600052604160045260246000fd5b604052613d4e83613cf4565b8152613d5c60208401613cf4565b6020820152613d6d60408401613cf4565b6040820152613d7e60608401613cf4565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b6001600160e01b03198316815260408101600b8310613dcc57613dcc613b5d565b8260208301529392505050565b600081518084526020808501945080840160005b838110156137675781516001600160a01b031687529582019590820190600101613ded565b604081526000613e256040830186613dd9565b82810360208401528381527f07ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff841115613e5d57600080fd5b8360051b808660208401370160200195945050505050565b600060018201613e8757613e87613c01565b5060010190565b6020815260006113bb6020830184613dd9565b606081526000613eb46060830186613dd9565b8281036020840152613ec68186613737565b90508281036040840152613eda8185613737565b969550505050505056fea26469706673582212209c26c9b27087c4ace8fe06bea64a20c6bdad77f3bf4c4bee053bd164543bfbec64736f6c6343000815003300000000000000000000000000 + │ ├─ [3277977] → new Staking@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + │ │ ├─ emit Initialized(version: 255) + │ │ └─ ← 16154 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, Staking: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], Staking, StakingLogic, 0x, 3)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, StakingLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + │ ├─ [0] GeneralConfig::getContractName(8) [staticcall] + │ │ └─ ← NotifiedMigrator + │ ├─ [0] GeneralConfig::getContractFileName(8) [staticcall] + │ │ └─ ← NotifiedMigrator.sol:NotifiedMigrator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000004 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(NotifiedMigrator.sol:NotifiedMigrator) [staticcall] + │ │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000f6a61010060405260405162000f6a38038062000f6a833981016040819052620000279162000272565b83838362000035816200016f565b62000040826200016f565b6200004b836200016f565b60408051600380825260808201909252600091602082016060803683370190505090508381600081518110620000855762000085620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508281600181518110620000bc57620000bc620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508181600281518110620000f357620000f3620002cf565b6001600160a01b03909216602092830291909101909101526200011681620001aa565b156200014857604051630d697db160e11b81526001600160e01b03196000351660048201526024015b60405180910390fd5b506001600160a01b03928316608052821660a052811660c0521660e05250620002e5915050565b806001600160a01b03163b600003620001a757604051630bfc64a360e21b81526001600160a01b03821660048201526024016200013f565b50565b60008151600003620001be57506000919050565b60005b60018351038110156200024c57600181015b83518110156200024257838181518110620001f257620001f2620002cf565b60200260200101516001600160a01b0316848381518110620002185762000218620002cf565b60200260200101516001600160a01b03160362000239575060019392505050565b600101620001d3565b50600101620001c1565b50600092915050565b80516001600160a01b03811681146200026d57600080fd5b919050565b600080600080608085870312156200028957600080fd5b620002948562000255565b9350620002a46020860162000255565b9250620002b46040860162000255565b9150620002c46060860162000255565b905092959194509250565b634e487b7160e01b600052603260045260246000fd5b60805160a05160c05160e051610c306200033a60003960008181610174015261036301526000818160b0015261027101526000818161010001526103cd0152600081816101dd015261020a0152610c306000f3fe60806040526004361061007f5760003560e01c80639f2e6a0c1161004e5780639f2e6a0c14610162578063d39f567714610196578063de981f1b146101ab578063f89360c2146101cb57610096565b8063014fdae61461009e57806330b53157146100ee578063865e6fd3146101225780638f61eea61461014257610096565b366100965761008c6101ff565b61009461026a565b005b61008c6101ff565b3480156100aa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200160405180910390f35b3480156100fa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b34801561012e57600080fd5b5061009461013d36600461082b565b61029f565b34801561014e57600080fd5b5061009461015d36600461086e565b6102be565b34801561016e57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b3480156101a257600080fd5b50610094610350565b3480156101b757600080fd5b506100d26101c63660046108e3565b6103f1565b3480156101d757600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610268576040517f145be2450000000000000000000000000000000000000000000000000000000081523060048201526024015b60405180910390fd5b565b60006102957f0000000000000000000000000000000000000000000000000000000000000000610485565b9050805160208201f35b6102a761050d565b6102b081610581565b6102ba82826105d3565b5050565b6102c661050d565b6102ce6101ff565b7f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae026338160005b81811015610349578285858381811061030e5761030e610905565b9050602002810190610320919061091b565b825460018101845560009384526020909320909201916103409183610a04565b506001016102f3565b5050505050565b6103586101ff565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146103c8576040517f8f47e7e30000000000000000000000000000000000000000000000000000000081526001600160e01b031960003516600482015260240161025f565b6102687f000000000000000000000000000000000000000000000000000000000000000061068f565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561042857610428610ac4565b60ff1681526020810191909152604001600020546001600160a01b031690508061048057816040517f812281be00000000000000000000000000000000000000000000000000000000815260040161025f9190610ada565b919050565b6060600080836001600160a01b03166000366040516104a5929190610af4565b600060405180830381855af49150503d80600081146104e0576040519150601f19603f3d011682016040523d82523d6000602084013e6104e5565b606091505b5090925090506105048215156001600160e01b031960003516836107d6565b91506104809050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610268576000356001600160e01b03191660016040517f3e523c0000000000000000000000000000000000000000000000000000000000815260040161025f929190610b04565b806001600160a01b03163b6000036105d0576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b038216600482015260240161025f565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561060957610609610ac4565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f81111561066257610662610ac4565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc8190556040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a27f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633805460006060815b838110156107ce57856001600160a01b031685828154811061073457610734610905565b9060005260206000200160405161074b9190610b32565b600060405180830381855af49150503d8060008114610786576040519150601f19603f3d011682016040523d82523d6000602084013e61078b565b606091505b5080935081945050506107c68582815481106107a9576107a9610905565b906000526020600020016107bc90610ba8565b84151590846107d6565b600101610710565b505050505050565b6001600160e01b0319600035168361081657815180156107f7578060208401fd5b50604051638e3eda2b81528160208201528360408201526044601c8201fd5b50505050565b80356010811061048057600080fd5b6000806040838503121561083e57600080fd5b6108478361081c565b915060208301356001600160a01b038116811461086357600080fd5b809150509250929050565b6000806020838503121561088157600080fd5b823567ffffffffffffffff8082111561089957600080fd5b818501915085601f8301126108ad57600080fd5b8135818111156108bc57600080fd5b8660208260051b85010111156108d157600080fd5b60209290920196919550909350505050565b6000602082840312156108f557600080fd5b6108fe8261081c565b9392505050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261093257600080fd5b83018035915067ffffffffffffffff82111561094d57600080fd5b60200191503681900382131561096257600080fd5b9250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c9082168061099357607f821691505b6020821081036109b357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156109ff57600081815260208120601f850160051c810160208610156109e05750805b601f850160051c820191505b818110156107ce578281556001016109ec565b505050565b67ffffffffffffffff831115610a1c57610a1c610969565b610a3083610a2a835461097f565b836109b9565b6000601f841160018114610a645760008515610a4c5750838201355b600019600387901b1c1916600186901b178355610349565b600083815260209020601f19861690835b82811015610a955786850135825560209485019460019092019101610a75565b5086821015610ab25760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610aee57610aee610ac4565b91905290565b8183823760009101908152919050565b6001600160e01b03198316815260408101600b8310610b2557610b25610ac4565b8260208301529392505050565b6000808354610b408161097f565b60018281168015610b585760018114610b6d57610b9c565b60ff1984168752821515830287019450610b9c565b8760005260208060002060005b85811015610b935781548a820152908401908201610b7a565b50505082870194505b50929695505050505050565b6000610bb4825461097f565b82601f821115610bca5783600052602060002090505b546001600160e01b031980821693506004831015610bf25780818460040360031b1b83161693505b50505091905056fea2646970667358221220cfbacdac14165fdb77ab5bf3271cf7989242f716ce34787311f0ee35eb2c809e64736f6c6343000815003300000000000000000000000000000000000000000000 + │ ├─ [629007] → new NotifiedMigrator@0x47c5e40890bcE4a473A49D7501808b9633F29782 + │ │ └─ ← 3120 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::label(NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782], NotifiedMigrator)  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::setAddress(3, 8, NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782])  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782], NotifiedMigrator, NotifiedMigrator, 0x000000000000000000000000545edb750eb8769c868429be9586f5857a7687580000000000000000000000009b0e61e629eb44875cff534de0c176078cac502f0000000000000000000000008be503bcded90ed42eff31f56199399b2b0154ca000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f, 4)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, NotifiedMigrator) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] console::log(notifier, ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) [staticcall] + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ │ └─ ← () + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [55807] ronin-mainnet.Staking::upgradeToAndCall(NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000045cd8a76b00000000000000000000000000000000000000000000000000000000)  + │ │ ├─ emit Upgraded(implementation: NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + │ │ ├─ [43786] NotifiedMigrator::setCallDatas([0x5cd8a76b]) [delegatecall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ └─ ← ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758] + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(0) [staticcall] + │ └─ ← ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6] + ├─ [0] GeneralConfig::getContractName(6) [staticcall] + │ └─ ← Profile + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(6) [staticcall] + │ └─ ← ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035] + ├─ [6942400] → new NotifiedMigratorUpgrade@0xDc82c0362A241Aa94d53546648EACe48C9773dAa + │ └─ ← 34712 bytes of code + ├─ [0] NotifiedMigratorUpgrade::run(4, [0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6, 0x3101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035])  + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::makePersistent(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] VM::allowCheatcodes(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getCurrentNetwork() [staticcall] + │ │ └─ ← 3 + │ ├─ [1674000] → new LogGenerator@0xA307c1AEf114D9a2c6699Ae4d28A6e85870Bc2d9 + │ │ └─ ← 8370 bytes of code + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(4) [staticcall] + │ │ └─ ← ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3] + │ ├─ [0] VM::load(ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + │ ├─ [0] VM::load(ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3], 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc) [staticcall] + │ │ └─ ← 0x000000000000000000000000056500e6028048db7fca81ac307008a9042605f3 + │ ├─ [0] GeneralConfig::getContractName(4) [staticcall] + │ │ └─ ← SlashIndicator + │ ├─ [0] GeneralConfig::getContractFileName(4) [staticcall] + │ │ └─ ← SlashIndicator.sol:SlashIndicator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000005 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(SlashIndicator.sol:SlashIndicator) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000390160806040523480156200001157600080fd5b506200001c62000022565b620000e7565b61011354610100900460ff1615620000905760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b6101135460ff9081161015620000e557610113805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61380a80620000f76000396000f3fe608060405234801561001057600080fd5b506004361061020b5760003560e01c806399103f7b1161012a578063d1cf4343116100bd578063df4b6ee01161008c578063f1001e7811610071578063f1001e78146104a9578063f562b3c4146104c9578063fd422cd0146104d257600080fd5b8063df4b6ee01461047e578063e9bb1666146104a257600080fd5b8063d1cf43431461041c578063d1f992f71461042f578063d3dd2bdf14610442578063de981f1b1461046b57600080fd5b8063c6391fa2116100f9578063c6391fa2146103d2578063ccbb72ed146103e3578063cf39d13c146103f6578063d1737e271461040957600080fd5b806399103f7b1461038e578063a345ecb2146103a1578063c008ce39146103b4578063c2e524dc146103c757600080fd5b80633101cfcb116101a25780637680850c116101715780637680850c1461033a5780637c2b55a01461034d578063853af1b714610368578063865e6fd31461037b57600080fd5b80633101cfcb146102e75780633d48fd7d146102fa578063487e00ea1461030b57806362ffe6cb1461032757600080fd5b80631a697341116101de5780631a6973411461028b5780631e90b2a01461029e57806329b6eca9146102b157806329ddc3c0146102c457600080fd5b806307c2d2f614610210578063082e7420146102255780630e1512ac1461024b5780631079402a1461025e575b600080fd5b61022361021e366004612a4b565b6104e5565b005b610238610233366004612aa2565b6105f3565b6040519081526020015b60405180910390f35b610223610259366004612abf565b61066a565b606d54606e54606f546070545b604080519485526020850193909352918301526060820152608001610242565b610223610299366004612aa2565b610684565b6102236102ac366004612b33565b610993565b6102236102bf366004612aa2565b610ba0565b6102d76102d2366004612bb6565b610d14565b6040519015158152602001610242565b6102236102f5366004612aa2565b610d43565b60a55460a65460a75460a85461026b565b601d54601e545b60408051928352602083019190915201610242565b610238610335366004612bb6565b610e37565b610223610348366004612be2565b610e60565b60675b6040516001600160a01b039091168152602001610242565b610223610376366004612c2e565b611177565b610223610389366004612c5f565b61118d565b61022361039c366004612cb8565b6111a8565b6102236103af366004612c2e565b61135a565b6102236103c2366004612d76565b61136c565b603854603954610312565b60dd5460de5460df5460e05461026b565b6102236103f1366004612abf565b61141a565b610223610404366004612dab565b61142e565b610223610417366004612abf565b611446565b61022361042a366004612dd7565b61145a565b61022361043d366004612aa2565b6117da565b610238610450366004612aa2565b6001600160a01b0316600090815260dc602052604090205490565b610350610479366004612e96565b611c78565b60015460025460035460408051938452602084019290925290820152606001610242565b6069610350565b6104bc6104b7366004612a4b565b611d0c565b6040516102429190612eec565b61023860a35481565b6102236104e0366004612aa2565b611dd7565b60086104f081612161565b60008267ffffffffffffffff81111561050b5761050b612eff565b604051908082528060200260200182016040528015610534578160200160208202803683370190505b50905060005b838110156105b157600085858381811061055657610556612f15565b905060200201602081019061056b9190612aa2565b6001600160a01b038116600090815260dc6020526040812055835190915083908390811061059b5761059b612f15565b600060209182029290920101525060010161053a565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c234808484836040516105e593929190612f69565b60405180910390a150505050565b6000610664826106036008611c78565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610640573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103359190612f99565b92915050565b6106726121c6565b61067e84848484612222565b50505050565b61068c6121c6565b6000610698600a611c78565b6040517fdb6693a20000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063db6693a29060240160a060405180830381865afa1580156106f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061071d919061303a565b905060006107c061072e600b611c78565b60408085015190517f988ef53c0000000000000000000000000000000000000000000000000000000081526001600160a01b03918216600482015291169063988ef53c90602401602060405180830381865afa158015610792573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107b69190612f99565b83608001516122cd565b905060006107ce6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610810573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108349190612f99565b60385490915061084484436130d8565b11158061087457506001600160a01b038516600090815260376020908152604080832084845290915290205460ff165b156108ab576040517f5c61141600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600081815260376020908152604080832085845290915290819020805460ff19166001179055517f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d99061090c906004908590613101565b60405180910390a2603954604051630bde081360e21b81526001600160a01b0387811660048301526000602483018190526044830193909352606482019290925290831690632f78204c90608401600060405180830381600087803b15801561097457600080fd5b505af1158015610988573d6000803e3d6000fd5b505050505050505050565b61099b6121c6565b600084846040516109ad92919061311f565b60405180910390209050600083836040516109c992919061311f565b604080519182900390912060008481526004602052919091205490915060ff1680610a02575060008181526004602052604090205460ff165b15610a205760405163f27b8ec960e01b815260040160405180910390fd5b610a2d87878787876122e4565b15610b97576000610a3e6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa49190612f99565b6000858152600460205260408082208054600160ff19918216811790925587845292829020805490931617909155519091506001600160a01b038a16907f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d990610b11906003908590613101565b60405180910390a260025460018054604051630bde081360e21b81526001600160a01b038d8116600483015260248201949094526044810191909152606481019190915290831690632f78204c90608401600060405180830381600087803b158015610b7c57600080fd5b505af1158015610b90573d6000803e3d6000fd5b5050505050505b50505050505050565b61011354600290610100900460ff16158015610bc457506101135460ff8083169116105b610c2c5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b610113805461ffff191660ff831617610100179055600054610c59906008906001600160a01b03166123d5565b606c54610c71906005906001600160a01b03166123d5565b610c7c6004836123d5565b603554610c9490600a906001600160a01b03166123d5565b6000805473ffffffffffffffffffffffffffffffffffffffff19908116909155606c8054821690556035805482169055603680549091169055610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b61011354600390610100900460ff16158015610d6757506101135460ff8083169116105b610dca5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805461ffff191660ff831617610100179055610dea600f836123d5565b610df8600154600254612486565b610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610d08565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610d3c565b6008610e6b81612161565b60003390506000816001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610eb0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ed49190612f99565b90506000826001600160a01b0316634de2b73588886040518363ffffffff1660e01b8152600401610f0692919061312f565b600060405180830381865afa158015610f23573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610f4b9190810190613177565b90506000610f596005611c78565b6001600160a01b031663ba303755898986436040518563ffffffff1660e01b8152600401610f8a9493929190613214565b600060405180830381865afa158015610fa7573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610fcf9190810190613177565b905060008767ffffffffffffffff811115610fec57610fec612eff565b604051908082528060200260200182016040528015611015578160200160208202803683370190505b50905060005b888110156111305760008a8a8381811061103757611037612f15565b905060200201602081019061104c9190612aa2565b9050600061105a828b610e37565b9050600086848151811061107057611070612f15565b60200260200101519050600086858151811061108e5761108e612f15565b60200260200101519050600082806110a35750815b6110b8576110b360dd54856124c6565b6110bb565b60005b6001600160a01b038616600090815260dc602052604090205460de549192506110e59183906124e0565b6001600160a01b038616600090815260dc60205260409020819055875188908890811061111457611114612f15565b602002602001018181525050856001019550505050505061101b565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c2348089898360405161116493929190612f69565b60405180910390a1505050505050505050565b61117f6121c6565b61118982826124fd565b5050565b6111956121c6565b61119e8161253d565b61118982826123d5565b61011354610100900460ff16158080156111ca575061011354600160ff909116105b806111e55750303b1580156111e557506101135460ff166001145b6112485760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805460ff19166001179055801561126d57610113805461ff0019166101001790555b61127860088b6123d5565b61128360058a6123d5565b61128e6004886123d5565b611299600a896123d5565b6112b286356020880135604089013560608a0135612222565b6112c1853560208701356124fd565b6112d584356020860135604087013561258c565b6112ee83356020850135604086013560608701356125e1565b6113078235602084013560408501356060860135612686565b801561134e57610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6113626121c6565b6111898282612486565b600861137781612161565b826001036113c857836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96005846040516113bb929190613101565b60405180910390a261067e565b8260020361067e57836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960068460405161140c929190613101565b60405180910390a250505050565b6114226121c6565b61067e84848484612686565b6114366121c6565b61144183838361258c565b505050565b61144e6121c6565b61067e848484846125e1565b61146333612755565b600003611493576000356001600160e01b0319166003604051620f948f60ea1b8152600401610c2392919061323b565b600061149f600f611c78565b6040517ff46609400000000000000000000000000000000000000000000000000000000081526001600160a01b038a8116600483015291925060009183169063f466094090602401600060405180830381865afa158015611504573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261152c91908101906132fa565b60a0015190508080519060200120888860405161154a92919061311f565b604051809103902014611597576040517f053265f10000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b6040516bffffffffffffffffffffffff1960608b901b1660208201526034810187905260009060540160408051601f1981840301815291815281516020928301206000818152601f90935291205490915060ff16156116095760405163f27b8ec960e01b815260040160405180910390fd5b61167f89898080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250506040805180820182528c935091508a90600290839083908082843760009201919091525061167191508a9050613413565b61167a896134eb565b6127e6565b1561134e576000818152601f60205260408120805460ff191660011790556116a76008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116e9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061170d9190612f99565b90508b6001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960088360405161174b929190613101565b60405180910390a2601e54601d54604051630bde081360e21b81526001600160a01b038f81166004830152602482019390935260448101919091526001606482015290831690632f78204c90608401600060405180830381600087803b1580156117b457600080fd5b505af11580156117c8573d6000803e3d6000fd5b50505050505050505050505050505050565b60006117e66008611c78565b6040517fa0c3f2d20000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301529192509082169063a0c3f2d290602401602060405180830381865afa158015611849573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061186d9190613544565b61189a576000356001600160e01b0319166008604051620f948f60ea1b8152600401610c2392919061323b565b6040517f04d971ab0000000000000000000000000000000000000000000000000000000081526001600160a01b0383811660048301523360248301528216906304d971ab90604401602060405180830381865afa1580156118ff573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119239190613544565b611950576000356001600160e01b0319166004604051620f948f60ea1b8152600401610c2392919061323b565b6040517f96585fc20000000000000000000000000000000000000000000000000000000081526001600160a01b03838116600483015260009182918416906396585fc290602401606060405180830381865afa1580156119b4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119d8919061355f565b925050915081611a14576040517f6cd31b5900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000836001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611a54573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a789190612f99565b6001600160a01b038616600090815260db6020908152604080832084845290915290205490915060ff1615611ad9576040517f7674d6a900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260dc602052604081205460df54909190611b029085613594565b905080821015611b3e576040517f8c5cb26e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040517f15b5ebde0000000000000000000000000000000000000000000000000000000081526001600160a01b038881166004830152602482018590528716906315b5ebde90604401600060405180830381600087803b158015611ba157600080fd5b505af1158015611bb5573d6000803e3d6000fd5b505050506001600160a01b038716600090815260dc602052604081208054839290611be19084906130d8565b90915550506001600160a01b038716600090815260a4602090815260408083208684529091528120556001600160a01b038716600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a250505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115611caf57611caf6130eb565b60ff1681526020810191909152604001600020546001600160a01b0316905080611d0757816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c2391906135bf565b919050565b60608167ffffffffffffffff811115611d2757611d27612eff565b604051908082528060200260200182016040528015611d50578160200160208202803683370190505b50905060005b8151811015611dd05760dc6000858584818110611d7557611d75612f15565b9050602002016020810190611d8a9190612aa2565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611dbd57611dbd612f15565b6020908102919091010152600101611d56565b5092915050565b60a3544311611e12576040517f557fd09100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b4360a355334114611e46576000356001600160e01b0319166002604051620f948f60ea1b8152600401610c2392919061323b565b611e4f8161286f565b1561215e576000611e606008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611ea2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ec69190612f99565b6001600160a01b038416600090815260a460209081526040808320848452909152812080546001019081905560a85492935091611f049043906129b7565b905060a6548203611fcd57846001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600285604051611f4b929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0387811660048301526024820184905260448201929092526000606482015290851690632f78204c90608401600060405180830381600087803b158015611fb057600080fd5b505af1158015611fc4573d6000803e3d6000fd5b50505050612159565b60a5548203612159576000611fe28685610d14565b9050806120a257856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600186604051612025929190613101565b60405180910390a2604051630bde081360e21b81526001600160a01b038781166004830152600060248301819052604483018190526064830152861690632f78204c90608401600060405180830381600087803b15801561208557600080fd5b505af1158015612099573d6000803e3d6000fd5b50505050612157565b856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96007866040516120de929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0388811660048301526024820185905260448201929092526001606482015290861690632f78204c90608401600060405180830381600087803b15801561214357600080fd5b505af115801561134e573d6000803e3d6000fd5b505b505050505b50565b61216a81611c78565b6001600160a01b0316336001600160a01b03161461215e576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c23939291906135cd565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314612220576000356001600160e01b0319166001604051620f948f60ea1b8152600401610c2392919061323b565b565b82841180612231575061271084115b8061223d575061271083115b15612274576040517f397c357e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b606d849055606e839055606f82905560708190556040805185815260208101859052908101839052606081018290527fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b906080016105e5565b6000818310156122dd5781610d3c565b5090919050565b6040516000906067906001908390612308908a908a908a908a908a9060240161362b565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7fc3567700000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b602083016020828483895afa61238257600094505b503d61238d57600093505b836123c4576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5115159a9950505050505050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561240b5761240b6130eb565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115612459576124596130eb565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b601d829055601e81905560408051838152602081018390527f381ec200df2ed0875638486318f9f8a84e3550bdc686bf1400c9371a18d087f09101610d08565b60008183116124d6576000610d3c565b610d3c82846130d8565b60006124f56124ef848661366d565b836129d2565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a9101610d08565b806001600160a01b03163b60000361215e576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c23565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b9060600160405180910390a1505050565b60a65460a554111561262d576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b60a584905560a683905560a782905560a88190556040805185815260208101859052908101839052606081018290527f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa98906080016105e5565b828411156126c0576040517f112af4d100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108111156126fc576040517fe0b2228c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60dd84905560de83905560df82905560e08190556040805185815260208101859052908101839052606081018290527fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b906080016105e5565b6000612761600a611c78565b6040517fd78392f80000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063d78392f890602401602060405180830381865afa1580156127c2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106649190612f99565b604051600090606990600190839061280a908a908a908a908a908a906024016136f1565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7b47d06b00000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b6000336001600160a01b03831614801590612914575061288f6008611c78565b6040517f65244ece0000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015291909116906365244ece90602401602060405180830381865afa1580156128f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129149190613544565b801561066457506129256005611c78565b6040517f0fbeb37f0000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301524360248301529190911690630fbeb37f90604401602060405180830381865afa15801561298c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129b09190613544565b1592915050565b6000816000036129c8576000610d3c565b610d3c828461366d565b60008183106122dd5781610d3c565b60405180602001604052806001906020820280368337509192915050565b60008083601f840112612a1157600080fd5b50813567ffffffffffffffff811115612a2957600080fd5b6020830191508360208260051b8501011115612a4457600080fd5b9250929050565b60008060208385031215612a5e57600080fd5b823567ffffffffffffffff811115612a7557600080fd5b612a81858286016129ff565b90969095509350505050565b6001600160a01b038116811461215e57600080fd5b600060208284031215612ab457600080fd5b8135610d3c81612a8d565b60008060008060808587031215612ad557600080fd5b5050823594602084013594506040840135936060013592509050565b60008083601f840112612b0357600080fd5b50813567ffffffffffffffff811115612b1b57600080fd5b602083019150836020828501011115612a4457600080fd5b600080600080600060608688031215612b4b57600080fd5b8535612b5681612a8d565b9450602086013567ffffffffffffffff80821115612b7357600080fd5b612b7f89838a01612af1565b90965094506040880135915080821115612b9857600080fd5b50612ba588828901612af1565b969995985093965092949392505050565b60008060408385031215612bc957600080fd5b8235612bd481612a8d565b946020939093013593505050565b600080600060408486031215612bf757600080fd5b833567ffffffffffffffff811115612c0e57600080fd5b612c1a868287016129ff565b909790965060209590950135949350505050565b60008060408385031215612c4157600080fd5b50508035926020909101359150565b803560108110611d0757600080fd5b60008060408385031215612c7257600080fd5b612c7b83612c50565b91506020830135612c8b81612a8d565b809150509250929050565b806080810183101561066457600080fd5b806040810183101561066457600080fd5b60008060008060008060008060006102a08a8c031215612cd757600080fd5b8935612ce281612a8d565b985060208a0135612cf281612a8d565b975060408a0135612d0281612a8d565b965060608a0135612d1281612a8d565b9550612d218b60808c01612c96565b9450612d318b6101008c01612ca7565b93506101a08a018b811115612d4557600080fd5b6101408b019350612d568c82612c96565b925050612d678b6102208c01612c96565b90509295985092959850929598565b600080600060608486031215612d8b57600080fd5b8335612d9681612a8d565b95602085013595506040909401359392505050565b600080600060608486031215612dc057600080fd5b505081359360208301359350604090920135919050565b600080600080600080600060e0888a031215612df257600080fd5b8735612dfd81612a8d565b9650602088013567ffffffffffffffff80821115612e1a57600080fd5b612e268b838c01612af1565b909850965060408a01359550869150612e428b60608c01612ca7565b945060a08a0135915080821115612e5857600080fd5b612e648b838c01612ca7565b935060c08a0135915080821115612e7a57600080fd5b50612e878a828b01612ca7565b91505092959891949750929550565b600060208284031215612ea857600080fd5b610d3c82612c50565b600081518084526020808501945080840160005b83811015612ee157815187529582019590820190600101612ec5565b509495945050505050565b602081526000610d3c6020830184612eb1565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b8183526000602080850194508260005b85811015612ee1578135612f4e81612a8d565b6001600160a01b031687529582019590820190600101612f3b565b604081526000612f7d604083018587612f2b565b8281036020840152612f8f8185612eb1565b9695505050505050565b600060208284031215612fab57600080fd5b5051919050565b60405160c0810167ffffffffffffffff81118282101715612fd557612fd5612eff565b60405290565b6040805190810167ffffffffffffffff81118282101715612fd557612fd5612eff565b604051601f8201601f1916810167ffffffffffffffff8111828210171561302757613027612eff565b604052919050565b8051611d0781612a8d565b600060a0828403121561304c57600080fd5b60405160a0810181811067ffffffffffffffff8211171561306f5761306f612eff565b604052825161307d81612a8d565b8152602083015161308d81612a8d565b602082015260408301516130a081612a8d565b6040820152606083810151908201526080928301519281019290925250919050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610664576106646130c2565b634e487b7160e01b600052602160045260246000fd5b6040810160098410613115576131156130eb565b9281526020015290565b8183823760009101908152919050565b6020815260006124f5602083018486612f2b565b600067ffffffffffffffff82111561315d5761315d612eff565b5060051b60200190565b80518015158114611d0757600080fd5b6000602080838503121561318a57600080fd5b825167ffffffffffffffff8111156131a157600080fd5b8301601f810185136131b257600080fd5b80516131c56131c082613143565b612ffe565b81815260059190911b820183019083810190878311156131e457600080fd5b928401925b82841015613209576131fa84613167565b825292840192908401906131e9565b979650505050505050565b606081526000613228606083018688612f2b565b6020830194909452506040015292915050565b6001600160e01b03198316815260408101600b831061325c5761325c6130eb565b8260208301529392505050565b600067ffffffffffffffff82111561328357613283612eff565b50601f01601f191660200190565b60005b838110156132ac578181015183820152602001613294565b50506000910152565b600082601f8301126132c657600080fd5b81516132d46131c082613269565b8181528460208386010111156132e957600080fd5b6124f5826020830160208701613291565b60006020828403121561330c57600080fd5b815167ffffffffffffffff8082111561332457600080fd5b9083019060c0828603121561333857600080fd5b613340612fb2565b825161334b81612a8d565b8152602083015161335b81612a8d565b6020820152604083015161336e81612a8d565b604082015261337f6060840161302f565b60608201526133906080840161302f565b608082015260a0830151828111156133a757600080fd5b6133b3878286016132b5565b60a08301525095945050505050565b600082601f8301126133d357600080fd5b81356133e16131c082613269565b8181528460208386010111156133f657600080fd5b816020850160208301376000918101602001919091529392505050565b600061341d612fdb565b80604084013681111561342f57600080fd5b845b818110156134e157803567ffffffffffffffff808211156134525760008081fd5b9087019036601f8301126134665760008081fd5b813560206134766131c083613143565b82815260059290921b840181019181810190368411156134965760008081fd5b8286015b848110156134ce578035868111156134b25760008081fd5b6134c03686838b01016133c2565b84525091830191830161349a565b5089525090960195505050602001613431565b5090949350505050565b60006134f5612fdb565b80604084013681111561350757600080fd5b845b818110156134e157803567ffffffffffffffff8111156135295760008081fd5b613535368289016133c2565b85525060209384019301613509565b60006020828403121561355657600080fd5b610d3c82613167565b60008060006060848603121561357457600080fd5b61357d84613167565b925060208401519150604084015190509250925092565b8082028115828204841417610664576106646130c2565b601081106135bb576135bb6130eb565b9052565b6020810161066482846135ab565b6001600160e01b031984168152606081016135eb60208301856135ab565b6001600160a01b0383166040830152949350505050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b038616815260606020820152600061364e606083018688613602565b8281036040840152613661818587613602565b98975050505050505050565b80820180821115610664576106646130c2565b60008151808452613698816020860160208601613291565b601f01601f19169290920160200192915050565b600082604081018360005b60028110156136e65783830387526136d0838351613680565b60209788019790935091909101906001016136b7565b509095945050505050565b60c08152600061370460c0830188613680565b60208781850152604084018760005b600281101561373057815183529183019190830190600101613713565b505050838203608085015281604081018760005b60028110156137b1578583038452815180518085529086019086850190600581901b8601880160005b8281101561379b57601f19888303018452613789828651613680565b948a0194938a0193915060010161376d565b5096880196955050509185019150600101613744565b505085810360a08701526137c581886136ac565b9b9a505050505050505050505056fea26469706673582212203dbb57dc8e95a92b94b022dfe41ffd6257773156df8af8a6f5401ce4ee74766764736f6c6343000815003300000000000000000000000000000000000000000000000000000000000000 + │ ├─ [2895930] → new SlashIndicator@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + │ │ ├─ emit Initialized(version: 255) + │ │ └─ ← 14346 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, SlashIndicator: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], SlashIndicator, SlashIndicatorLogic, 0x, 5)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, SlashIndicatorLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + │ ├─ [0] GeneralConfig::getContractName(8) [staticcall] + │ │ └─ ← NotifiedMigrator + │ ├─ [0] GeneralConfig::getContractFileName(8) [staticcall] + │ │ └─ ← NotifiedMigrator.sol:NotifiedMigrator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000006 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(NotifiedMigrator.sol:NotifiedMigrator) [staticcall] + │ │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000f6a61010060405260405162000f6a38038062000f6a833981016040819052620000279162000272565b83838362000035816200016f565b62000040826200016f565b6200004b836200016f565b60408051600380825260808201909252600091602082016060803683370190505090508381600081518110620000855762000085620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508281600181518110620000bc57620000bc620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508181600281518110620000f357620000f3620002cf565b6001600160a01b03909216602092830291909101909101526200011681620001aa565b156200014857604051630d697db160e11b81526001600160e01b03196000351660048201526024015b60405180910390fd5b506001600160a01b03928316608052821660a052811660c0521660e05250620002e5915050565b806001600160a01b03163b600003620001a757604051630bfc64a360e21b81526001600160a01b03821660048201526024016200013f565b50565b60008151600003620001be57506000919050565b60005b60018351038110156200024c57600181015b83518110156200024257838181518110620001f257620001f2620002cf565b60200260200101516001600160a01b0316848381518110620002185762000218620002cf565b60200260200101516001600160a01b03160362000239575060019392505050565b600101620001d3565b50600101620001c1565b50600092915050565b80516001600160a01b03811681146200026d57600080fd5b919050565b600080600080608085870312156200028957600080fd5b620002948562000255565b9350620002a46020860162000255565b9250620002b46040860162000255565b9150620002c46060860162000255565b905092959194509250565b634e487b7160e01b600052603260045260246000fd5b60805160a05160c05160e051610c306200033a60003960008181610174015261036301526000818160b0015261027101526000818161010001526103cd0152600081816101dd015261020a0152610c306000f3fe60806040526004361061007f5760003560e01c80639f2e6a0c1161004e5780639f2e6a0c14610162578063d39f567714610196578063de981f1b146101ab578063f89360c2146101cb57610096565b8063014fdae61461009e57806330b53157146100ee578063865e6fd3146101225780638f61eea61461014257610096565b366100965761008c6101ff565b61009461026a565b005b61008c6101ff565b3480156100aa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200160405180910390f35b3480156100fa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b34801561012e57600080fd5b5061009461013d36600461082b565b61029f565b34801561014e57600080fd5b5061009461015d36600461086e565b6102be565b34801561016e57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b3480156101a257600080fd5b50610094610350565b3480156101b757600080fd5b506100d26101c63660046108e3565b6103f1565b3480156101d757600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610268576040517f145be2450000000000000000000000000000000000000000000000000000000081523060048201526024015b60405180910390fd5b565b60006102957f0000000000000000000000000000000000000000000000000000000000000000610485565b9050805160208201f35b6102a761050d565b6102b081610581565b6102ba82826105d3565b5050565b6102c661050d565b6102ce6101ff565b7f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae026338160005b81811015610349578285858381811061030e5761030e610905565b9050602002810190610320919061091b565b825460018101845560009384526020909320909201916103409183610a04565b506001016102f3565b5050505050565b6103586101ff565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146103c8576040517f8f47e7e30000000000000000000000000000000000000000000000000000000081526001600160e01b031960003516600482015260240161025f565b6102687f000000000000000000000000000000000000000000000000000000000000000061068f565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561042857610428610ac4565b60ff1681526020810191909152604001600020546001600160a01b031690508061048057816040517f812281be00000000000000000000000000000000000000000000000000000000815260040161025f9190610ada565b919050565b6060600080836001600160a01b03166000366040516104a5929190610af4565b600060405180830381855af49150503d80600081146104e0576040519150601f19603f3d011682016040523d82523d6000602084013e6104e5565b606091505b5090925090506105048215156001600160e01b031960003516836107d6565b91506104809050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610268576000356001600160e01b03191660016040517f3e523c0000000000000000000000000000000000000000000000000000000000815260040161025f929190610b04565b806001600160a01b03163b6000036105d0576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b038216600482015260240161025f565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561060957610609610ac4565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f81111561066257610662610ac4565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc8190556040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a27f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633805460006060815b838110156107ce57856001600160a01b031685828154811061073457610734610905565b9060005260206000200160405161074b9190610b32565b600060405180830381855af49150503d8060008114610786576040519150601f19603f3d011682016040523d82523d6000602084013e61078b565b606091505b5080935081945050506107c68582815481106107a9576107a9610905565b906000526020600020016107bc90610ba8565b84151590846107d6565b600101610710565b505050505050565b6001600160e01b0319600035168361081657815180156107f7578060208401fd5b50604051638e3eda2b81528160208201528360408201526044601c8201fd5b50505050565b80356010811061048057600080fd5b6000806040838503121561083e57600080fd5b6108478361081c565b915060208301356001600160a01b038116811461086357600080fd5b809150509250929050565b6000806020838503121561088157600080fd5b823567ffffffffffffffff8082111561089957600080fd5b818501915085601f8301126108ad57600080fd5b8135818111156108bc57600080fd5b8660208260051b85010111156108d157600080fd5b60209290920196919550909350505050565b6000602082840312156108f557600080fd5b6108fe8261081c565b9392505050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261093257600080fd5b83018035915067ffffffffffffffff82111561094d57600080fd5b60200191503681900382131561096257600080fd5b9250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c9082168061099357607f821691505b6020821081036109b357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156109ff57600081815260208120601f850160051c810160208610156109e05750805b601f850160051c820191505b818110156107ce578281556001016109ec565b505050565b67ffffffffffffffff831115610a1c57610a1c610969565b610a3083610a2a835461097f565b836109b9565b6000601f841160018114610a645760008515610a4c5750838201355b600019600387901b1c1916600186901b178355610349565b600083815260209020601f19861690835b82811015610a955786850135825560209485019460019092019101610a75565b5086821015610ab25760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610aee57610aee610ac4565b91905290565b8183823760009101908152919050565b6001600160e01b03198316815260408101600b8310610b2557610b25610ac4565b8260208301529392505050565b6000808354610b408161097f565b60018281168015610b585760018114610b6d57610b9c565b60ff1984168752821515830287019450610b9c565b8760005260208060002060005b85811015610b935781548a820152908401908201610b7a565b50505082870194505b50929695505050505050565b6000610bb4825461097f565b82601f821115610bca5783600052602060002090505b546001600160e01b031980821693506004831015610bf25780818460040360031b1b83161693505b50505091905056fea2646970667358221220cfbacdac14165fdb77ab5bf3271cf7989242f716ce34787311f0ee35eb2c809e64736f6c6343000815003300000000000000000000000000000000000000000000 + │ ├─ [629007] → new NotifiedMigrator@0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9 + │ │ └─ ← 3120 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::label(NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], NotifiedMigrator)  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::setAddress(3, 8, NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9])  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], NotifiedMigrator, NotifiedMigrator, 0x000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba3000000000000000000000000056500e6028048db7fca81ac307008a9042605f300000000000000000000000029b2440db4a256b0c1e6d3b4cdcaa68e2440a08f000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f, 6)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, NotifiedMigrator) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] console::log(notifier, ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) [staticcall] + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ │ └─ ← () + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [159700] ronin-mainnet.SlashIndicator::upgradeToAndCall(NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000a0000000000000000000000000000000000000000000000000000000000000002429b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe60000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d03500000000000000000000000000000000000000000000000000000000)  + │ │ ├─ emit Upgraded(implementation: NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9]) + │ │ ├─ [147298] NotifiedMigrator::setCallDatas([0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6, 0x3101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035]) [delegatecall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ └─ ← ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3] + ├─ [6942400] → new NotifiedMigratorUpgrade@0x18d59CE2692A4495ed9B7df3f2BF36F47C41aCB5 + │ └─ ← 34712 bytes of code + ├─ [0] NotifiedMigratorUpgrade::run(11, [])  + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::makePersistent(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] VM::allowCheatcodes(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getCurrentNetwork() [staticcall] + │ │ └─ ← 3 + │ ├─ [1674000] → new LogGenerator@0xd8485A8e87E6A59ae2a4a8DF0e0E250af5efA572 + │ │ └─ ← 8370 bytes of code + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(11) [staticcall] + │ │ └─ ← ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090] + │ ├─ [0] VM::load(ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + │ ├─ [0] VM::load(ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090], 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc) [staticcall] + │ │ └─ ← 0x000000000000000000000000877a15cd0bf1667baab50b4c85fd79125c47b7b3 + │ ├─ [0] GeneralConfig::getContractName(11) [staticcall] + │ │ └─ ← RoninTrustedOrganization + │ ├─ [0] GeneralConfig::getContractFileName(11) [staticcall] + │ │ └─ ← RoninTrustedOrganization.sol:RoninTrustedOrganization + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000007 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(RoninTrustedOrganization.sol:RoninTrustedOrganization) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000206b608060405234801561001057600080fd5b5061204b806100206000396000f3fe608060405234801561001057600080fd5b50600436106101825760003560e01c806396c82e57116100d8578063cc7e6b3b1161008c578063db6693a211610066578063db6693a21461035a578063e75235b81461037a578063f09267c21461038557600080fd5b8063cc7e6b3b146102fb578063d78392f81461030e578063dafae4081461033757600080fd5b8063b505a07c116100bd578063b505a07c146102b8578063b7f67e97146102cb578063b9c36209146102d357600080fd5b806396c82e571461029d578063a85c7d6e146102a557600080fd5b8063562419111161013a5780637c37103c116101145780637c37103c1461026f5780637de5dedd14610282578063903bb3c51461028a57600080fd5b80635624191114610220578063691845a914610249578063708236251461025c57600080fd5b8063150740051161016b57806315074005146101c257806341feed1c146101d7578063520fce621461020057600080fd5b80630e777c06146101875780630ed285df146101ad575b600080fd5b61019a610195366004611aef565b610398565b6040519081526020015b60405180910390f35b6101c06101bb366004611ba9565b610404565b005b6101ca61041a565b6040516101a49190611beb565b61019a6101e5366004611c8f565b6001600160a01b031660009081526005602052604090205490565b61021361020e366004611aef565b610606565b6040516101a49190611caa565b61019a61022e366004611c8f565b6001600160a01b031660009081526007602052604090205490565b61019a610257366004611aef565b6106ca565b61021361026a366004611aef565b61072f565b6101c061027d366004611ce2565b6107f3565b61019a61094a565b61019a610298366004611aef565b610987565b60035461019a565b6101c06102b3366004611aef565b6109ec565b6101c06102c6366004611ba9565b610a96565b60095461019a565b6102e66102e1366004611d33565b610b35565b604080519283526020830191909152016101a4565b610213610309366004611aef565b610b56565b61019a61031c366004611c8f565b6001600160a01b031660009081526006602052604090205490565b61034a610345366004611d55565b610c1a565b60405190151581526020016101a4565b61036d610368366004611c8f565b610c41565b6040516101a49190611d6e565b6001546002546102e6565b61036d610393366004611d55565b610cf9565b6000805b828110156103fd57600760008585848181106103ba576103ba611dbc565b90506020020160208101906103cf9190611c8f565b6001600160a01b031681526020810191909152604001600020546103f39083611de8565b915060010161039c565b5092915050565b61040c610dff565b6104168282610e75565b5050565b60095460609067ffffffffffffffff81111561043857610438611dfb565b60405190808252806020026020018201604052801561049157816020015b6040805160a0810182526000808252602080830182905292820181905260608201819052608082015282526000199092019101816104565790505b5090506000805b825181101561060157600981815481106104b4576104b4611dbc565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104e7576104e7611dbc565b60209081029190910101516001600160a01b039091169052600a80548290811061051357610513611dbc565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061054357610543611dbc565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b818154811061057a5761057a611dbc565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106105aa576105aa611dbc565b6020908102919091018101516001600160a01b0392831660409182015291841660009081526005909152205483518490839081106105ea576105ea611dbc565b602090810291909101015160600152600101610498565b505090565b60608167ffffffffffffffff81111561062157610621611dfb565b60405190808252806020026020018201604052801561064a578160200160208202803683370190505b50905060005b81518110156103fd576005600085858481811061066f5761066f611dbc565b90506020020160208101906106849190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106106b7576106b7611dbc565b6020908102919091010152600101610650565b6000805b828110156103fd57600560008585848181106106ec576106ec611dbc565b90506020020160208101906107019190611c8f565b6001600160a01b031681526020810191909152604001600020546107259083611de8565b91506001016106ce565b60608167ffffffffffffffff81111561074a5761074a611dfb565b604051908082528060200260200182016040528015610773578160200160208202803683370190505b50905060005b81518110156103fd576007600085858481811061079857610798611dbc565b90506020020160208101906107ad9190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107e0576107e0611dbc565b6020908102919091010152600101610779565b600054610100900460ff16158080156108135750600054600160ff909116105b8061082d5750303b15801561082d575060005460ff166001145b6108be576040517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084015b60405180910390fd5b6000805460ff1916600117905580156108e1576000805461ff0019166101001790555b83156108f1576108f18585610e75565b6108fb8383610eea565b50508015610943576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546109649190611e11565b61096e9190611de8565b6109789190611e28565b6109829190611e3b565b905090565b6000805b828110156103fd57600660008585848181106109a9576109a9611dbc565b90506020020160208101906109be9190611c8f565b6001600160a01b031681526020810191909152604001600020546109e29083611de8565b915060010161098b565b6109f4610dff565b6000819003610a16576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610a5857610a50838383818110610a3657610a36611dbc565b9050602002016020810190610a4b9190611c8f565b610f99565b600101610a19565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a78282604051610a8a929190611e5d565b60405180910390a15050565b610a9e610dff565b6000819003610ac0576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610b0357610afb838383818110610ae057610ae0611dbc565b905060a00201803603810190610af69190611ea9565b611308565b600101610ac3565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610a8a929190611f3a565b600080610b40610dff565b610b4a8484610eea565b915091505b9250929050565b60608167ffffffffffffffff811115610b7157610b71611dfb565b604051908082528060200260200182016040528015610b9a578160200160208202803683370190505b50905060005b81518110156103fd5760066000858584818110610bbf57610bbf611dbc565b9050602002016020810190610bd49190611c8f565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610c0757610c07611dbc565b6020908102919091010152600101610ba0565b6000600354600154610c2c9190611e11565b600254610c399084611e11565b101592915050565b6040805160a0810182526000808252602082018190529181018290526060810182905260808101829052905b600954811015610cc657826001600160a01b031660098281548110610c9457610c94611dbc565b6000918252602090912001546001600160a01b031603610cbe57610cb781610cf9565b9392505050565b600101610c6d565b506040517fe57fdbef00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040805160a081018252600080825260208201819052918101829052606081018290526080810191909152600060098381548110610d3957610d39611dbc565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610d8657610d86611dbc565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610db757610db7611dbc565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610e73576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108b5929190611fc3565b565b60005b81811015610eb857610eb0838383818110610e9557610e95611dbc565b905060a00201803603810190610eab9190611ea9565b61162f565b600101610e78565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610a8a929190611f3a565b60008082841115610f35576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b03811660009081526005602052604081205490819003610fde576040516349f748eb60e01b81526001600160a01b03831660048201526024016108b5565b600954600090815b8181101561103557846001600160a01b03166009828154811061100b5761100b611dbc565b6000918252602090912001546001600160a01b03160361102d57809250611035565b600101610fe6565b5082600360008282546110489190611e28565b90915550506001600160a01b038416600090815260086020908152604080832083905560059091528120556009611080600183611e28565b8154811061109057611090611dbc565b600091825260209091200154600980546001600160a01b0390921691849081106110bc576110bc611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b0316021790555060098054806110fb576110fb611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a848154811061113a5761113a611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a61116c600183611e28565b8154811061117c5761117c611dbc565b600091825260209091200154600a80546001600160a01b0390921691849081106111a8576111a8611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a8054806111e7576111e7611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b848154811061122657611226611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b611258600183611e28565b8154811061126857611268611dbc565b600091825260209091200154600b80546001600160a01b03909216918490811061129457611294611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b8054806112d3576112d3611fff565b6000828152602090208101600019908101805473ffffffffffffffffffffffffffffffffffffffff1916905501905550505050565b611311816118eb565b80516001600160a01b03166000908152600560205260408120549081900361135a5781516040516349f748eb60e01b81526001600160a01b0390911660048201526024016108b5565b60095460005b818110156116295783600001516001600160a01b03166009828154811061138957611389611dbc565b6000918252602090912001546001600160a01b0316036116215782600360008282546113b59190611e28565b90915550506060840151600380546000906113d1908490611de8565b9250508190555083602001516001600160a01b0316600a82815481106113f9576113f9611dbc565b6000918252602090912001546001600160a01b0316146114d4576020808501516001600160a01b03166000908152600690915260409020541561144f576040516346da180960e01b815260040160405180910390fd5b60066000600a838154811061146657611466611dbc565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a8054839081106114a5576114a5611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b82815481106114f5576114f5611dbc565b6000918252602090912001546001600160a01b0316146115cf576040808501516001600160a01b031660009081526007602052205415611548576040516346da180960e01b815260040160405180910390fd5b60076000600b838154811061155f5761155f611dbc565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b8054839081106115a0576115a0611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b600101611360565b50505050565b60808101511561166b576040517f94e1670800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611674816118eb565b80516001600160a01b0316600090815260056020526040902054156116d35780516040517fada9a3530000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6020808201516001600160a01b0316600090815260069091526040902054156117395760208101516040517ffebc5eb20000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6040808201516001600160a01b03166000908152600760205220541561179c5760408082015190517f0f69702d0000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af909101805473ffffffffffffffffffffffffffffffffffffffff199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916118e3908490611de8565b909155505050565b8060600151600003611937576040517ffe2371460000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b604080516003808252608082019092526000916020820160608036833701905050905081600001518160008151811061197257611972611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160200151816001815181106119aa576119aa611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160400151816002815181106119e2576119e2611dbc565b60200260200101906001600160a01b031690816001600160a01b031681525050611a0b81611a50565b15610416576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b60008151600003611a6357506000919050565b60005b6001835103811015611ae657600181015b8351811015611add57838181518110611a9257611a92611dbc565b60200260200101516001600160a01b0316848381518110611ab557611ab5611dbc565b60200260200101516001600160a01b031603611ad5575060019392505050565b600101611a77565b50600101611a66565b50600092915050565b60008060208385031215611b0257600080fd5b823567ffffffffffffffff80821115611b1a57600080fd5b818501915085601f830112611b2e57600080fd5b813581811115611b3d57600080fd5b8660208260051b8501011115611b5257600080fd5b60209290920196919550909350505050565b60008083601f840112611b7657600080fd5b50813567ffffffffffffffff811115611b8e57600080fd5b60208301915083602060a083028501011115610b4f57600080fd5b60008060208385031215611bbc57600080fd5b823567ffffffffffffffff811115611bd357600080fd5b611bdf85828601611b64565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b81811015611c6757611c548385516001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b9284019260a09290920191600101611c07565b50909695505050505050565b80356001600160a01b0381168114611c8a57600080fd5b919050565b600060208284031215611ca157600080fd5b610cb782611c73565b6020808252825182820181905260009190848201906040850190845b81811015611c6757835183529284019291840191600101611cc6565b60008060008060608587031215611cf857600080fd5b843567ffffffffffffffff811115611d0f57600080fd5b611d1b87828801611b64565b90989097506020870135966040013595509350505050565b60008060408385031215611d4657600080fd5b50508035926020909101359150565b600060208284031215611d6757600080fd5b5035919050565b60a08101611db682846001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b92915050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b80820180821115611db657611db6611dd2565b634e487b7160e01b600052604160045260246000fd5b8082028115828204841417611db657611db6611dd2565b81810381811115611db657611db6611dd2565b600082611e5857634e487b7160e01b600052601260045260246000fd5b500490565b60208082528181018390526000908460408401835b86811015611e9e576001600160a01b03611e8b84611c73565b1682529183019190830190600101611e72565b509695505050505050565b600060a08284031215611ebb57600080fd5b60405160a0810181811067ffffffffffffffff82111715611eec57634e487b7160e01b600052604160045260246000fd5b604052611ef883611c73565b8152611f0660208401611c73565b6020820152611f1760408401611c73565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b87811015611fb6576001600160a01b0380611f6a84611c73565b16845280611f79878501611c73565b168685015280611f8a868501611c73565b168486015250606082810135908401526080808301359084015260a09283019290910190600101611f50565b5090979650505050505050565b6001600160e01b03198316815260408101600b8310611ff257634e487b7160e01b600052602160045260246000fd5b8260208301529392505050565b634e487b7160e01b600052603160045260246000fdfea26469706673582212203322efc2dc5067897fa0ebf0e71848432953790436ddeae3b329f243ac407aea64736f6c63430008150033000000000000000000000000000000000000000000 + │ ├─ [1655136] → new RoninTrustedOrganization@0x3BB898B4Bbe24f68A4e9bE46cFE72D1787FD74F4 + │ │ └─ ← 8267 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninTrustedOrganization: [0x3BB898B4Bbe24f68A4e9bE46cFE72D1787FD74F4], RoninTrustedOrganization, RoninTrustedOrganizationLogic, 0x, 7)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, RoninTrustedOrganizationLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + │ ├─ [0] GeneralConfig::getContractName(8) [staticcall] + │ │ └─ ← NotifiedMigrator + │ ├─ [0] GeneralConfig::getContractFileName(8) [staticcall] + │ │ └─ ← NotifiedMigrator.sol:NotifiedMigrator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000008 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(NotifiedMigrator.sol:NotifiedMigrator) [staticcall] + │ │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000f6a61010060405260405162000f6a38038062000f6a833981016040819052620000279162000272565b83838362000035816200016f565b62000040826200016f565b6200004b836200016f565b60408051600380825260808201909252600091602082016060803683370190505090508381600081518110620000855762000085620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508281600181518110620000bc57620000bc620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508181600281518110620000f357620000f3620002cf565b6001600160a01b03909216602092830291909101909101526200011681620001aa565b156200014857604051630d697db160e11b81526001600160e01b03196000351660048201526024015b60405180910390fd5b506001600160a01b03928316608052821660a052811660c0521660e05250620002e5915050565b806001600160a01b03163b600003620001a757604051630bfc64a360e21b81526001600160a01b03821660048201526024016200013f565b50565b60008151600003620001be57506000919050565b60005b60018351038110156200024c57600181015b83518110156200024257838181518110620001f257620001f2620002cf565b60200260200101516001600160a01b0316848381518110620002185762000218620002cf565b60200260200101516001600160a01b03160362000239575060019392505050565b600101620001d3565b50600101620001c1565b50600092915050565b80516001600160a01b03811681146200026d57600080fd5b919050565b600080600080608085870312156200028957600080fd5b620002948562000255565b9350620002a46020860162000255565b9250620002b46040860162000255565b9150620002c46060860162000255565b905092959194509250565b634e487b7160e01b600052603260045260246000fd5b60805160a05160c05160e051610c306200033a60003960008181610174015261036301526000818160b0015261027101526000818161010001526103cd0152600081816101dd015261020a0152610c306000f3fe60806040526004361061007f5760003560e01c80639f2e6a0c1161004e5780639f2e6a0c14610162578063d39f567714610196578063de981f1b146101ab578063f89360c2146101cb57610096565b8063014fdae61461009e57806330b53157146100ee578063865e6fd3146101225780638f61eea61461014257610096565b366100965761008c6101ff565b61009461026a565b005b61008c6101ff565b3480156100aa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200160405180910390f35b3480156100fa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b34801561012e57600080fd5b5061009461013d36600461082b565b61029f565b34801561014e57600080fd5b5061009461015d36600461086e565b6102be565b34801561016e57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b3480156101a257600080fd5b50610094610350565b3480156101b757600080fd5b506100d26101c63660046108e3565b6103f1565b3480156101d757600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610268576040517f145be2450000000000000000000000000000000000000000000000000000000081523060048201526024015b60405180910390fd5b565b60006102957f0000000000000000000000000000000000000000000000000000000000000000610485565b9050805160208201f35b6102a761050d565b6102b081610581565b6102ba82826105d3565b5050565b6102c661050d565b6102ce6101ff565b7f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae026338160005b81811015610349578285858381811061030e5761030e610905565b9050602002810190610320919061091b565b825460018101845560009384526020909320909201916103409183610a04565b506001016102f3565b5050505050565b6103586101ff565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146103c8576040517f8f47e7e30000000000000000000000000000000000000000000000000000000081526001600160e01b031960003516600482015260240161025f565b6102687f000000000000000000000000000000000000000000000000000000000000000061068f565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561042857610428610ac4565b60ff1681526020810191909152604001600020546001600160a01b031690508061048057816040517f812281be00000000000000000000000000000000000000000000000000000000815260040161025f9190610ada565b919050565b6060600080836001600160a01b03166000366040516104a5929190610af4565b600060405180830381855af49150503d80600081146104e0576040519150601f19603f3d011682016040523d82523d6000602084013e6104e5565b606091505b5090925090506105048215156001600160e01b031960003516836107d6565b91506104809050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610268576000356001600160e01b03191660016040517f3e523c0000000000000000000000000000000000000000000000000000000000815260040161025f929190610b04565b806001600160a01b03163b6000036105d0576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b038216600482015260240161025f565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561060957610609610ac4565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f81111561066257610662610ac4565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc8190556040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a27f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633805460006060815b838110156107ce57856001600160a01b031685828154811061073457610734610905565b9060005260206000200160405161074b9190610b32565b600060405180830381855af49150503d8060008114610786576040519150601f19603f3d011682016040523d82523d6000602084013e61078b565b606091505b5080935081945050506107c68582815481106107a9576107a9610905565b906000526020600020016107bc90610ba8565b84151590846107d6565b600101610710565b505050505050565b6001600160e01b0319600035168361081657815180156107f7578060208401fd5b50604051638e3eda2b81528160208201528360408201526044601c8201fd5b50505050565b80356010811061048057600080fd5b6000806040838503121561083e57600080fd5b6108478361081c565b915060208301356001600160a01b038116811461086357600080fd5b809150509250929050565b6000806020838503121561088157600080fd5b823567ffffffffffffffff8082111561089957600080fd5b818501915085601f8301126108ad57600080fd5b8135818111156108bc57600080fd5b8660208260051b85010111156108d157600080fd5b60209290920196919550909350505050565b6000602082840312156108f557600080fd5b6108fe8261081c565b9392505050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261093257600080fd5b83018035915067ffffffffffffffff82111561094d57600080fd5b60200191503681900382131561096257600080fd5b9250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c9082168061099357607f821691505b6020821081036109b357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156109ff57600081815260208120601f850160051c810160208610156109e05750805b601f850160051c820191505b818110156107ce578281556001016109ec565b505050565b67ffffffffffffffff831115610a1c57610a1c610969565b610a3083610a2a835461097f565b836109b9565b6000601f841160018114610a645760008515610a4c5750838201355b600019600387901b1c1916600186901b178355610349565b600083815260209020601f19861690835b82811015610a955786850135825560209485019460019092019101610a75565b5086821015610ab25760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610aee57610aee610ac4565b91905290565b8183823760009101908152919050565b6001600160e01b03198316815260408101600b8310610b2557610b25610ac4565b8260208301529392505050565b6000808354610b408161097f565b60018281168015610b585760018114610b6d57610b9c565b60ff1984168752821515830287019450610b9c565b8760005260208060002060005b85811015610b935781548a820152908401908201610b7a565b50505082870194505b50929695505050505050565b6000610bb4825461097f565b82601f821115610bca5783600052602060002090505b546001600160e01b031980821693506004831015610bf25780818460040360031b1b83161693505b50505091905056fea2646970667358221220cfbacdac14165fdb77ab5bf3271cf7989242f716ce34787311f0ee35eb2c809e64736f6c6343000815003300000000000000000000000000000000000000000000 + │ ├─ [629007] → new NotifiedMigrator@0x117814AF22Cb83D8Ad6e8489e9477d28265bc105 + │ │ └─ ← 3120 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::label(NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105], NotifiedMigrator)  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::setAddress(3, 8, NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105])  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105], NotifiedMigrator, NotifiedMigrator, 0x00000000000000000000000098d0230884448b3e2f09a177433d60fb1e19c090000000000000000000000000877a15cd0bf1667baab50b4c85fd79125c47b7b30000000000000000000000003bb898b4bbe24f68a4e9be46cfe72d1787fd74f4000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f, 8)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, NotifiedMigrator) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] console::log(notifier, ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) [staticcall] + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ │ └─ ← () + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [13239] ronin-mainnet.RoninTrustedOrganization::upgradeToAndCall(NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000)  + │ │ ├─ emit Upgraded(implementation: NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105]) + │ │ ├─ [1446] NotifiedMigrator::setCallDatas([]) [delegatecall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ └─ ← ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090] + ├─ [6942400] → new NotifiedMigratorUpgrade@0x856e75e9c0Da547F9753c17746D6cc139b668e5c + │ └─ ← 34712 bytes of code + ├─ [0] NotifiedMigratorUpgrade::run(2, [0x5cd8a76b])  + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::makePersistent(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] VM::allowCheatcodes(GeneralConfig: [0xd78242CE1dCFF75B216544700Dc0357BB5728c6D])  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getCurrentNetwork() [staticcall] + │ │ └─ ← 3 + │ ├─ [1674000] → new LogGenerator@0x6aBde7ca59972309106AFda3744B1f80f3B144A9 + │ │ └─ ← 8370 bytes of code + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(2) [staticcall] + │ │ └─ ← ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2] + │ ├─ [0] VM::load(ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + │ ├─ [0] VM::load(ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2], 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc) [staticcall] + │ │ └─ ← 0x000000000000000000000000fca143fe2751a992e8cff2eb5d64eda809049295 + │ ├─ [0] GeneralConfig::getContractName(2) [staticcall] + │ │ └─ ← BridgeTracking + │ ├─ [0] GeneralConfig::getContractFileName(2) [staticcall] + │ │ └─ ← BridgeTracking.sol:BridgeTracking + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000009 + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(BridgeTracking.sol:BridgeTracking) [staticcall] + │ │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001cd8608060405234801561001057600080fd5b5061001961001e565b6100eb565b600154600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60015460ff600160a01b909104811610156100e9576001805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611bde806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100d45760003560e01c8063d25ed4c611610081578063e7ec7b391161005b578063e7ec7b39146101a6578063f67e8152146101b9578063f84bd121146101d957600080fd5b8063d25ed4c614610155578063de981f1b14610168578063e2a75f361461019357600080fd5b80635cd8a76b116100b25780635cd8a76b14610127578063865e6fd31461012f578063c7c4fea91461014257600080fd5b80631794bb3c146100d9578063229f88ea146100ee5780634ac0bcda14610101575b600080fd5b6100ec6100e736600461163b565b6101e1565b005b6100ec6100fc36600461168b565b610340565b61011461010f3660046116b5565b6104e8565b6040519081526020015b60405180910390f35b6100ec610506565b6100ec61013d3660046116f4565b61066a565b6100ec610150366004611720565b610689565b610114610163366004611760565b610a9f565b61017b610176366004611779565b610ad4565b6040516001600160a01b03909116815260200161011e565b6101146101a1366004611760565b610b63565b6100ec6101b4366004611794565b610b8d565b6101cc6101c73660046117d4565b610d1e565b60405161011e919061188e565b600254610114565b600154600160a81b900460ff1615808015610207575060018054600160a01b900460ff16105b806102275750303b158015610227575060018054600160a01b900460ff16145b61028f5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b600180547fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff16600160a01b17905580156102d7576001805460ff60a81b1916600160a81b1790555b6102e2600285610d65565b6102ed600884610d65565b6002829055801561033a576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15b50505050565b600261034b81610e16565b610353610e7e565b6000600a600085600281111561036b5761036b6118a1565b600281111561037c5761037c6118a1565b815260200190815260200160002060008481526020019081526020016000209050806000015460000361033a576103b1610e8c565b60006103bd6008610ad4565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156103fa573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061041e91906118b7565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928892849260ff1990921691849081111561047b5761047b6118a1565b02179055506001808201869055830160005b81548110156104d0576104c888888484815481106104ad576104ad6118d0565b6000918252602090912001546001600160a01b03168761112e565b60010161048d565b506104df6001850160006115ae565b50505050505050565b60006104fd83836104f8866112bb565b6113e1565b90505b92915050565b600154600290600160a81b900460ff16158015610531575060015460ff808316600160a01b90920416105b6105945760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610286565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790556000546105d4906002906001600160a01b0316610d65565b6001546105ec906008906001600160a01b0316610d65565b6000805473ffffffffffffffffffffffffffffffffffffffff19169055600180547fffffffffffffffffffff00ff000000000000000000000000000000000000000016905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b610672611437565b61067b816114ab565b6106858282610d65565b5050565b600261069481610e16565b61069c610e7e565b60006106a86008610ad4565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106e5573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061070991906118b7565b9050610713610e8c565b6000600a600087600281111561072b5761072b6118a1565b600281111561073c5761073c6118a1565b81526020019081526020016000206000868152602001908152602001600020905080600001546000036107ab5760019081018054918201815560009081526020902001805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0385161790555061033a565b6107b78686868561112e565b600b54828110156104df57600b8381556000906107d390610ad4565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa158015610810573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526108389190810190611907565b9050600061084683836114fa565b9050600061085384610b63565b9050600061086085610a9f565b9050600061086e600c610ad4565b9050600080826001600160a01b0316878786888c6040516024016108969594939291906119cc565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff16634dca592560e01b179052516108e09190611a65565b6000604051808303816000865af19150503d806000811461091d576040519150601f19603f3d011682016040523d82523d6000602084013e610922565b606091505b50915091508161097957604051634dca592560e01b906001600160a01b038516907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610970908590611a81565b60405180910390a35b6000610985600d610ad4565b9050806001600160a01b0316888887898d6040516024016109aa9594939291906119cc565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166335e5b7eb60e11b179052516109f49190611a65565b6000604051808303816000865af19150503d8060008114610a31576040519150601f19603f3d011682016040523d82523d6000602084013e610a36565b606091505b50909350915082610a8e576040516335e5b7eb60e11b906001600160a01b038316907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610a85908690611a81565b60405180910390a35b505050505050505050505050505050565b600081815260096020526040902060010154610aba826112bb565b15610acf57600654610acc9082611aca565b90505b919050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610b0b57610b0b6118a1565b60ff1681526020810191909152604001600020546001600160a01b0316905080610acf57816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016102869190611af1565b600081815260096020526040902054610b7b826112bb565b15610acf57600454610acc9082611aca565b600154600390600160a81b900460ff16158015610bb8575060015460ff808316600160a01b90920416105b610c1b5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610286565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055610c4e600b85610d65565b610c59600c84610d65565b610c64600d83610d65565b6001610c706008610ad4565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610cad573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cd191906118b7565b610cdb9190611aff565b600b556001805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610331565b6060610d5d848484808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152506114fa92505050565b949350505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610d9b57610d9b6118a1565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115610de957610de96118a1565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610e1f81610ad4565b6001600160a01b0316336001600160a01b031614610e7b576000356001600160e01b03191681336040517f8383e63400000000000000000000000000000000000000000000000000000000815260040161028693929190611b12565b50565b600254431015610e8a57005b565b6000610e986008610ad4565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015610ee2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f0691906118b7565b9050806003600001541015610685576000826001600160a01b031663468c96ae6003600001546001610f389190611aca565b6040518263ffffffff1660e01b8152600401610f5691815260200190565b6040805180830381865afa158015610f72573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f969190611b47565b60038490556000818152600960205260408120600454815493955090935091839190610fc3908490611aca565b9091555050600654600182018054600090610fdf908490611aca565b90915550600090505b60085481101561106f5760088054600091908390811061100a5761100a6118d0565b60009182526020808320909101546001600160a01b031680835260078252604080842054600288019093528320805491945091929061104a908490611aca565b90915550506001600160a01b0316600090815260076020526040812055600101610fe8565b5060005b60045481101561110157600060036001018281548110611095576110956118d0565b6000918252602082206002918202018054909350600a91839160ff16908111156110c1576110c16118a1565b60028111156110d2576110d26118a1565b815260208082019290925260409081016000908120600195860154825290925290206003018590555001611073565b5061110e600460006115cc565b600060058181556006829055906111266008826115ae565b505050505050565b6000600a6000866002811115611146576111466118a1565b6002811115611157576111576118a1565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff161561119a575061033a565b6001600160a01b03831660009081526002820160205260408120805460ff19166001179055600382015490819003611274576001600160a01b038416600090815260076020526040812054900361124457600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee301805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0386161790555b6006805460019081019091556001600160a01b038516600090815260076020526040902080549091019055611126565b82810361112657600090815260096020908152604080832060018082018054820190556001600160a01b039790971684526002019091529020805490930190925550505050565b6000806112c86008610ad4565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015611312573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061133691906118b7565b9050600080836001600160a01b031663468c96ae600360000154600161135c9190611aca565b6040518263ffffffff1660e01b815260040161137a91815260200190565b6040805180830381865afa158015611396573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113ba9190611b47565b915091508180156113ca57508086145b80156113d7575060035483115b9695505050505050565b60008381526009602090815260408083206001600160a01b03861684526002019091529020548115611430576001600160a01b038316600090815260076020526040902054610d5d9082611aca565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610e8a576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610286929190611b7a565b806001600160a01b03163b600003610e7b576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610286565b80516060908067ffffffffffffffff811115611518576115186118e6565b604051908082528060200260200182016040528015611541578160200160208202803683370190505b509150600061154f856112bb565b905060005b828110156115a55761158086868381518110611572576115726118d0565b6020026020010151846113e1565b848281518110611592576115926118d0565b6020908102919091010152600101611554565b50505092915050565b5080546000825590600052602060002090810190610e7b91906115ed565b5080546000825560020290600052602060002090810190610e7b9190611606565b5b8082111561160257600081556001016115ee565b5090565b5b8082111561160257805460ff1916815560006001820155600201611607565b6001600160a01b0381168114610e7b57600080fd5b60008060006060848603121561165057600080fd5b833561165b81611626565b9250602084013561166b81611626565b929592945050506040919091013590565b803560038110610acf57600080fd5b6000806040838503121561169e57600080fd5b6116a78361167c565b946020939093013593505050565b600080604083850312156116c857600080fd5b8235915060208301356116da81611626565b809150509250929050565b803560108110610acf57600080fd5b6000806040838503121561170757600080fd5b611710836116e5565b915060208301356116da81611626565b60008060006060848603121561173557600080fd5b61173e8461167c565b925060208401359150604084013561175581611626565b809150509250925092565b60006020828403121561177257600080fd5b5035919050565b60006020828403121561178b57600080fd5b6104fd826116e5565b6000806000606084860312156117a957600080fd5b83356117b481611626565b925060208401356117c481611626565b9150604084013561175581611626565b6000806000604084860312156117e957600080fd5b83359250602084013567ffffffffffffffff8082111561180857600080fd5b818601915086601f83011261181c57600080fd5b81358181111561182b57600080fd5b8760208260051b850101111561184057600080fd5b6020830194508093505050509250925092565b600081518084526020808501945080840160005b8381101561188357815187529582019590820190600101611867565b509495945050505050565b6020815260006104fd6020830184611853565b634e487b7160e01b600052602160045260246000fd5b6000602082840312156118c957600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b8051610acf81611626565b6000602080838503121561191a57600080fd5b825167ffffffffffffffff8082111561193257600080fd5b818501915085601f83011261194657600080fd5b815181811115611958576119586118e6565b8060051b604051601f19603f8301168101818110858211171561197d5761197d6118e6565b60405291825284820192508381018501918883111561199b57600080fd5b938501935b828510156119c0576119b1856118fc565b845293850193928501926119a0565b98975050505050505050565b60a0808252865190820181905260009060209060c0840190828a01845b82811015611a0e5781516001600160a01b0316845292840192908401906001016119e9565b50505083810382850152611a228189611853565b6040850197909752505050606081019290925260809091015292915050565b60005b83811015611a5c578181015183820152602001611a44565b50506000910152565b60008251611a77818460208701611a41565b9190910192915050565b6020815260008251806020840152611aa0816040850160208701611a41565b601f01601f19169190910160400192915050565b634e487b7160e01b600052601160045260246000fd5b8082018082111561050057610500611ab4565b60108110611aed57611aed6118a1565b9052565b602081016105008284611add565b8181038181111561050057610500611ab4565b6001600160e01b03198416815260608101611b306020830185611add565b6001600160a01b0383166040830152949350505050565b60008060408385031215611b5a57600080fd5b82518015158114611b6a57600080fd5b6020939093015192949293505050565b6001600160e01b03198316815260408101600b8310611b9b57611b9b6118a1565b826020830152939250505056fea264697066735822122004c877371e53db2fd08f7e9d70eb710681ae253c9bb4de234c4f667655c9304764736f6c634300081500330000000000000000 + │ ├─ [1451904] → new BridgeTracking@0x6901F7206A34E441Ac5020b5fB53598A65547A23 + │ │ ├─ emit Initialized(version: 255) + │ │ └─ ← 7134 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, BridgeTracking: [0x6901F7206A34E441Ac5020b5fB53598A65547A23], BridgeTracking, BridgeTrackingLogic, 0x, 9)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, BridgeTrackingLogic) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + │ ├─ [0] GeneralConfig::getContractName(8) [staticcall] + │ │ └─ ← NotifiedMigrator + │ ├─ [0] GeneralConfig::getContractFileName(8) [staticcall] + │ │ └─ ← NotifiedMigrator.sol:NotifiedMigrator + │ ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000000a + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ │ └─ ← () + │ ├─ [0] VM::getCode(NotifiedMigrator.sol:NotifiedMigrator) [staticcall] + │ │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000f6a61010060405260405162000f6a38038062000f6a833981016040819052620000279162000272565b83838362000035816200016f565b62000040826200016f565b6200004b836200016f565b60408051600380825260808201909252600091602082016060803683370190505090508381600081518110620000855762000085620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508281600181518110620000bc57620000bc620002cf565b60200260200101906001600160a01b031690816001600160a01b0316815250508181600281518110620000f357620000f3620002cf565b6001600160a01b03909216602092830291909101909101526200011681620001aa565b156200014857604051630d697db160e11b81526001600160e01b03196000351660048201526024015b60405180910390fd5b506001600160a01b03928316608052821660a052811660c0521660e05250620002e5915050565b806001600160a01b03163b600003620001a757604051630bfc64a360e21b81526001600160a01b03821660048201526024016200013f565b50565b60008151600003620001be57506000919050565b60005b60018351038110156200024c57600181015b83518110156200024257838181518110620001f257620001f2620002cf565b60200260200101516001600160a01b0316848381518110620002185762000218620002cf565b60200260200101516001600160a01b03160362000239575060019392505050565b600101620001d3565b50600101620001c1565b50600092915050565b80516001600160a01b03811681146200026d57600080fd5b919050565b600080600080608085870312156200028957600080fd5b620002948562000255565b9350620002a46020860162000255565b9250620002b46040860162000255565b9150620002c46060860162000255565b905092959194509250565b634e487b7160e01b600052603260045260246000fd5b60805160a05160c05160e051610c306200033a60003960008181610174015261036301526000818160b0015261027101526000818161010001526103cd0152600081816101dd015261020a0152610c306000f3fe60806040526004361061007f5760003560e01c80639f2e6a0c1161004e5780639f2e6a0c14610162578063d39f567714610196578063de981f1b146101ab578063f89360c2146101cb57610096565b8063014fdae61461009e57806330b53157146100ee578063865e6fd3146101225780638f61eea61461014257610096565b366100965761008c6101ff565b61009461026a565b005b61008c6101ff565b3480156100aa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b03909116815260200160405180910390f35b3480156100fa57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b34801561012e57600080fd5b5061009461013d36600461082b565b61029f565b34801561014e57600080fd5b5061009461015d36600461086e565b6102be565b34801561016e57600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b3480156101a257600080fd5b50610094610350565b3480156101b757600080fd5b506100d26101c63660046108e3565b6103f1565b3480156101d757600080fd5b506100d27f000000000000000000000000000000000000000000000000000000000000000081565b306001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001614610268576040517f145be2450000000000000000000000000000000000000000000000000000000081523060048201526024015b60405180910390fd5b565b60006102957f0000000000000000000000000000000000000000000000000000000000000000610485565b9050805160208201f35b6102a761050d565b6102b081610581565b6102ba82826105d3565b5050565b6102c661050d565b6102ce6101ff565b7f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae026338160005b81811015610349578285858381811061030e5761030e610905565b9050602002810190610320919061091b565b825460018101845560009384526020909320909201916103409183610a04565b506001016102f3565b5050505050565b6103586101ff565b336001600160a01b037f000000000000000000000000000000000000000000000000000000000000000016146103c8576040517f8f47e7e30000000000000000000000000000000000000000000000000000000081526001600160e01b031960003516600482015260240161025f565b6102687f000000000000000000000000000000000000000000000000000000000000000061068f565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561042857610428610ac4565b60ff1681526020810191909152604001600020546001600160a01b031690508061048057816040517f812281be00000000000000000000000000000000000000000000000000000000815260040161025f9190610ada565b919050565b6060600080836001600160a01b03166000366040516104a5929190610af4565b600060405180830381855af49150503d80600081146104e0576040519150601f19603f3d011682016040523d82523d6000602084013e6104e5565b606091505b5090925090506105048215156001600160e01b031960003516836107d6565b91506104809050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610268576000356001600160e01b03191660016040517f3e523c0000000000000000000000000000000000000000000000000000000000815260040161025f929190610b04565b806001600160a01b03163b6000036105d0576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b038216600482015260240161025f565b50565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561060957610609610ac4565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f81111561066257610662610ac4565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7f360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc8190556040516001600160a01b038216907fbc7cd75a20ee27fd9adebab32041f755214dbc6bffa90cc0225b39da2e5c2d3b90600090a27f330d87be17f5b23d41285647e0e9b0e7124a778feb3f952590ed6a023ae02633805460006060815b838110156107ce57856001600160a01b031685828154811061073457610734610905565b9060005260206000200160405161074b9190610b32565b600060405180830381855af49150503d8060008114610786576040519150601f19603f3d011682016040523d82523d6000602084013e61078b565b606091505b5080935081945050506107c68582815481106107a9576107a9610905565b906000526020600020016107bc90610ba8565b84151590846107d6565b600101610710565b505050505050565b6001600160e01b0319600035168361081657815180156107f7578060208401fd5b50604051638e3eda2b81528160208201528360408201526044601c8201fd5b50505050565b80356010811061048057600080fd5b6000806040838503121561083e57600080fd5b6108478361081c565b915060208301356001600160a01b038116811461086357600080fd5b809150509250929050565b6000806020838503121561088157600080fd5b823567ffffffffffffffff8082111561089957600080fd5b818501915085601f8301126108ad57600080fd5b8135818111156108bc57600080fd5b8660208260051b85010111156108d157600080fd5b60209290920196919550909350505050565b6000602082840312156108f557600080fd5b6108fe8261081c565b9392505050565b634e487b7160e01b600052603260045260246000fd5b6000808335601e1984360301811261093257600080fd5b83018035915067ffffffffffffffff82111561094d57600080fd5b60200191503681900382131561096257600080fd5b9250929050565b634e487b7160e01b600052604160045260246000fd5b600181811c9082168061099357607f821691505b6020821081036109b357634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156109ff57600081815260208120601f850160051c810160208610156109e05750805b601f850160051c820191505b818110156107ce578281556001016109ec565b505050565b67ffffffffffffffff831115610a1c57610a1c610969565b610a3083610a2a835461097f565b836109b9565b6000601f841160018114610a645760008515610a4c5750838201355b600019600387901b1c1916600186901b178355610349565b600083815260209020601f19861690835b82811015610a955786850135825560209485019460019092019101610a75565b5086821015610ab25760001960f88860031b161c19848701351681555b505060018560011b0183555050505050565b634e487b7160e01b600052602160045260246000fd5b6020810160108310610aee57610aee610ac4565b91905290565b8183823760009101908152919050565b6001600160e01b03198316815260408101600b8310610b2557610b25610ac4565b8260208301529392505050565b6000808354610b408161097f565b60018281168015610b585760018114610b6d57610b9c565b60ff1984168752821515830287019450610b9c565b8760005260208060002060005b85811015610b935781548a820152908401908201610b7a565b50505082870194505b50929695505050505050565b6000610bb4825461097f565b82601f821115610bca5783600052602060002090505b546001600160e01b031980821693506004831015610bf25780818460040360031b1b83161693505b50505091905056fea2646970667358221220cfbacdac14165fdb77ab5bf3271cf7989242f716ce34787311f0ee35eb2c809e64736f6c6343000815003300000000000000000000000000000000000000000000 + │ ├─ [629007] → new NotifiedMigrator@0x684c903c66D69777377f0945052160C9f778d689 + │ │ └─ ← 3120 bytes of code + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ ├─ [0] VM::label(NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689], NotifiedMigrator)  + │ │ └─ ← () + │ ├─ [0] GeneralConfig::setAddress(3, 8, NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689])  + │ │ └─ ← () + │ ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689], NotifiedMigrator, NotifiedMigrator, 0x0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000fca143fe2751a992e8cff2eb5d64eda8090492950000000000000000000000006901f7206a34e441ac5020b5fb53598a65547a23000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f, 10)  + │ │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ │ └─ ← (false, false) + │ │ ├─ [0] console::log(Skipping artifact generation for:, NotifiedMigrator) [staticcall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] console::log(notifier, ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) [staticcall] + │ │ └─ ← () + │ ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ │ └─ ← () + │ ├─ [0] VM::resumeGasMetering()  + │ │ └─ ← () + │ ├─ [55807] ronin-mainnet.BridgeTracking::upgradeToAndCall(NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000045cd8a76b00000000000000000000000000000000000000000000000000000000)  + │ │ ├─ emit Upgraded(implementation: NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689]) + │ │ ├─ [43786] NotifiedMigrator::setCallDatas([0x5cd8a76b]) [delegatecall] + │ │ │ └─ ← () + │ │ └─ ← () + │ ├─ [0] VM::pauseGasMetering()  + │ │ └─ ← () + │ └─ ← ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2] + ├─ [0] VM::warp(1696244594 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139076 [2.813e7])  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::numberOfBlocksInEpoch() [staticcall] + │ ├─ [0] RoninValidatorSetTimedMigrator::numberOfBlocksInEpoch() [delegatecall] + │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::numberOfBlocksInEpoch() [delegatecall] + │ │ │ └─ ← 200 + │ │ └─ ← 200 + │ └─ ← 200 + ├─ [0] VM::warp(1696330994 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139199 [2.813e7])  + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::wrapUpEpoch()  + │ ├─ [0] RoninValidatorSetTimedMigrator::wrapUpEpoch() [delegatecall] + │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriod() [staticcall] + │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::currentPeriod() [delegatecall] + │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::currentPeriod() [delegatecall] + │ │ │ │ │ └─ ← 19632 [1.963e4] + │ │ │ │ └─ ← 19632 [1.963e4] + │ │ │ └─ ← 19632 [1.963e4] + │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::wrapUpEpoch() [delegatecall] + │ │ │ ├─ [0] ronin-mainnet.BridgeTracking::totalBallots(19632 [1.963e4]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::totalBallots(19632 [1.963e4]) [delegatecall] + │ │ │ │ │ ├─ [0] 0xFCA143FE2751A992e8Cff2eB5D64Eda809049295::totalBallots(19632 [1.963e4]) [delegatecall] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::epochOf(28139199 [2.813e7]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::tryGetPeriodOfEpoch(140697 [1.406e5]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000580 + │ │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000580 + │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000580 + │ │ │ ├─ [0] ronin-mainnet.BridgeTracking::totalVotes(19632 [1.963e4]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::totalVotes(19632 [1.963e4]) [delegatecall] + │ │ │ │ │ ├─ [0] 0xFCA143FE2751A992e8Cff2eB5D64Eda809049295::totalVotes(19632 [1.963e4]) [delegatecall] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::epochOf(28139199 [2.813e7]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::tryGetPeriodOfEpoch(140697 [1.406e5]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000040 + │ │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000040 + │ │ │ │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000040 + │ │ │ ├─ [0] ronin-mainnet.BridgeTracking::getManyTotalBallots(19632 [1.963e4], [0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, 0xD9d5b3E58fa693B468a20C716793B18A1195380a, 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, 0x4a4217d8751a027D853785824eF40522c512A3Fe, 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, 0x32cB6da260726BB2192c4085B857aFD945A215Cb, 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, 0x332253265e36689D9830E57112CD1aaDB1A773f9, 0x66225AcC78Be789C57a11C9a18F051C779d678B5, 0xE795F18F2F5DF5a666994e839b98263Dba86C902, 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99, 0x063105D0E7215B703909a7274FE38393302F3134, 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::getManyTotalBallots(19632 [1.963e4], [0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, 0xD9d5b3E58fa693B468a20C716793B18A1195380a, 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, 0x4a4217d8751a027D853785824eF40522c512A3Fe, 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, 0x32cB6da260726BB2192c4085B857aFD945A215Cb, 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, 0x332253265e36689D9830E57112CD1aaDB1A773f9, 0x66225AcC78Be789C57a11C9a18F051C779d678B5, 0xE795F18F2F5DF5a666994e839b98263Dba86C902, 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99, 0x063105D0E7215B703909a7274FE38393302F3134, 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E]) [delegatecall] + │ │ │ │ │ ├─ [0] 0xFCA143FE2751A992e8Cff2eB5D64Eda809049295::getManyTotalBallots(19632 [1.963e4], [0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, 0xD9d5b3E58fa693B468a20C716793B18A1195380a, 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, 0x4a4217d8751a027D853785824eF40522c512A3Fe, 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, 0x32cB6da260726BB2192c4085B857aFD945A215Cb, 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, 0x332253265e36689D9830E57112CD1aaDB1A773f9, 0x66225AcC78Be789C57a11C9a18F051C779d678B5, 0xE795F18F2F5DF5a666994e839b98263Dba86C902, 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99, 0x063105D0E7215B703909a7274FE38393302F3134, 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E]) [delegatecall] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::epochOf(28139199 [2.813e7]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::epochOf(28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ │ └─ ← 140696 [1.406e5] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::tryGetPeriodOfEpoch(140697 [1.406e5]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::tryGetPeriodOfEpoch(140697 [1.406e5]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ │ └─ ← false, 0 + │ │ │ │ │ │ └─ ← [64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64] + │ │ │ │ │ └─ ← [64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64] + │ │ │ │ └─ ← [64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64] + │ │ │ ├─ [0] ronin-mainnet.SlashIndicator::getBridgeOperatorSlashingConfigs() [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::getBridgeOperatorSlashingConfigs() [delegatecall] + │ │ │ │ │ ├─ [0] 0x056500E6028048dB7FCA81Ac307008A9042605f3::getBridgeOperatorSlashingConfigs() [delegatecall] + │ │ │ │ │ │ └─ ← 1000, 3000, 0, 50 + │ │ │ │ │ └─ ← 1000, 3000, 0, 50 + │ │ │ │ └─ ← 1000, 3000, 0, 50 + │ │ │ ├─ [0] 0xab4BC28137a9535838a27fBE59044F6eE3D68428::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, bridgeOperator: 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, recipientAddr: 0xab4BC28137a9535838a27fBE59044F6eE3D68428, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xab4BC28137a9535838a27fBE59044F6eE3D68428::fallback{value: 169807176758141357622}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169807176758141357622 [1.698e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, recipient: 0xab4BC28137a9535838a27fBE59044F6eE3D68428, amount: 169807176758141357622 [1.698e20]) + │ │ │ ├─ [0] 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x9B959D27840a31988410Ee69991BCF0110D61F02, bridgeOperator: 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, recipientAddr: 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4::fallback{value: 118963578955331395475}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 118963578955331395475 [1.189e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x9B959D27840a31988410Ee69991BCF0110D61F02, recipient: 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4, amount: 118963578955331395475 [1.189e20]) + │ │ │ ├─ [0] 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, bridgeOperator: 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, recipientAddr: 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2::fallback{value: 169879446172168538675}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169879446172168538675 [1.698e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, recipient: 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2, amount: 169879446172168538675 [1.698e20]) + │ │ │ ├─ [0] 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x6E46924371d0e910769aaBE0d867590deAC20684, bridgeOperator: 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, recipientAddr: 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72::fallback{value: 135925354685204004300}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6E46924371d0e910769aaBE0d867590deAC20684, recipient: 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72, amount: 135925354685204004300 [1.359e20]) + │ │ │ ├─ [0] 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, bridgeOperator: 0xD9d5b3E58fa693B468a20C716793B18A1195380a, recipientAddr: 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8::fallback{value: 169870705637003507268}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169870705637003507268 [1.698e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, recipient: 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8, amount: 169870705637003507268 [1.698e20]) + │ │ │ ├─ [0] 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xFc3e31519B551bd594235dd0eF014375a87C4e21, bridgeOperator: 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, recipientAddr: 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9::fallback{value: 170136480416710407898}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170136480416710407898 [1.701e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xFc3e31519B551bd594235dd0eF014375a87C4e21, recipient: 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9, amount: 170136480416710407898 [1.701e20]) + │ │ │ ├─ [0] 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xE07D7e56588a6FD860c5073c70a099658C060F3D, bridgeOperator: 0x4a4217d8751a027D853785824eF40522c512A3Fe, recipientAddr: 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3::fallback{value: 340436100948920512964}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xE07D7e56588a6FD860c5073c70a099658C060F3D, recipient: 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3, amount: 340436100948920512964 [3.404e20]) + │ │ │ ├─ [0] 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, bridgeOperator: 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, recipientAddr: 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888::fallback{value: 340325252087546507482}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, recipient: 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888, amount: 340325252087546507482 [3.403e20]) + │ │ │ ├─ [0] 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x52349003240770727900b06a3B3a90f5c0219ADe, bridgeOperator: 0x32cB6da260726BB2192c4085B857aFD945A215Cb, recipientAddr: 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034::fallback{value: 339817976993460557814}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x52349003240770727900b06a3B3a90f5c0219ADe, recipient: 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034, amount: 339817976993460557814 [3.398e20]) + │ │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, bridgeOperator: 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, recipientAddr: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 340374055555383969820}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, recipient: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 340374055555383969820 [3.403e20]) + │ │ │ ├─ [0] 0x2d593A0087029501eE419b9415DeC3fAC195FE4A::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xd11D9842baBd5209b9B1155e46f5878c989125b7, bridgeOperator: 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, recipientAddr: 0x2d593A0087029501eE419b9415DeC3fAC195FE4A, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x2d593A0087029501eE419b9415DeC3fAC195FE4A::fallback{value: 340363726701776549276}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 340363726701776549276 [3.403e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xd11D9842baBd5209b9B1155e46f5878c989125b7, recipient: 0x2d593A0087029501eE419b9415DeC3fAC195FE4A, amount: 340363726701776549276 [3.403e20]) + │ │ │ ├─ [0] 0xD8FCC2BC2da24e7d74af0078408E6394d7080776::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, bridgeOperator: 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, recipientAddr: 0xD8FCC2BC2da24e7d74af0078408E6394d7080776, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xD8FCC2BC2da24e7d74af0078408E6394d7080776::fallback{value: 339728192236459901442}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 339728192236459901442 [3.397e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, recipient: 0xD8FCC2BC2da24e7d74af0078408E6394d7080776, amount: 339728192236459901442 [3.397e20]) + │ │ │ ├─ [0] 0xE5718182af678C7d65c286851934273AA39e67d6::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, bridgeOperator: 0x332253265e36689D9830E57112CD1aaDB1A773f9, recipientAddr: 0xE5718182af678C7d65c286851934273AA39e67d6, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xE5718182af678C7d65c286851934273AA39e67d6::fallback{value: 84815024893111142653}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84815024893111142653 [8.481e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, recipient: 0xE5718182af678C7d65c286851934273AA39e67d6, amount: 84815024893111142653 [8.481e19]) + │ │ │ ├─ [0] 0xa27a1095015dC037C92403F4B26196b04f342961::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, bridgeOperator: 0x66225AcC78Be789C57a11C9a18F051C779d678B5, recipientAddr: 0xa27a1095015dC037C92403F4B26196b04f342961, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xa27a1095015dC037C92403F4B26196b04f342961::fallback{value: 85096491629164641003}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85096491629164641003 [8.509e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, recipient: 0xa27a1095015dC037C92403F4B26196b04f342961, amount: 85096491629164641003 [8.509e19]) + │ │ │ ├─ [0] 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, bridgeOperator: 0xE795F18F2F5DF5a666994e839b98263Dba86C902, recipientAddr: 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814::fallback{value: 85089196191471422275}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85089196191471422275 [8.508e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, recipient: 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814, amount: 85089196191471422275 [8.508e19]) + │ │ │ ├─ [0] 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, bridgeOperator: 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, recipientAddr: 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434::fallback{value: 85177254352471927923}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, recipient: 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434, amount: 85177254352471927923 [8.517e19]) + │ │ │ ├─ [0] 0x9305E94C367e04b508cB9919f9dce3B60058A740::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, bridgeOperator: 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, recipientAddr: 0x9305E94C367e04b508cB9919f9dce3B60058A740, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x9305E94C367e04b508cB9919f9dce3B60058A740::fallback{value: 84968697635262370274}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84968697635262370274 [8.496e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, recipient: 0x9305E94C367e04b508cB9919f9dce3B60058A740, amount: 84968697635262370274 [8.496e19]) + │ │ │ ├─ [0] 0xA1FBA3752cf39647f1028a4c61791611a78588aB::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, bridgeOperator: 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99, recipientAddr: 0xA1FBA3752cf39647f1028a4c61791611a78588aB, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0xA1FBA3752cf39647f1028a4c61791611a78588aB::fallback{value: 84955525293728741846}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, recipient: 0xA1FBA3752cf39647f1028a4c61791611a78588aB, amount: 84955525293728741846 [8.495e19]) + │ │ │ ├─ [0] 0x69134fB518A13403F4725a15ff60f5B688894c42::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, bridgeOperator: 0x063105D0E7215B703909a7274FE38393302F3134, recipientAddr: 0x69134fB518A13403F4725a15ff60f5B688894c42, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x69134fB518A13403F4725a15ff60f5B688894c42::fallback{value: 169880292287037425572}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, recipient: 0x69134fB518A13403F4725a15ff60f5B688894c42, amount: 169880292287037425572 [1.698e20]) + │ │ │ ├─ [0] 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F::fallback{value: 56541441814645454545}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 56541441814645454545 [5.654e19]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, bridgeOperator: 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, recipientAddr: 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F::fallback{value: 170227489474005394791}()  + │ │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170227489474005394791 [1.702e20]) + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, recipient: 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F, amount: 170227489474005394791 [1.702e20]) + │ │ │ ├─ [0] 0x9B0612E43855ef9a7c329ee89653bA45273B550e::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x61089875fF9e506ae78C7FE9f7c388416520E386, bridgeOperator: 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, recipientAddr: 0x9B0612E43855ef9a7c329ee89653bA45273B550e, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x9B0612E43855ef9a7c329ee89653bA45273B550e::fallback{value: 169909652573519158189}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x61089875fF9e506ae78C7FE9f7c388416520E386, recipient: 0x9B0612E43855ef9a7c329ee89653bA45273B550e, amount: 169909652573519158189 [1.699e20]) + │ │ │ ├─ [0] 0x72A69B04B59C36fCED19ac54209beF878e84FcBF::fallback{value: 56541441814645454545}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit BridgeOperatorRewardDistributed(consensusAddr: 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, bridgeOperator: 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E, recipientAddr: 0x72A69B04B59C36fCED19ac54209beF878e84FcBF, amount: 56541441814645454545 [5.654e19]) + │ │ │ ├─ [0] 0x72A69B04B59C36fCED19ac54209beF878e84FcBF::fallback{value: 169862575167464156156}()  + │ │ │ │ └─ ← () + │ │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, recipient: 0x72A69B04B59C36fCED19ac54209beF878e84FcBF, amount: 169862575167464156156 [1.698e20]) + │ │ │ ├─ [0] ronin-mainnet.Staking::fallback{value: 33235944893664027916805}()  + │ │ │ │ ├─ [0] NotifiedMigrator::receive() [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::fallback() [delegatecall] + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ [0] ronin-mainnet.Staking::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4])  + │ │ │ │ ├─ [0] NotifiedMigrator::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4]) [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4]) [delegatecall] + │ │ │ │ │ │ ├─ emit PoolsUpdated(period: 19632 [1.963e4], poolAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], aRps: [66357646962488955 [6.635e16], 95431207368377915 [9.543e16], 95695598399621230 [9.569e16], 94573200455822051 [9.457e16], 97687248220171528 [9.768e16], 97310118461513347 [9.731e16], 93829791800558853 [9.382e16], 99884465958207150 [9.988e16], 99093477004188600 [9.909e16], 97216470633378110 [9.721e16], 100780733232959799 [1.007e17], 99144578508031030 [9.914e16], 93318776012821131 [9.331e16], 94447227634309187 [9.444e16], 98467985935188233 [9.846e16], 88199764422009158 [8.819e16], 93079390018252421 [9.307e16], 67225014440065554 [6.722e16], 94805313929688703 [9.48e16], 97239053863980682 [9.723e16], 98902645602159682 [9.89e16], 99019423310445352 [9.901e16]], shares: [10190748510465558475599875 [1.019e25], 7206104688158066377918315 [7.206e24], 6881867025193447219128274 [6.881e24], 6781274466483249341608615 [6.781e24], 6658249476098351649251578 [6.658e24], 6503464654044309321751691 [6.503e24], 5903862198409162686318766 [5.903e24], 5813275267619519038407189 [5.813e24], 5784491179033799937345365 [5.784e24], 5778443231451247986081315 [5.778e24], 5741644343444817691866731 [5.741e24], 5761256007661259154805105 [5.761e24], 7389521338803830815958367 [7.389e24], 7188192519136884811285316 [7.188e24], 7047161408616008536704042 [7.047e24], 7015615166482386890314536 [7.015e24], 6993506329773885059751580 [6.993e24], 6906329454934638339591820 [6.906e24], 6718763510770822301943622 [6.718e24], 6452840193432170260900982 [6.452e24], 6396343690109009473179767 [6.396e24], 6365969656770395353461256 [6.365e24]]) + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ emit StakingRewardDistributed(totalAmount: 33235944893664027916805 [3.323e22], consensusAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], amounts: [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]]) + │ │ │ ├─ [0] ronin-mainnet.SlashIndicator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4])  + │ │ │ │ ├─ [0] NotifiedMigrator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4]) [delegatecall] + │ │ │ │ │ ├─ [0] 0x056500E6028048dB7FCA81Ac307008A9042605f3::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4]) [delegatecall] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriodStartAtBlock() [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::currentPeriodStartAtBlock() [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::currentPeriodStartAtBlock() [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [delegatecall] + │ │ │ │ │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [delegatecall] + │ │ │ │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [staticcall] + │ │ │ │ │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ │ │ ├─ emit CreditScoresUpdated(validators: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], creditScores: [600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600]) + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ ├─ [0] ronin-mainnet.Staking::waitingSecsToRevoke() [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::waitingSecsToRevoke() [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::waitingSecsToRevoke() [delegatecall] + │ │ │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ ├─ [0] ronin-mainnet.Staking::minValidatorStakingAmount() [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::minValidatorStakingAmount() [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::minValidatorStakingAmount() [delegatecall] + │ │ │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ ├─ [0] ronin-mainnet.Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ ├─ [0] ronin-mainnet.Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ ├─ [0] 0x9B0E61e629EB44875CFf534DE0c176078CaC502f::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ ├─ [0] ronin-mainnet.RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ │ ├─ [0] NotifiedMigrator::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ ├─ [0] 0x877A15cD0bf1667BaaB50b4C85FD79125c47b7B3::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ ├─ [0] 0x0000000000000000000000000000000000000068::pickValidatorSet([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1], [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]], [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0], 22, 12) [staticcall] + │ │ │ │ └─ ← [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe] + │ │ │ ├─ emit ValidatorSetUpdated(period: 19633 [1.963e4], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [staticcall] + │ │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [delegatecall] + │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ ├─ emit BlockProducerSetUpdated(period: 19633 [1.963e4], epoch: 140697 [1.406e5], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ │ ├─ emit BridgeOperatorSetUpdated(period: 19633 [1.963e4], epoch: 140697 [1.406e5], bridgeOperators: [0x332253265e36689D9830E57112CD1aaDB1A773f9, 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, 0x66225AcC78Be789C57a11C9a18F051C779d678B5, 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99, 0xD9d5b3E58fa693B468a20C716793B18A1195380a, 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, 0x4a4217d8751a027D853785824eF40522c512A3Fe, 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, 0x6149781fB072826089b4676b7d4e5712ad58C7b1, 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, 0xE795F18F2F5DF5a666994e839b98263Dba86C902, 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, 0x063105D0E7215B703909a7274FE38393302F3134, 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E, 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, 0x32cB6da260726BB2192c4085B857aFD945A215Cb]) + │ │ │ ├─ emit WrappedUpEpoch(periodNumber: 19632 [1.963e4], epochNumber: 140696 [1.406e5], periodEnding: true) + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriod() [staticcall] + │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::currentPeriod() [delegatecall] + │ │ │ │ ├─ [0] 0xaB2985fa821CAae0524f6C5657aE40DaBDf2Eae0::currentPeriod() [delegatecall] + │ │ │ │ │ └─ ← 19633 [1.963e4] + │ │ │ │ └─ ← 19633 [1.963e4] + │ │ │ └─ ← 19633 [1.963e4] + │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::selfUpgrade()  + │ │ │ ├─ [0] RoninValidatorSetTimedMigrator::selfUpgrade() [delegatecall] + │ │ │ │ ├─ emit Upgraded(implementation: RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3]) + │ │ │ │ ├─ [0] RoninValidatorSet::initializeV2() [delegatecall] + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 9, addr: ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758]) + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 6, addr: ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3]) + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 7, addr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816]) + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 3, addr: ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2]) + │ │ │ │ │ ├─ emit Initialized(version: 2) + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ [0] RoninValidatorSet::initializeV3(ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) [delegatecall] + │ │ │ │ │ ├─ emit ContractUpdated(contractType: 14, addr: ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) + │ │ │ │ │ ├─ emit Initialized(version: 3) + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ [0] ronin-mainnet.Staking::selfUpgrade()  + │ │ │ │ │ ├─ [0] NotifiedMigrator::selfUpgrade() [delegatecall] + │ │ │ │ │ │ ├─ emit Upgraded(implementation: Staking: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA]) + │ │ │ │ │ │ ├─ [0] Staking::initializeV2() [delegatecall] + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ │ │ │ │ │ ├─ emit Initialized(version: 2) + │ │ │ │ │ │ │ └─ ← () + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ [0] ronin-mainnet.SlashIndicator::selfUpgrade()  + │ │ │ │ │ ├─ [0] NotifiedMigrator::selfUpgrade() [delegatecall] + │ │ │ │ │ │ ├─ emit Upgraded(implementation: SlashIndicator: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f]) + │ │ │ │ │ │ ├─ [0] SlashIndicator::initializeV2(ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) [delegatecall] + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 4, addr: ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ │ │ │ │ │ ├─ emit Initialized(version: 2) + │ │ │ │ │ │ │ └─ ← () + │ │ │ │ │ │ ├─ [0] SlashIndicator::initializeV3(ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) [delegatecall] + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 15, addr: ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) + │ │ │ │ │ │ │ ├─ emit FastFinalitySlashingConfigsUpdated(slashFastFinalityAmount: 250000000000000000000000 [2.5e23], fastFinalityJailUntilBlock: 115792089237316195423570985008687907853269984665640564039457584007913129639935 [1.157e77]) + │ │ │ │ │ │ │ ├─ emit Initialized(version: 3) + │ │ │ │ │ │ │ └─ ← () + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ [0] ronin-mainnet.RoninTrustedOrganization::selfUpgrade()  + │ │ │ │ │ ├─ [0] NotifiedMigrator::selfUpgrade() [delegatecall] + │ │ │ │ │ │ ├─ emit Upgraded(implementation: RoninTrustedOrganization: [0x3BB898B4Bbe24f68A4e9bE46cFE72D1787FD74F4]) + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ [0] ronin-mainnet.BridgeTracking::selfUpgrade()  + │ │ │ │ │ ├─ [0] NotifiedMigrator::selfUpgrade() [delegatecall] + │ │ │ │ │ │ ├─ emit Upgraded(implementation: BridgeTracking: [0x6901F7206A34E441Ac5020b5fB53598A65547A23]) + │ │ │ │ │ │ ├─ [0] BridgeTracking::initializeV2() [delegatecall] + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 2, addr: ronin-mainnet.RoninGatewayV3: [0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df]) + │ │ │ │ │ │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ │ │ │ │ │ ├─ emit Initialized(version: 2) + │ │ │ │ │ │ │ └─ ← () + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ └─ ← () + │ └─ ← () + └─ ← () + + +Script ran successfully. + +== Logs == + Skipping artifact generation for: MockPrecompile + Skipping artifact generation for: RoninValidatorSetLogic + Skipping artifact generation for: RoninValidatorSetTimedMigratorLogic + Skipping artifact generation for: StakingLogic + Skipping artifact generation for: NotifiedMigrator + notifier 0x617c5d73662282EA7FfD231E020eCa6D2B0D552f + Skipping artifact generation for: SlashIndicatorLogic + Skipping artifact generation for: NotifiedMigrator + notifier 0x617c5d73662282EA7FfD231E020eCa6D2B0D552f + Skipping artifact generation for: RoninTrustedOrganizationLogic + Skipping artifact generation for: NotifiedMigrator + notifier 0x617c5d73662282EA7FfD231E020eCa6D2B0D552f + Skipping artifact generation for: BridgeTrackingLogic + Skipping artifact generation for: NotifiedMigrator + notifier 0x617c5d73662282EA7FfD231E020eCa6D2B0D552f +========================== +Simulated On-chain Traces: + + [954922] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + └─ ← 4176 bytes of code + + [4659560] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + ├─ emit Initialized(version: 255) + └─ ← 21253 bytes of code + + [895656] → new RoninValidatorSetTimedMigrator@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + └─ ← 3848 bytes of code + + [151757] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSetTimedMigrator: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x8f61eea6000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000045cd8a76b0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da57600000000000000000000000000000000000000000000000000000000)  + ├─ emit Upgraded(implementation: RoninValidatorSetTimedMigrator: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + ├─ [107045] RoninValidatorSetTimedMigrator::setCallDatas([0x5cd8a76b, 0x3101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da576]) [delegatecall] + │ └─ ← () + └─ ← () + + [3579805] → new Staking@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + ├─ emit Initialized(version: 255) + └─ ← 16154 bytes of code + + [739463] → new NotifiedMigrator@0x47c5e40890bcE4a473A49D7501808b9633F29782 + └─ ← 3120 bytes of code + + [83332] ronin-mainnet.Staking::upgradeToAndCall(NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000045cd8a76b00000000000000000000000000000000000000000000000000000000)  + ├─ emit Upgraded(implementation: NotifiedMigrator: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + ├─ [43786] NotifiedMigrator::setCallDatas([0x5cd8a76b]) [delegatecall] + │ └─ ← () + └─ ← () + + [3169482] → new SlashIndicator@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + ├─ emit Initialized(version: 255) + └─ ← 14346 bytes of code + + [739451] → new NotifiedMigrator@0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9 + └─ ← 3120 bytes of code + + [194973] ronin-mainnet.SlashIndicator::upgradeToAndCall(NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000a0000000000000000000000000000000000000000000000000000000000000002429b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe60000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d03500000000000000000000000000000000000000000000000000000000)  + ├─ emit Upgraded(implementation: NotifiedMigrator: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9]) + ├─ [147298] NotifiedMigrator::setCallDatas([0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6, 0x3101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035]) [delegatecall] + │ └─ ← () + └─ ← () + + [1834812] → new RoninTrustedOrganization@0x3BB898B4Bbe24f68A4e9bE46cFE72D1787FD74F4 + └─ ← 8267 bytes of code + + [739463] → new NotifiedMigrator@0x117814AF22Cb83D8Ad6e8489e9477d28265bc105 + └─ ← 3120 bytes of code + + [39819] ronin-mainnet.RoninTrustedOrganization::upgradeToAndCall(NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000)  + ├─ emit Upgraded(implementation: NotifiedMigrator: [0x117814AF22Cb83D8Ad6e8489e9477d28265bc105]) + ├─ [1446] NotifiedMigrator::setCallDatas([]) [delegatecall] + │ └─ ← () + └─ ← () + + [1618956] → new BridgeTracking@0x6901F7206A34E441Ac5020b5fB53598A65547A23 + ├─ emit Initialized(version: 255) + └─ ← 7134 bytes of code + + [739463] → new NotifiedMigrator@0x684c903c66D69777377f0945052160C9f778d689 + └─ ← 3120 bytes of code + + [83332] ronin-mainnet.BridgeTracking::upgradeToAndCall(NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689], 0x8f61eea600000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000045cd8a76b00000000000000000000000000000000000000000000000000000000)  + ├─ emit Upgraded(implementation: NotifiedMigrator: [0x684c903c66D69777377f0945052160C9f778d689]) + ├─ [43786] NotifiedMigrator::setCallDatas([0x5cd8a76b]) [delegatecall] + │ └─ ← () + └─ ← () + + +========================== + +Chain 2020 + +Estimated gas price: 20 gwei + +Estimated total gas used for script: 26291510 + +Estimated amount required: 0.5258302 ETH + +========================== + +SIMULATION COMPLETE. To broadcast these transactions, add --broadcast and wallet configuration(s) to the previous command. See forge script --help for more. + +Transactions saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/broadcast/20231003_REP002AndREP003_RON.s.sol/2020/dry-run/run-latest.json + +Sensitive values saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/cache_foundry/20231003_REP002AndREP003_RON.s.sol/2020/dry-run/run-latest.json + diff --git a/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional.log b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional.log new file mode 100644 index 000000000..49f50cfc8 --- /dev/null +++ b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional.log @@ -0,0 +1,545 @@ +- skipping the remapping +No files changed, compilation skipped +Traces: + [9223372036854775807] Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional::run()  + ├─ [0] GeneralConfig::getContractName(7) [staticcall] + │ └─ ← MockPrecompile + ├─ [0] GeneralConfig::getContractFileName(7) [staticcall] + │ └─ ← MockPrecompile.sol:MockPrecompile + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000000 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(MockPrecompile.sol:MockPrecompile) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001070608060405234801561001057600080fd5b50611050806100206000396000f3fe608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c6343000815003300000000000000000000000000000000 + ├─ [836070] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + │ └─ ← 4176 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] VM::label(MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile)  + │ └─ ← () + ├─ [0] GeneralConfig::setAddress(3, 7, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1])  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile, MockPrecompile, 0x, 0)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, MockPrecompile) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::etch(0x0000000000000000000000000000000000000068, 0x608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c63430008150033)  + │ └─ ← () + ├─ [0] VM::makePersistent(0x0000000000000000000000000000000000000068)  + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(1) [staticcall] + │ └─ ← RoninValidatorSet + ├─ [0] GeneralConfig::getContractFileName(1) [staticcall] + │ └─ ← RoninValidatorSet.sol:RoninValidatorSet + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000001 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(RoninValidatorSet.sol:RoninValidatorSet) [staticcall] + │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000053e160806040523480156200001157600080fd5b506200001c62000022565b620000e4565b600054610100900460ff16156200008f5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff9081161015620000e2576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b6152ed80620000f46000396000f3fe6080604052600436106103855760003560e01c806365244ece116101d1578063a3d545f511610102578063c94aaa02116100a0578063e5125a1d1161006f578063e5125a1d14610a00578063edb194bb14610a20578063eeb629a814610a82578063f883afaf14610a9757610394565b8063c94aaa021461098b578063d09f1ab4146109ab578063dd716ad3146109c0578063de981f1b146109e057610394565b8063afc69d73116100dc578063afc69d731461092c578063b7ab4db514610941578063ba77b06c14610956578063c3c8b5d61461096b57610394565b8063a3d545f5146108d7578063a66c0f77146108f7578063a7c2f1191461090c57610394565b8063823a7b9c1161016f57806387c891bd1161014957806387c891bd146108565780638d559c381461086b57806396585fc21461087f578063a0c3f2d21461089f57610394565b8063823a7b9c146107f6578063865e6fd314610816578063873a5a701461083657610394565b8063690b7536116101ab578063690b7536146107a45780636aa1c2ef146107b957806372e46810146107ce5780637593ff71146107d657610394565b806365244ece1461074d5780636558954f1461076d5780636611f8431461078457610394565b80633101cfcb116102b65780634de2b735116102545780635248184a116102235780635248184a146106ec5780635cd8a76b1461070e578063605239a114610723578063612c8d981461073857610394565b80634de2b735146106825780634ee4d72b146106af5780634f2a693f146106c457806352091f17146106e457610394565b80633b3159b6116102905780633b3159b6146105e1578063468c96ae1461060957806349096d26146106405780634d8df0631461066257610394565b80633101cfcb1461058157806331a8aef5146105a1578063367ec12b146105c157610394565b8063217f35c2116103235780632924de71116102fd5780632924de71146104ff578063297a8fca1461051f5780632d784a98146105345780632f78204c1461056157610394565b8063217f35c21461049d57806323c65eb0146104b257806328bde1e1146104d257610394565b80630f43a6771161035f5780630f43a6771461040a57806311662dc2146104205780631196ab661461045d57806315b5ebde1461047d57610394565b8063038278841461039c57806304d971ab146103c557806306040618146103f557610394565b3661039457610392610ab7565b005b610392610ab7565b3480156103a857600080fd5b506103b26104b081565b6040519081526020015b60405180910390f35b3480156103d157600080fd5b506103e56103e036600461484b565b610b36565b60405190151581526020016103bc565b34801561040157600080fd5b506103b2610b5d565b34801561041657600080fd5b506103b260aa5481565b34801561042c57600080fd5b5061044061043b366004614884565b610b6d565b6040805193151584526020840192909252908201526060016103bc565b34801561046957600080fd5b506103926104783660046148b0565b610bf0565b34801561048957600080fd5b50610392610498366004614884565b610c04565b3480156104a957600080fd5b506103e5610d23565b3480156104be57600080fd5b506103e56104cd366004614884565b610d38565b3480156104de57600080fd5b506104f26104ed3660046148c9565b610d5c565b6040516103bc91906148e6565b34801561050b57600080fd5b506103e561051a3660046148c9565b610e3c565b34801561052b57600080fd5b506004546103b2565b34801561054057600080fd5b5061055461054f3660046148c9565b610e48565b6040516103bc9190614944565b34801561056d57600080fd5b5061039261057c366004614969565b610ec3565b34801561058d57600080fd5b5061039261059c3660046148c9565b6110e3565b3480156105ad57600080fd5b506103e56105bc366004614884565b6111cc565b3480156105cd57600080fd5b506103926105dc3660046149c4565b6111f8565b3480156105ed57600080fd5b5060685b6040516001600160a01b0390911681526020016103bc565b34801561061557600080fd5b506106296106243660046148b0565b611384565b6040805192151583526020830191909152016103bc565b34801561064c57600080fd5b506106556113c2565b6040516103bc9190614ace565b34801561066e57600080fd5b5061039261067d3660046148b0565b6114a2565b34801561068e57600080fd5b506106a261069d366004614ae1565b6114b3565b6040516103bc9190614b56565b3480156106bb57600080fd5b5060e4546103b2565b3480156106d057600080fd5b506103926106df3660046148b0565b611565565b610392611576565b3480156106f857600080fd5b5061070161199c565b6040516103bc9190614b9c565b34801561071a57600080fd5b50610392611af0565b34801561072f57600080fd5b506072546103b2565b34801561074457600080fd5b506076546103b2565b34801561075957600080fd5b506103e56107683660046148c9565b611c82565b34801561077957600080fd5b506103b26201518081565b34801561079057600080fd5b5061039261079f3660046148b0565b611cbc565b3480156107b057600080fd5b5060e5546103b2565b3480156107c557600080fd5b506001546103b2565b610392611ccd565b3480156107e257600080fd5b506103e56107f13660046148b0565b611f7f565b34801561080257600080fd5b506103926108113660046148b0565b611fa3565b34801561082257600080fd5b50610392610831366004614c3d565b611fb4565b34801561084257600080fd5b506103e56108513660046148c9565b611fd3565b34801561086257600080fd5b506002546103b2565b34801561087757600080fd5b5060666105f1565b34801561088b57600080fd5b5061044061089a3660046148c9565b61200d565b3480156108ab57600080fd5b506103e56108ba3660046148c9565b6001600160a01b0316600090815260746020526040902054151590565b3480156108e357600080fd5b506103b26108f23660046148b0565b612029565b34801561090357600080fd5b5060e6546103b2565b34801561091857600080fd5b50610392610927366004614884565b612034565b34801561093857600080fd5b506103b26122d5565b34801561094d57600080fd5b50610655612318565b34801561096257600080fd5b506106556123bf565b34801561097757600080fd5b5061039261098636600461484b565b612421565b34801561099757600080fd5b506103926109a63660046148b0565b612678565b3480156109b757600080fd5b5060a9546103b2565b3480156109cc57600080fd5b506103926109db366004614884565b612689565b3480156109ec57600080fd5b506105f16109fb366004614c59565b612741565b348015610a0c57600080fd5b50610392610a1b366004614c74565b6127d0565b348015610a2c57600080fd5b50610554610a3b3660046148c9565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b348015610a8e57600080fd5b5060ad546103b2565b348015610aa357600080fd5b50610392610ab2366004614ca9565b612914565b610ac16007612741565b6001600160a01b0316336001600160a01b031614158015610afd5750610ae76009612741565b6001600160a01b0316336001600160a01b031614155b15610b34576040517fffcb451300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610b6860035490565b905090565b6001600160a01b0382166000908152603a60205260408120548190819084811015610ba357600080600093509350935050610be9565b60019350610bb18582614d10565b610bbc906001614d23565b9250610bc785612029565b610bd082612029565b610bda9190614d10565b610be5906001614d23565b9150505b9250925092565b610bf8612b9a565b610c0181612c0e565b50565b6006610c0f81612c7e565b6001600160a01b0383166000908152603c60205260409020544311610c70576040517f53e0424d0000000000000000000000000000000000000000000000000000000081526001600160a01b03841660048201526024015b60405180910390fd5b6001600160a01b038316600081815260386020908152604080832086845282528083208054600160ff199182168117909255948452603783528184208785529092529091208054909216909155610cc79043614d10565b6001600160a01b0384166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e90610d169085815260200190565b60405180910390a2505050565b6000610b68610d3142612ce3565b6003541090565b6001600160a01b0382166000908152603a60205260408120548211155b9392505050565b6040805160e08101825260008082526020808301829052828401829052606083018290526080830182905260a0830182905260c083018290526001600160a01b0385168252607490529190912054610dc75760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610b578243610d38565b604080518082018252600080825260209182018190526001600160a01b038416815260e882528281208351808501909452805484526001015491830182905203610ebe576040517fe1fba9e200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b6006610ece81612c7e565b6000610ed8610b5d565b6001600160a01b03871660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e090915291902054919250610f2691614d23565b60e46000828254610f379190614d23565b90915550506001600160a01b038616600090815260e06020908152604080832083905560e18252808320839055603a909152902054610f77908690612cf2565b6001600160a01b0387166000908152603a60205260409020558315611032576000610fa26009612741565b60405163138ac02f60e11b81526001600160a01b038981166004830152602482018890529190911690632715805e906044016020604051808303816000875af1158015610ff3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110179190614d36565b90508060e4600082825461102b9190614d23565b9091555050505b8215611076576001600160a01b0386166000908152603c602052604090205461105c908690612cf2565b6001600160a01b0387166000908152603c60205260409020555b6001600160a01b0386166000818152603a6020908152604080832054815190815291820188905260019082015260608101919091528291907f54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68a9060800160405180910390a3505050505050565b600054600390610100900460ff16158015611105575060005460ff8083169116105b6111685760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055611187600e83612d09565b6000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b6001600160a01b038216600090815260376020908152604080832084845290915281205460ff16610d55565b600054610100900460ff16158080156112185750600054600160ff909116105b806112325750303b158015611232575060005460ff166001145b6112955760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805460ff1916600117905580156112b8576000805461ff0019166101001790555b6112c360068e612d09565b6112ce60098d612d09565b6112d960078c612d09565b6112e460058b612d09565b6112ef600a8a612d09565b6112f887612dad565b61130186612de2565b61130a85612e17565b61131384612c0e565b61131d8235612e88565b61132a6020830135612ebd565b60018390558015611375576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050505050565b60008061139043612029565b831115806113ab575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b606060aa5467ffffffffffffffff8111156113df576113df614d65565b604051908082528060200260200182016040528015611408578160200160208202803683370190505b5090506000805b825181101561149c57600081815260ab6020526040902054611439906001600160a01b0316611c82565b1561149457600081815260ab60205260409020546001600160a01b0316838361146181614d7b565b94508151811061147357611473614d4f565b60200260200101906001600160a01b031690816001600160a01b0316815250505b60010161140f565b50815290565b6114aa612b9a565b610c0181612ebd565b60608167ffffffffffffffff8111156114ce576114ce614d65565b6040519080825280602002602001820160405280156114f7578160200160208202803683370190505b50905060005b8281101561155e5761153484848381811061151a5761151a614d4f565b905060200201602081019061152f91906148c9565b612ef2565b82828151811061154657611546614d4f565b911515602092830291909101909101526001016114fd565b5092915050565b61156d612b9a565b610c0181612de2565b61157e612f13565b600061158933611c82565b801561159b575061159933612ef2565b155b80156115db57506115d9336115ae610b5d565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b155b90506000806115ea6007612741565b6040517f0634f5b90000000000000000000000000000000000000000000000000000000081528415156004820152600060248201526001600160a01b039190911690630634f5b9906044016080604051808303816000875af1158015611654573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116789190614d94565b935050925050826116cf573460e460008282546116959190614d23565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90610d16903490600190614de9565b604080513481526020810184905233917f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b1910160405180910390a26000611714610b5d565b905060006117228434614d23565b905060006127106117338584614e0d565b61173d9190614e3a565b9050600061174b8284614d10565b905060008260e260008282546117619190614d23565b909155505033600090815260386020908152604080832088845290915290205460ff161561186c5760006117956006612741565b6001600160a01b031663c6391fa26040518163ffffffff1660e01b8152600401608060405180830381865afa1580156117d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117f69190614e4e565b9350505050612710818461180a9190614e0d565b6118149190614e3a565b91508160e460008282546118289190614d23565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90611862908590600290614de9565b60405180910390a2505b6118768183614d10565b91506000806118856009612741565b6001600160a01b0316634530d2026040518163ffffffff1660e01b81526004016040805180830381865afa1580156118c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118e59190614e84565b33600090815260756020526040812060040154929450909250906119139061190d9084612f4c565b84612cf2565b905060006127106119248784614e0d565b61192e9190614e3a565b33600090815260e06020526040812080549293508392909190611952908490614d23565b90915550600090506119648288614d10565b33600090815260e16020526040812080549293508392909190611988908490614d23565b909155505050505050505050505050505050565b60735460609067ffffffffffffffff8111156119ba576119ba614d65565b604051908082528060200260200182016040528015611a2157816020015b6040805160e08101825260008082526020808301829052928201819052606082018190526080820181905260a0820181905260c082015282526000199092019101816119d85790505b50905060005b8151811015611aec576075600060738381548110611a4757611a47614d4f565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c08201528251839083908110611ad957611ad9614d4f565b6020908102919091010152600101611a27565b5090565b600054600290610100900460ff16158015611b12575060005460ff8083169116105b611b755760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055607154611ba1906009906001600160a01b0316612d09565b606f54611bb9906005906001600160a01b0316612d09565b607054611bd1906006906001600160a01b0316612d09565b606d54611be9906007906001600160a01b0316612d09565b60a854611c0190600a906001600160a01b0316612d09565b607180546001600160a01b0319908116909155606f8054821690556070805482169055606d805482169055606e80548216905560a8805490911690556000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6001600160a01b038116600090815260ac6020526040812054610b579060019060ff166003811115611cb657611cb6614dd3565b90612f5b565b611cc4612b9a565b610c0181612e88565b611cd5612f13565b611cde43611f7f565b611d14576040517f6c74eecf00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611d1d43612029565b611d28600254612029565b10611d5f576040517f2458f64100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b436002556000611d6e42612ce3565b90506000611d7d826003541090565b90506000611d89612318565b905060606000611d9843612029565b90506000611da7826001614d23565b90506000611db3610b5d565b9050611dbf8386612f8e565b8515611f1957600080611dd283886130fd565b91509150611de2838884846132e9565b611dea61340c565b611df2613560565b6000611dfe6006612741565b6040517f7680850c0000000000000000000000000000000000000000000000000000000081529091506001600160a01b03821690637680850c90611e48908b908890600401614ea8565b600060405180830381600087803b158015611e6257600080fd5b505af1158015611e76573d6000803e3d6000fd5b50505050611e838a6136bc565b8051919950975015611f07576040517f07c2d2f60000000000000000000000000000000000000000000000000000000081526001600160a01b038216906307c2d2f690611ed4908a90600401614ace565b600060405180830381600087803b158015611eee57600080fd5b505af1158015611f02573d6000803e3d6000fd5b505050505b611f12436001614d23565b6004555050505b611f2487838761384d565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce788604051611f59911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b600060018054611f8f9190614d10565b600154611f9c9084614eca565b1492915050565b611fab612b9a565b610c0181612dad565b611fbc612b9a565b611fc581613ae9565b611fcf8282612d09565b5050565b600080611fde610b5d565b6001600160a01b038416600090815260376020908152604080832084845290915290205490915060ff16610d55565b600080600061201c8443610b6d565b9250925092509193909250565b6000610b5782613b38565b600961203f81612c7e565b6001600160a01b038316600090815260e860205260409020600181015415612093576040517f2bd5598800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600061209f8442614d23565b6001600160a01b03861660009081526075602052604090209091506120c49082613b53565b6001600160a01b0385166000818152603b602052604080822084905560e554905163138ac02f60e11b815260048101939093526024830152903390632715805e906044016020604051808303816000875af1158015612127573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061214b9190614d36565b9050801561228a57600060e654426121639190614d23565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038b16179055838655850181905590506121ea7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b6001600160a01b03888116600081815260756020526040908190206002015490517fa2fae5700000000000000000000000000000000000000000000000000000000081526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b15801561227057600080fd5b505af1158015612284573d6000803e3d6000fd5b50505050505b856001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c4826040516122c591815260200190565b60405180910390a2505050505050565b6000805b60aa54811015611aec57600081815260ab6020526040902054612304906001600160a01b0316611c82565b15612310576001909101905b6001016122d9565b606060aa5467ffffffffffffffff81111561233557612335614d65565b60405190808252806020026020018201604052801561235e578160200160208202803683370190505b50905060005b8151811015611aec57600081815260ab602052604090205482516001600160a01b0390911690819084908490811061239e5761239e614d4f565b6001600160a01b039092166020928302919091019091015250600101612364565b6060607380548060200260200160405190810160405280929190818152602001828054801561241757602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116123f9575b5050505050905090565b612429612b9a565b6001600160a01b038216600090815260e8602052604090206001015415611fcf5760e7548060005b828110156124a057846001600160a01b031660e7828154811061247657612476614d4f565b6000918252602090912001546001600160a01b031603612498578091506124a0565b600101612451565b508181036124ae5750505050565b6001600160a01b038416600090815260e860205260409020548015612671576001600160a01b038516600090815260e8602052604081208181556001908101919091558311156125705760e7612505600185614d10565b8154811061251557612515614d4f565b60009182526020909120015460e780546001600160a01b03909216918490811061254157612541614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061258157612581614ede565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff191660011790556125d384826104b0613bdc565b1561262c57836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e48360405161261d91815260200190565b60405180910390a35050505050565b604080518281524760208201526001600160a01b0380871692908816917f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a1910161261d565b5050505050565b612680612b9a565b610c0181612e17565b600961269481612c7e565b61269d83613c3c565b156126d4576040517f030081e700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152607560205260409020600581015415612728576040517ffab9167300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61273b816127368542614d23565b613b53565b50505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561277857612778614dd3565b60ff1681526020810191909152604001600020546001600160a01b0316905080610ebe57816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c679190614f08565b60096127db81612c7e565b6001600160a01b0384166000908152607760205260409020541561282b576040517f5e65b9ba00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61271082111561284e57604051631b8454a360e21b815260040160405180910390fd5b60765483101561288a576040517ffa0ae69300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b03841660009081526077602052604081209062015180856128b28242614e3a565b6128bc9190614d23565b6128c69190614e0d565b8083556001830185905560408051828152602081018790529192506001600160a01b038816917f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f2191016122c5565b600961291f81612c7e565b607354607254811061295d576040517f8616841b00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260746020526040902054156129ad576040517f8ad9cdf900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108311156129d057604051631b8454a360e21b815260040160405180910390fd5b60005b607354811015612ac957600060756000607384815481106129f6576129f6614d4f565b60009182526020808320909101546001600160a01b03908116845290830193909352604090910190208054909250811690891603612a6b576040517ffc3d8c750000000000000000000000000000000000000000000000000000000081526001600160a01b0389166004820152602401610c67565b60028101546001600160a01b0390811690871603612ac0576040517f5a674fce0000000000000000000000000000000000000000000000000000000081526001600160a01b0387166004820152602401610c67565b506001016129d3565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b031990811687179091556075909352818420805484168d881690811782559181018054851687179055600281018054909416968b1696871790935560048301899055905191949093909290917f1ca451a9920472b99355a9cf74185bf017604a7849c113f020888ecec9db93669190a450505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610b34576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610c67929190614f16565b6001811015612c49576040517f17b8970f00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a2526790602001611c77565b612c8781612741565b6001600160a01b0316336001600160a01b031614610c01576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c6793929190614f37565b6000610b576201518083614e3a565b600081831015612d025781610d55565b5090919050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115612d3f57612d3f614dd3565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115612d8057612d80614dd3565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b590602001611c77565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab490602001611c77565b60a954811115612e53576040517faa8119d200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e90602001611c77565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a90602001611c77565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b90602001611c77565b6001600160a01b0381166000908152603a6020526040812054431115610b57565b334114610b34576040517f09f358fd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000818310612d025781610d55565b6000816003811115612f6f57612f6f614dd3565b836003811115612f8157612f81614dd3565b1660ff1615159392505050565b6000612f9a600e612741565b6001600160a01b031663468d24be84846040518363ffffffff1660e01b8152600401612fc7929190614f6c565b600060405180830381865afa158015612fe4573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261300c9190810190614fe2565b90506000825160015461301f9190614e0d565b60e25490915060009081805b86518110156130ce578486828151811061304757613047614d4f565b60200260200101518461305a9190614e0d565b6130649190614e3a565b93508360e3600089848151811061307d5761307d614d4f565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060008282546130b49190614d23565b909155506130c490508483614d23565b915060010161302b565b506130d98183614d10565b60e460008282546130ea9190614d23565b9091555050600060e25550505050505050565b60006060600080845167ffffffffffffffff81111561311e5761311e614d65565b604051908082528060200260200182016040528015613147578160200160208202803683370190505b50925060005b85518110156132df5785818151811061316857613168614d4f565b6020908102919091018101516001600160a01b03808216600090815260759093526040909220600201549094501691506131a183612ef2565b1580156131d257506001600160a01b03831660009081526037602090815260408083208a845290915290205460ff16155b15613250576001600160a01b038316600090815260e160205260409020546131fa9086614d23565b6001600160a01b038416600090815260e1602052604090205485519196509085908390811061322b5761322b614d4f565b6020026020010181815250506132418383613cd5565b61324b8383613d9d565b6132a7565b6001600160a01b038316600090815260e3602090815260408083205460e183528184205460e09093529220546132869190614d23565b6132909190614d23565b60e460008282546132a19190614d23565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e390915281205560010161314d565b5050509250929050565b60006132f56009612741565b90508215612671576133078184613e58565b156133c8576040517facd79c460000000000000000000000000000000000000000000000000000000081526001600160a01b0382169063acd79c469061335590879086908a906004016150a8565b600060405180830381600087803b15801561336f57600080fd5b505af1158015613383573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d0878385846040516133ba939291906150de565b60405180910390a15061273b565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f89838584476040516133fd9493929190615113565b60405180910390a15050505050565b60e754600080805b8383101561273b5760e7838154811061342f5761342f614d4f565b60009182526020808320909101546001600160a01b031680835260e8909152604090912060018101549193509150421061355557805460e48054600090613477908490614d23565b90915550506001600160a01b038216600090815260e8602052604081208181556001018190556134a685615150565b945084111561351d5760e784815481106134c2576134c2614d4f565b60009182526020909120015460e780546001600160a01b0390921691859081106134ee576134ee614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061352e5761352e614ede565b600082815260209020810160001990810180546001600160a01b0319169055019055613414565b600190920191613414565b60e4548015610c015760006135756007612741565b600060e481905560408051600481526024810182526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f59f778df00000000000000000000000000000000000000000000000000000000179052905192935090916001600160a01b0384169185916135f09190615167565b60006040518083038185875af1925050503d806000811461362d576040519150601f19603f3d011682016040523d82523d6000602084013e613632565b606091505b50509050801561367757816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051610d1691815260200190565b604080518481524760208201526001600160a01b038416917fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b739101610d16565b505050565b6060806136c883613eb4565b905060006136d66009612741565b6001600160a01b03166391f8723f60736040518263ffffffff1660e01b81526004016137029190615196565b600060405180830381865afa15801561371f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526137479190810190614fe2565b90506000613755600a612741565b6001600160a01b031663520fce6260736040518263ffffffff1660e01b81526004016137819190615196565b600060405180830381865afa15801561379e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526137c69190810190614fe2565b90506000613835607380548060200260200160405190810160405280929190818152602001828054801561382357602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311613805575b5050505050848460a95460ad546143dc565b90955090506138458582886144ed565b505050915091565b60006138596005612741565b6001600160a01b031663fdadda8183613873436001614d23565b6040518363ffffffff1660e01b8152600401613890929190614ea8565b600060405180830381865afa1580156138ad573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526138d591908101906151da565b905060005b8251811015613aa25760008382815181106138f7576138f7614d4f565b6020908102919091018101516001600160a01b0381166000908152603b90925260408220549092504211159061392c83611c82565b9050600061395f8461393f436001614d23565b6001600160a01b03919091166000908152603a6020526040902054101590565b80613980575085858151811061397757613977614d4f565b60200260200101515b806139885750825b159050811580156139965750805b15613a11576001600160a01b038416600090815260ac60205260409020546139d59060019060ff1660038111156139cf576139cf614dd3565b9061462d565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613a0757613a07614dd3565b0217905550613a93565b818015613a1c575080155b15613a93576001600160a01b038416600090815260ac6020526040902054613a5b9060019060ff166003811115613a5557613a55614dd3565b90614668565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613a8d57613a8d614dd3565b02179055505b846001019450505050506138da565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b82613ace6113c2565b604051613adb9190614ace565b60405180910390a350505050565b806001600160a01b03163b600003610c01576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c67565b600060015482613b489190614e3a565b610b57906001614d23565b60018201546001600160a01b0316600090815260746020526040902054613b8d5760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e79060200160405180910390a25050565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613c2c576040519150601f19603f3d011682016040523d82523d6000602084013e613c31565b606091505b509095945050505050565b600080613c49600a612741565b6040517f41feed1c0000000000000000000000000000000000000000000000000000000081526001600160a01b03858116600483015291909116906341feed1c90602401602060405180830381865afa158015613caa573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613cce9190614d36565b1192915050565b6001600160a01b038216600090815260e0602052604090205480156136b757613d0182826104b0613bdc565b15613d5857816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec83604051613d4b91815260200190565b60405180910390a3505050565b604080518281524760208201526001600160a01b0380851692908616917f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e9101613d4b565b6001600160a01b038216600090815260e3602052604090205480156136b757613dc982826104b0613bdc565b15613e1357816001600160a01b0316836001600160a01b03167f0c4d6a43fc8470dee97db74874b5685e412cc517d9bdecfde1623c5e835b18e483604051613d4b91815260200190565b604080518281524760208201526001600160a01b0380851692908616917f98697ee35f04a599a814432016fff3968c483d2d88dacb484926b9358f8e7cf99101613d4b565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114613ea5576040519150601f19603f3d011682016040523d82523d6000602084013e613eaa565b606091505b5090949350505050565b60606000613ec26009612741565b90506000816001600160a01b031663af2454296040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f04573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f289190614d36565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f6a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f8e9190614d36565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b8152600401613fbf9190615196565b600060405180830381865afa158015613fdc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526140049190810190614fe2565b60735490915060008167ffffffffffffffff81111561402557614025614d65565b60405190808252806020026020018201604052801561404e578160200160208202803683370190505b50965060008060005b84831015614314576073838154811061407257614072614d4f565b60009182526020808320909101546001600160a01b0316808352607590915260409091206006810154885192945090925015159088908890869081106140ba576140ba614d4f565b6020026020010151101561412857806141235760006140d98a42614d23565b600684018190556040518181529091506001600160a01b038516907f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342759060200160405180910390a2505b61417b565b801561417b578160060160009055826001600160a01b03167f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a34275600060405161417291815260200190565b60405180910390a25b60008260050154600014158015614196575042836005015411155b806141b957506001600160a01b038416600090815260e9602052604090205460ff165b9050600083600601546000141580156141d6575042846006015411155b905081806141e15750805b1561427357886141f089615150565b9850888151811061420357614203614d4f565b602002602001015189878151811061421d5761421d614d4f565b602002602001018181525050848d888060010199508151811061424257614242614d4f565b60200260200101906001600160a01b031690816001600160a01b03168152505061426b856146a4565b505050614057565b6001600160a01b038516600090815260776020526040902054801580159061429b5750428111155b15614304576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b5050600190940193506140579050565b50505080875280156143d1577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c918760405161434f9190614ace565b60405180910390a16040517fe22d1c9d0000000000000000000000000000000000000000000000000000000081526001600160a01b0387169063e22d1c9d9061439e908a908c90600401614ea8565b600060405180830381600087803b1580156143b857600080fd5b505af11580156143cc573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401614400959493929190615269565b60408051601f19818403018152919052602080820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f779415120000000000000000000000000000000000000000000000000000000017905281518b51929350600192909160009161447191614e0d565b61447c906040614d23565b90506020840181888483895afa61449257600093505b503d61449d57600092505b602087019650826144da576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa5481101561454157600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b03191690556001016144ef565b5060005b8281101561458157600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff19169055600101614545565b5060005b828110156145f55760008482815181106145a1576145a1614d4f565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b031916909117905550600101614585565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051610d169190614ace565b600081600381111561464157614641614dd3565b83600381111561465357614653614dd3565b1760ff166003811115610d5557610d55614dd3565b600081600381111561467c5761467c614dd3565b1983600381111561468f5761468f614dd3565b1660ff166003811115610d5557610d55614dd3565b6001600160a01b038116600090815260e960209081526040808320805460ff191690556074909152812054610c01918391908190036146e1575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b03199081168255600180830180548316905560028301805483169055600383018054909216909155600482018590556005820185905560069091018490556074835281842084905560779092528220828155810182905560738054909161476b91614d10565b8154811061477b5761477b614d4f565b6000918252602090912001546001600160a01b039081169150831681146147fe576001600160a01b03811660009081526074602052604090208290556073805482919084199081106147cf576147cf614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b607380548061480f5761480f614ede565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6001600160a01b0381168114610c0157600080fd5b6000806040838503121561485e57600080fd5b823561486981614836565b9150602083013561487981614836565b809150509250929050565b6000806040838503121561489757600080fd5b82356148a281614836565b946020939093013593505050565b6000602082840312156148c257600080fd5b5035919050565b6000602082840312156148db57600080fd5b8135610d5581614836565b60e08101610b5782846001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b815181526020808301519082015260408101610b57565b8015158114610c0157600080fd5b6000806000806080858703121561497f57600080fd5b843561498a81614836565b9350602085013592506040850135915060608501356149a88161495b565b939692955090935050565b8060408101831015610b5757600080fd5b6000806000806000806000806000806000806101a08d8f0312156149e757600080fd5b8c356149f281614836565b9b5060208d0135614a0281614836565b9a5060408d0135614a1281614836565b995060608d0135614a2281614836565b985060808d0135614a3281614836565b975060a08d0135614a4281614836565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d01359150614a788e6101608f016149b3565b90509295989b509295989b509295989b565b600081518084526020808501945080840160005b83811015614ac35781516001600160a01b031687529582019590820190600101614a9e565b509495945050505050565b602081526000610d556020830184614a8a565b60008060208385031215614af457600080fd5b823567ffffffffffffffff80821115614b0c57600080fd5b818501915085601f830112614b2057600080fd5b813581811115614b2f57600080fd5b8660208260051b8501011115614b4457600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015614b90578351151583529284019291840191600101614b72565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b81811015614b9057614c1b8385516001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b9284019260e09290920191600101614bb8565b803560108110610ebe57600080fd5b60008060408385031215614c5057600080fd5b61486983614c2e565b600060208284031215614c6b57600080fd5b610d5582614c2e565b600080600060608486031215614c8957600080fd5b8335614c9481614836565b95602085013595506040909401359392505050565b60008060008060808587031215614cbf57600080fd5b8435614cca81614836565b93506020850135614cda81614836565b92506040850135614cea81614836565b9396929550929360600135925050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610b5757610b57614cfa565b80820180821115610b5757610b57614cfa565b600060208284031215614d4857600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b600060018201614d8d57614d8d614cfa565b5060010190565b60008060008060808587031215614daa57600080fd5b8451614db58161495b565b60208601516040870151606090970151919890975090945092505050565b634e487b7160e01b600052602160045260246000fd5b8281526040810160038310614e0057614e00614dd3565b8260208301529392505050565b8082028115828204841417610b5757610b57614cfa565b634e487b7160e01b600052601260045260246000fd5b600082614e4957614e49614e24565b500490565b60008060008060808587031215614e6457600080fd5b505082516020840151604085015160609095015191969095509092509050565b60008060408385031215614e9757600080fd5b505080516020909101519092909150565b604081526000614ebb6040830185614a8a565b90508260208301529392505050565b600082614ed957614ed9614e24565b500690565b634e487b7160e01b600052603160045260246000fd5b60108110614f0457614f04614dd3565b9052565b60208101610b578284614ef4565b6001600160e01b03198316815260408101600b8310614e0057614e00614dd3565b6001600160e01b03198416815260608101614f556020830185614ef4565b6001600160a01b0383166040830152949350505050565b828152604060208201526000614f856040830184614a8a565b949350505050565b604051601f8201601f1916810167ffffffffffffffff81118282101715614fb657614fb6614d65565b604052919050565b600067ffffffffffffffff821115614fd857614fd8614d65565b5060051b60200190565b60006020808385031215614ff557600080fd5b825167ffffffffffffffff81111561500c57600080fd5b8301601f8101851361501d57600080fd5b805161503061502b82614fbe565b614f8d565b81815260059190911b8201830190838101908783111561504f57600080fd5b928401925b8284101561506d57835182529284019290840190615054565b979650505050505050565b600081518084526020808501945080840160005b83811015614ac35781518752958201959082019060010161508c565b6060815260006150bb6060830186614a8a565b82810360208401526150cd8186615078565b915050826040830152949350505050565b8381526060602082015260006150f76060830185614a8a565b82810360408401526151098185615078565b9695505050505050565b84815260806020820152600061512c6080830186614a8a565b828103604084015261513e8186615078565b91505082606083015295945050505050565b60008161515f5761515f614cfa565b506000190190565b6000825160005b81811015615188576020818601810151858301520161516e565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b81811015614b905783546001600160a01b0316835260019384019392850192016151b5565b600060208083850312156151ed57600080fd5b825167ffffffffffffffff81111561520457600080fd5b8301601f8101851361521557600080fd5b805161522361502b82614fbe565b81815260059190911b8201830190838101908783111561524257600080fd5b928401925b8284101561506d57835161525a8161495b565b82529284019290840190615247565b60a08152600061527c60a0830188614a8a565b828103602084015261528e8188615078565b905082810360408401526152a28187615078565b6060840195909552505060800152939250505056fea2646970667358221220e1fa978536e3e7e5a867331abd0de9fa2550e65c5dc601ff991cba8430538f4f64736f6c6343000815003300000000000000000000000000000000000000000000000000000000000000 + ├─ [4274288] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + │ ├─ emit Initialized(version: 255) + │ └─ ← 21229 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + ├─ [0] VM::load(ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [86968] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3]) + │ ├─ [81147] RoninValidatorSet::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 9, addr: ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758]) + │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ ├─ emit ContractUpdated(contractType: 6, addr: ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3]) + │ │ ├─ emit ContractUpdated(contractType: 7, addr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816]) + │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], RoninValidatorSet, RoninValidatorSetLogic, 0x, 1)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, RoninValidatorSetLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(10) [staticcall] + │ └─ ← FastFinalityTracking + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(10) [staticcall] + │ └─ ← ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576] + ├─ [0] ronin-mainnet.RoninValidatorSet::initializeV3(ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576])  + │ ├─ [0] RoninValidatorSet::initializeV3(ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 14, addr: ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) + │ │ ├─ emit Initialized(version: 3) + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(5) [staticcall] + │ └─ ← Staking + ├─ [0] GeneralConfig::getContractFileName(5) [staticcall] + │ └─ ← Staking.sol:Staking + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000002 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(Staking.sol:Staking) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000401360806040523480156200001157600080fd5b5060016000556200002162000027565b620000e9565b60d154610100900460ff1615620000945760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60d15460ff9081161015620000e75760d1805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b613f1a80620000f96000396000f3fe6080604052600436106102bf5760003560e01c80636bd8f8041161016e578063aa15a6fd116100cb578063d01b8eed1161007f578063e22d1c9d11610064578063e22d1c9d14610821578063f92ad21914610841578063f9f031df14610861576102d1565b8063d01b8eed14610790578063de981f1b14610801576102d1565b8063af245429116100b0578063af2454291461070a578063c2a672e01461071f578063c50870031461073f576102d1565b8063aa15a6fd146106d7578063acd79c46146106f7576102d1565b8063909791dd11610122578063924f081e11610107578063924f081e146106775780639488e4e914610697578063969ffc14146106b7576102d1565b8063909791dd1461064257806391f8723f14610657576102d1565b8063865e6fd311610153578063865e6fd3146105c9578063888b9ae9146105e9578063895ab74214610609576102d1565b80636bd8f8041461055f57806376664b651461057f576102d1565b806342e0c4081161021c5780635c19a95c116101d05780636558954f116101b55780636558954f14610508578063679a6e431461051f5780636b0916951461053f576102d1565b80635c19a95c146104e05780635cd8a76b146104f3576102d1565b80634530d202116102015780634530d202146104785780634d99dd16146104a057806357473447146104c0576102d1565b806342e0c4081461040d57806342ef3c3414610458576102d1565b80631658c86e116102735780632715805e116102585780632715805e146103ba5780632baae125146103da5780633d8e846e146103ed576102d1565b80631658c86e1461038757806326476204146103a7576102d1565b8063095f6475116102a4578063095f64751461031a578063097e4a9d146103475780630dccaf4614610367576102d1565b806303827884146102dc5780630682e8fa14610305576102d1565b366102d15760086102cf81610881565b005b60086102cf81610881565b3480156102e857600080fd5b506102f26104b081565b6040519081526020015b60405180910390f35b34801561031157600080fd5b506038546102f2565b34801561032657600080fd5b5061033a6103353660046136cb565b6108f2565b6040516102fc9190613772565b34801561035357600080fd5b506102f261036236600461379a565b610a2b565b34801561037357600080fd5b506102cf6103823660046137f1565b610ae1565b34801561039357600080fd5b506102cf6103a2366004613842565b610c1a565b6102cf6103b5366004613842565b610ca3565b3480156103c657600080fd5b506102f26103d5366004613866565b610cdc565b6102cf6103e83660046137f1565b610d6d565b3480156103f957600080fd5b5061033a610408366004613892565b610ef8565b34801561041957600080fd5b50610448610428366004613842565b6001600160a01b039081166000908152603a602052604090205416151590565b60405190151581526020016102fc565b34801561046457600080fd5b5061033a6104733660046138e7565b611051565b34801561048457600080fd5b50606e54606d54604080519283526020830191909152016102fc565b3480156104ac57600080fd5b506102cf6104bb366004613866565b61111e565b3480156104cc57600080fd5b506102cf6104db366004613929565b6111ca565b6102cf6104ee366004613842565b6111dc565b3480156104ff57600080fd5b506102cf61124a565b34801561051457600080fd5b506102f26201518081565b34801561052b57600080fd5b506102cf61053a36600461394b565b61136c565b34801561054b57600080fd5b506102f261055a366004613964565b61137d565b34801561056b57600080fd5b506102cf61057a36600461399d565b6113c4565b34801561058b57600080fd5b506102f261059a366004613964565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b3480156105d557600080fd5b506102cf6105e43660046139ed565b611479565b3480156105f557600080fd5b506102cf61060436600461394b565b611494565b34801561061557600080fd5b506102f2610624366004613842565b6001600160a01b031660009081526037602052604090206003015490565b34801561064e57600080fd5b50606c546102f2565b34801561066357600080fd5b5061033a6106723660046138e7565b6114a5565b34801561068357600080fd5b506102cf610692366004613a09565b611546565b3480156106a357600080fd5b506102cf6106b23660046136cb565b611639565b3480156106c357600080fd5b506102cf6106d236600461394b565b611798565b3480156106e357600080fd5b506102cf6106f2366004613842565b6117a9565b6102cf610705366004613a3e565b611832565b34801561071657600080fd5b506039546102f2565b34801561072b57600080fd5b506102cf61073a366004613866565b611886565b34801561074b57600080fd5b5061077861075a366004613842565b6001600160a01b039081166000908152603a60205260409020541690565b6040516001600160a01b0390911681526020016102fc565b34801561079c57600080fd5b506107dc6107ab366004613842565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604080516001600160a01b0390941684526020840192909252908201526060016102fc565b34801561080d57600080fd5b5061077861081c366004613ab2565b6119a2565b34801561082d57600080fd5b506102cf61083c366004613acd565b611a36565b34801561084d57600080fd5b506102cf61085c366004613b19565b611c07565b34801561086d57600080fd5b506102f261087c3660046138e7565b611d54565b61088a816119a2565b6001600160a01b0316336001600160a01b0316146108ef576000356001600160e01b03191681336040517f8383e6340000000000000000000000000000000000000000000000000000000081526004016108e693929190613b87565b60405180910390fd5b50565b6060838214610914576040516376081a7b60e11b815260040160405180910390fd5b8367ffffffffffffffff81111561092d5761092d613bbc565b604051908082528060200260200182016040528015610956578160200160208202803683370190505b50905060005b8151811015610a22576037600087878481811061097b5761097b613bd2565b90506020020160208101906109909190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002060040160008585848181106109c7576109c7613bd2565b90506020020160208101906109dc9190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610a0f57610a0f613bd2565b602090810291909101015260010161095c565b50949350505050565b6000600260005403610a7f5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005581610a8e81611e04565b336000908152603a60205260409020546001600160a01b031615610ac757604051632fc6bfb160e21b81523360048201526024016108e6565b610ad333868686611ebb565b600160005595945050505050565b466107e514610b325760405162461bcd60e51b815260206004820152600260248201527f453100000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b7357832a94810e18c84a5a5e2c4dd67d012ade574f3314610b955760405162461bcd60e51b815260206004820152600260248201527f453200000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b610b9f60086119a2565b60405163f883afaf60e01b81526001600160a01b0386811660048301528581166024830152848116604483015260648201849052919091169063f883afaf906084015b600060405180830381600087803b158015610bfc57600080fd5b505af1158015610c10573d6000803e3d6000fd5b5050505050505050565b80610c2481611e04565b6001600160a01b038216600090815260376020526040902033610c478282611f28565b610c5160086119a2565b6039546040517fdd716ad30000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063dd716ad390604401610be2565b610cab611f71565b80610cb581611e04565b6001600160a01b0382166000908152603760205260409020610cd8903334611fad565b5050565b60006008610ce981610881565b6001600160a01b0384166000908152603760205260409020610d0b9084612058565b915033610d1881846120f5565b610d6557604080518481524760208201526001600160a01b0380841692908816917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b505092915050565b600260005403610dbf5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000908155338152603a60205260409020546001600160a01b031615610dfc57604051632fc6bfb160e21b81523360048201526024016108e6565b606d54811180610e0d5750606e5481105b15610e2b57604051631b8454a360e21b815260040160405180910390fd5b3433610e3b818787878787612151565b6001600160a01b03808616600081815260376020818152604080842060018101805497891673ffffffffffffffffffffffffffffffffffffffff19988916811790915581548816871782558552603a835290842080549096168517909555929091529052610eaa818385611fad565b816001600160a01b0316866001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a3505060016000555050505050565b6060600080610f0760086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f44573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f689190613be8565b90508367ffffffffffffffff811115610f8357610f83613bbc565b604051908082528060200260200182016040528015610fac578160200160208202803683370190505b50925060005b8481101561104757858582818110610fcc57610fcc613bd2565b9050602002016020810190610fe19190613842565b925061102283888461101d878c6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b6123df565b84828151811061103457611034613bd2565b6020908102919091010152600101610fb2565b5050509392505050565b60608167ffffffffffffffff81111561106c5761106c613bbc565b604051908082528060200260200182016040528015611095578160200160208202803683370190505b50905060005b8281101561111757603760008585848181106110b9576110b9613bd2565b90506020020160208101906110ce9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000206002015482828151811061110457611104613bd2565b602090810291909101015260010161109b565b5092915050565b6002600054036111705760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260009081556001600160a01b038316815260376020526040902033906111999082846124db565b6111a38183612777565b6111c057604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b6111d26127d8565b610cd8828261284c565b6111e4611f71565b806111ee81611e04565b336000908152603a60205260409020546001600160a01b03161561122757604051632fc6bfb160e21b81523360048201526024016108e6565b6001600160a01b0382166000908152603760205260409020610cd89033346128c0565b60d154600290610100900460ff1615801561126c575060d15460ff8083169116105b6112de5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805461ffff191660ff83161761010017905560365461130a906008906001600160a01b031661296f565b6036805473ffffffffffffffffffffffffffffffffffffffff1916905560d1805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6113746127d8565b6108ef81612a20565b60006113bb838361138c612a55565b6001600160a01b038088166000908152603760209081526040808320938a1683526004909301905220546123df565b90505b92915050565b6002600054036114165760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000558161142581611e04565b6001600160a01b0384166000908152603760205260409020339061144a9082856124db565b6001600160a01b038416600090815260376020526040902061146d9082856128c0565b50506001600055505050565b6114816127d8565b61148a81612ac7565b610cd8828261296f565b61149c6127d8565b6108ef81612b16565b60608167ffffffffffffffff8111156114c0576114c0613bbc565b6040519080825280602002602001820160405280156114e9578160200160208202803683370190505b50905060005b828110156111175761152184848381811061150c5761150c613bd2565b90506020020160208101906106249190613842565b82828151811061153357611533613bd2565b60209081029190910101526001016114ef565b8261155081611e04565b6001600160a01b0384166000908152603760205260409020336115738282611f28565b606d548411806115845750606e5484105b156115a257604051631b8454a360e21b815260040160405180910390fd5b6115ac60086119a2565b6040517fe5125a1d0000000000000000000000000000000000000000000000000000000081526001600160a01b0388811660048301526024820188905260448201879052919091169063e5125a1d906064015b600060405180830381600087803b15801561161957600080fd5b505af115801561162d573d6000803e3d6000fd5b50505050505050505050565b60026000540361168b5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005582158061169d5750828114155b156116bb576040516376081a7b60e11b815260040160405180910390fd5b336000805b85811015611763578484828181106116da576116da613bd2565b90506020020135826116ec9190613c17565b915061175b6037600089898581811061170757611707613bd2565b905060200201602081019061171c9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000208487878581811061174f5761174f613bd2565b905060200201356124db565b6001016116c0565b5061176e8282612777565b61178b57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b6117a06127d8565b6108ef81612b4b565b806117b381611e04565b6001600160a01b0382166000908152603760205260409020336117d68282611f28565b6117e060086119a2565b6039546040517fa7c2f1190000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063a7c2f11990604401610be2565b600861183d81610881565b61187e868680806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250889250879150869050612b80565b505050505050565b6002600054036118d85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600055816118e781611e04565b81600003611921576040517f31d9f7d700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061194c908690613c2a565b9050606c5481101561198a576040517fef0a995700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611995828487612fb1565b61176e83866104b06130b6565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156119d9576119d9613b5d565b60ff1681526020810191909152604001600020546001600160a01b0316905080611a3157816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016108e69190613c3d565b919050565b6008611a4181610881565b8215611c015760005b83811015611bc657600060376000878785818110611a6a57611a6a613bd2565b9050602002016020810190611a7f9190613842565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a9093529120805473ffffffffffffffffffffffffffffffffffffffff1916905560028101549091508015611b5357611ae38282612058565b506001820154611aff906001600160a01b0316826104b06130b6565b611b535760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b6000611b93888886818110611b6a57611b6a613bd2565b9050602002016020810190611b7f9190613842565b60018501546001600160a01b031688613116565b90508015611bb8576001830154611bb6906001600160a01b0316826104b06130b6565b505b836001019350505050611a4a565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d88484604051611bf8929190613c4b565b60405180910390a15b50505050565b60d154610100900460ff1615808015611c27575060d154600160ff909116105b80611c415750303b158015611c41575060d15460ff166001145b611cb35760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805460ff191660011790558015611cd65760d1805461ff0019166101001790555b611ce160088761296f565b611cea85612a20565b611cf560008561284c565b611cfe83612b16565b611d0782612b4b565b801561187e5760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a1505050505050565b6000600260005403611da85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600081905550611ded3384848080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b9050611df93382613296565b600160005592915050565b611e0e60086119a2565b604051635061f96960e11b81526001600160a01b038381166004830152919091169063a0c3f2d290602401602060405180830381865afa158015611e56573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e7a9190613c99565b6108ef576040517f1fa18c8a0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b6000611efa8585858080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b6001600160a01b0383166000908152603760205260409020909150611f209086836128c0565b949350505050565b60018201546001600160a01b03828116911614610cd8576040517ff78cb7ae00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b34600003611fab576040517fdbf97bca00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b8282611fb98282611f28565b82856002016000828254611fcd9190613c17565b92505081905550611ff385858760020154868960030154611fee9190613c17565b6132e4565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d906120499086815260200190565b60405180910390a25050505050565b600061206883600201548361331f565b90508083600201600082825461207e9190613c2a565b90915550506001830154600284015460038501546120ae9286926001600160a01b0390911691611fee9086613335565b82546040518281526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f759060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612142576040519150601f19603f3d011682016040523d82523d6000602084013e612147565b606091505b5090949350505050565b61215f8660006104b06130b6565b6121bd576040805163338f030160e01b81526001600160a01b03881660048201526024810191909152600a60448201527f706f6f6c2061646d696e0000000000000000000000000000000000000000000060648201526084016108e6565b6121cb8360006104b06130b6565b612229576040805163338f030160e01b81526001600160a01b03851660048201526024810191909152600860448201527f747265617375727900000000000000000000000000000000000000000000000060648201526084016108e6565b606c5481101561224c57604051630a8d7fa760e21b815260040160405180910390fd5b846001600160a01b0316866001600160a01b031614158061227f5750826001600160a01b0316856001600160a01b031614155b156122b6576040517fdc1d04ff00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60408051600280825260608201835260009260208301908036833701905050905086816000815181106122eb576122eb613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050848160018151811061231f5761231f613bd2565b60200260200101906001600160a01b031690816001600160a01b0316815250506123488161334f565b1561238d576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b5061239860086119a2565b60405163f883afaf60e01b81526001600160a01b0387811660048301528681166024830152858116604483015260648201859052919091169063f883afaf906084016115ff565b6001600160a01b0380851660009081526002602090815260408083209387168352929052908120600381015484900361241a57549050611f20565b6001600160a01b03861660009081526003602081815260408084206001808452828620948701548652939092528320918201548392901561247f57805460018601549094506124699085613c2a565b85600201546124789190613cbb565b9250612487565b846001015493505b8154600090612497908690613c2a565b6124a19089613cbb565b9050670de0b6b3a76400006124b68286613c17565b6124c09190613cd2565b86546124cc9190613c17565b9b9a5050505050505050505050565b82826124e782826133ee565b82600003612521576040517ff5618d5a00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0384166000908152600486016020526040902054831115612575576040517f34aa9a2800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600061258160086119a2565b8654604051635061f96960e11b81526001600160a01b03918216600482015291925082169063a0c3f2d290602401602060405180830381865afa1580156125cc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125f09190613c99565b8015612683575085546040517f28bde1e10000000000000000000000000000000000000000000000000000000081526001600160a01b039182166004820152908216906328bde1e19060240160e060405180830381865afa158015612659573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061267d9190613cff565b60a00151155b80156126b657506038546001600160a01b038616600090815260058801602052604090205442916126b391613c17565b10155b156126ed576040517ff19f52bd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260048701602052604090205461272b908790879061271b908890613c2a565b878a60030154611fee9190613c2a565b85546040518581526001600160a01b03918216918716907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c9060200160405180910390a3505050505050565b6000814710156127ce576040517f98c713c00000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152476024820152604481018390526064016108e6565b6113bb83836120f5565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611fab576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108e6929190613dab565b61271081118061285b57508082115b1561287957604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b82826128cc82826133ee565b6001600160a01b038416600090815260048601602052604090205461290a90869086906128fa908790613c17565b868960030154611fee9190613c17565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b906129609087815260200190565b60405180910390a35050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156129a5576129a5613b5d565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f8111156129f3576129f3613b5d565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be290602001611361565b6000612a6160086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015612a9e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612ac29190613be8565b905090565b806001600160a01b03163b6000036108ef576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a90602001611361565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c67890602001611361565b83518214612bc957807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a5858585604051612bbc93929190613e12565b60405180910390a2611c01565b6000806000806000885167ffffffffffffffff811115612beb57612beb613bbc565b604051908082528060200260200182016040528015612c14578160200160208202803683370190505b5090506000895167ffffffffffffffff811115612c3357612c33613bbc565b604051908082528060200260200182016040528015612c5c578160200160208202803683370190505b50905060008a5167ffffffffffffffff811115612c7b57612c7b613bbc565b604051908082528060200260200182016040528015612ca4578160200160208202803683370190505b50905060005b8b51811015612f17578b8181518110612cc557612cc5613bd2565b6020908102919091018101516001600160a01b038116600090815260038084526040808320603790955290912001549097506001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a9003612d6657868389806001019a5081518110612d4057612d40613bd2565b60200260200101906001600160a01b031690816001600160a01b03168152505050612f05565b60028101548a1115612d9457604080518082019091528681526020018a905260018101869055600281018a90555b600181015415612dde5760018101548c8c84818110612db557612db5613bd2565b90506020020135670de0b6b3a7640000612dcf9190613cbb565b612dd99190613cd2565b612de1565b60005b985088816000016000828254612df79190613c17565b9182905550905085612e098a85613c2a565b81518110612e1957612e19613bd2565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c815260200190815260200160002060008201518160000155602082015181600101559050508581600101600001819055508060010160000154848984612eac9190613c2a565b81518110612ebc57612ebc613bd2565b6020908102919091010152868d612ed38a85613c2a565b81518110612ee357612ee3613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050505b80612f0f81613e75565b915050612caa565b508515612f6057858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a382604051612f579190613e8e565b60405180910390a25b8a5115612fa457877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c8585604051612f9b93929190613ea1565b60405180910390a25b5050505050505050505050565b8282612fbd8282611f28565b8460020154831115612fe257604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b0385166000908152600587016020526040902054429161300b91613c17565b1115613043576040517f07b6105200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828560020160008282546130579190613c2a565b9250508190555061307885858760020154868960030154611fee9190613c2a565b84546040518481526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f7590602001612049565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613106576040519150601f19603f3d011682016040523d82523d6000602084013e61310b565b606091505b509095945050505050565b6001600160a01b0380841660009081526037602090815260408083209386168352600490930190529081205461314e858585846123df565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b78460405161319591815260200190565b60405180910390a36001600160a01b038086166000818152600260209081526040808320948916835293815283822082815592825260039052919091206131df9082868580613437565b60038181018590556001600160a01b03878116600081815260209384526040808220546001870155519081529188169290917faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad910160405180910390a350509392505050565b600080613250612a55565b905060005b8351811015610d655761328284828151811061327357613273613bd2565b60200260200101518684613116565b61328c9084613c17565b9250600101613255565b6132a08282612777565b610cd8576040517f3b97b7700000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b83546132fa906001600160a01b031684846134e2565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b600081831061332e57816113bb565b5090919050565b60008183116133455760006113bb565b6113bb8284613c2a565b6000815160000361336257506000919050565b60005b60018351038110156133e557600181015b83518110156133dc5783818151811061339157613391613bd2565b60200260200101516001600160a01b03168483815181106133b4576133b4613bd2565b60200260200101516001600160a01b0316036133d4575060019392505050565b600101613376565b50600101613365565b50600092915050565b60018201546001600160a01b03808316911603610cd8576040517f9feb934700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828460030154101561344b57600284018190555b600061345b85600201548461331f565b9050600081866002015461346f9190613c2a565b905080156134d9576002860182905560018701548111156134bc576040517fa5ca437e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808760010160000160008282546134d39190613c2a565b90915550505b50505050505050565b60006134ec612a55565b6001600160a01b0385166000908152600360205260409020600181015460028201549293509091831115613560576040518060400160405280613547886001600160a01b031660009081526037602052604090206003015490565b8152602090810185905281516001850155015160028301555b6001600160a01b038681166000818152600260209081526040808320948a1680845294825280832093835260378252808320948352600490940190529182205490916135ae898988856123df565b83549091508114613600578083556040518181526001600160a01b0389811691908b16907faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad9060200160405180910390a35b61360d8584888a86613437565b845460018085019190915560038401879055850154841461367457886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c876001016000015460405161366b91815260200190565b60405180910390a35b505050505050505050565b60008083601f84011261369157600080fd5b50813567ffffffffffffffff8111156136a957600080fd5b6020830191508360208260051b85010111156136c457600080fd5b9250929050565b600080600080604085870312156136e157600080fd5b843567ffffffffffffffff808211156136f957600080fd5b6137058883890161367f565b9096509450602087013591508082111561371e57600080fd5b5061372b8782880161367f565b95989497509550505050565b600081518084526020808501945080840160005b838110156137675781518752958201959082019060010161374b565b509495945050505050565b6020815260006113bb6020830184613737565b6001600160a01b03811681146108ef57600080fd5b6000806000604084860312156137af57600080fd5b833567ffffffffffffffff8111156137c657600080fd5b6137d28682870161367f565b90945092505060208401356137e681613785565b809150509250925092565b6000806000806080858703121561380757600080fd5b843561381281613785565b9350602085013561382281613785565b9250604085013561383281613785565b9396929550929360600135925050565b60006020828403121561385457600080fd5b813561385f81613785565b9392505050565b6000806040838503121561387957600080fd5b823561388481613785565b946020939093013593505050565b6000806000604084860312156138a757600080fd5b83356138b281613785565b9250602084013567ffffffffffffffff8111156138ce57600080fd5b6138da8682870161367f565b9497909650939450505050565b600080602083850312156138fa57600080fd5b823567ffffffffffffffff81111561391157600080fd5b61391d8582860161367f565b90969095509350505050565b6000806040838503121561393c57600080fd5b50508035926020909101359150565b60006020828403121561395d57600080fd5b5035919050565b6000806040838503121561397757600080fd5b823561398281613785565b9150602083013561399281613785565b809150509250929050565b6000806000606084860312156139b257600080fd5b83356139bd81613785565b925060208401356139cd81613785565b929592945050506040919091013590565b803560108110611a3157600080fd5b60008060408385031215613a0057600080fd5b613982836139de565b600080600060608486031215613a1e57600080fd5b8335613a2981613785565b95602085013595506040909401359392505050565b600080600080600060608688031215613a5657600080fd5b853567ffffffffffffffff80821115613a6e57600080fd5b613a7a89838a0161367f565b90975095506020880135915080821115613a9357600080fd5b50613aa08882890161367f565b96999598509660400135949350505050565b600060208284031215613ac457600080fd5b6113bb826139de565b600080600060408486031215613ae257600080fd5b833567ffffffffffffffff811115613af957600080fd5b613b058682870161367f565b909790965060209590950135949350505050565b600080600080600060a08688031215613b3157600080fd5b8535613b3c81613785565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052602160045260246000fd5b60108110613b8357613b83613b5d565b9052565b6001600160e01b03198416815260608101613ba56020830185613b73565b6001600160a01b0383166040830152949350505050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b600060208284031215613bfa57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b808201808211156113be576113be613c01565b818103818111156113be576113be613c01565b602081016113be8284613b73565b60208082528181018390526000908460408401835b86811015613c8e578235613c7381613785565b6001600160a01b031682529183019190830190600101613c60565b509695505050505050565b600060208284031215613cab57600080fd5b8151801515811461385f57600080fd5b80820281158282048414176113be576113be613c01565b600082613cef57634e487b7160e01b600052601260045260246000fd5b500490565b8051611a3181613785565b600060e08284031215613d1157600080fd5b60405160e0810181811067ffffffffffffffff82111715613d4257634e487b7160e01b600052604160045260246000fd5b604052613d4e83613cf4565b8152613d5c60208401613cf4565b6020820152613d6d60408401613cf4565b6040820152613d7e60608401613cf4565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b6001600160e01b03198316815260408101600b8310613dcc57613dcc613b5d565b8260208301529392505050565b600081518084526020808501945080840160005b838110156137675781516001600160a01b031687529582019590820190600101613ded565b604081526000613e256040830186613dd9565b82810360208401528381527f07ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff841115613e5d57600080fd5b8360051b808660208401370160200195945050505050565b600060018201613e8757613e87613c01565b5060010190565b6020815260006113bb6020830184613dd9565b606081526000613eb46060830186613dd9565b8281036020840152613ec68186613737565b90508281036040840152613eda8185613737565b969550505050505056fea26469706673582212209c26c9b27087c4ace8fe06bea64a20c6bdad77f3bf4c4bee053bd164543bfbec64736f6c6343000815003300000000000000000000000000 + ├─ [3277977] → new Staking@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + │ ├─ emit Initialized(version: 255) + │ └─ ← 16154 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(5) [staticcall] + │ └─ ← ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758] + ├─ [0] VM::load(ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [36277] ronin-mainnet.Staking::upgradeToAndCall(Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + │ ├─ [24636] Staking::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], Staking, StakingLogic, 0x, 2)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, StakingLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(0) [staticcall] + │ └─ ← ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6] + ├─ [0] GeneralConfig::getContractName(4) [staticcall] + │ └─ ← SlashIndicator + ├─ [0] GeneralConfig::getContractFileName(4) [staticcall] + │ └─ ← SlashIndicator.sol:SlashIndicator + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000003 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(SlashIndicator.sol:SlashIndicator) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000390160806040523480156200001157600080fd5b506200001c62000022565b620000e7565b61011354610100900460ff1615620000905760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b6101135460ff9081161015620000e557610113805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61380a80620000f76000396000f3fe608060405234801561001057600080fd5b506004361061020b5760003560e01c806399103f7b1161012a578063d1cf4343116100bd578063df4b6ee01161008c578063f1001e7811610071578063f1001e78146104a9578063f562b3c4146104c9578063fd422cd0146104d257600080fd5b8063df4b6ee01461047e578063e9bb1666146104a257600080fd5b8063d1cf43431461041c578063d1f992f71461042f578063d3dd2bdf14610442578063de981f1b1461046b57600080fd5b8063c6391fa2116100f9578063c6391fa2146103d2578063ccbb72ed146103e3578063cf39d13c146103f6578063d1737e271461040957600080fd5b806399103f7b1461038e578063a345ecb2146103a1578063c008ce39146103b4578063c2e524dc146103c757600080fd5b80633101cfcb116101a25780637680850c116101715780637680850c1461033a5780637c2b55a01461034d578063853af1b714610368578063865e6fd31461037b57600080fd5b80633101cfcb146102e75780633d48fd7d146102fa578063487e00ea1461030b57806362ffe6cb1461032757600080fd5b80631a697341116101de5780631a6973411461028b5780631e90b2a01461029e57806329b6eca9146102b157806329ddc3c0146102c457600080fd5b806307c2d2f614610210578063082e7420146102255780630e1512ac1461024b5780631079402a1461025e575b600080fd5b61022361021e366004612a4b565b6104e5565b005b610238610233366004612aa2565b6105f3565b6040519081526020015b60405180910390f35b610223610259366004612abf565b61066a565b606d54606e54606f546070545b604080519485526020850193909352918301526060820152608001610242565b610223610299366004612aa2565b610684565b6102236102ac366004612b33565b610993565b6102236102bf366004612aa2565b610ba0565b6102d76102d2366004612bb6565b610d14565b6040519015158152602001610242565b6102236102f5366004612aa2565b610d43565b60a55460a65460a75460a85461026b565b601d54601e545b60408051928352602083019190915201610242565b610238610335366004612bb6565b610e37565b610223610348366004612be2565b610e60565b60675b6040516001600160a01b039091168152602001610242565b610223610376366004612c2e565b611177565b610223610389366004612c5f565b61118d565b61022361039c366004612cb8565b6111a8565b6102236103af366004612c2e565b61135a565b6102236103c2366004612d76565b61136c565b603854603954610312565b60dd5460de5460df5460e05461026b565b6102236103f1366004612abf565b61141a565b610223610404366004612dab565b61142e565b610223610417366004612abf565b611446565b61022361042a366004612dd7565b61145a565b61022361043d366004612aa2565b6117da565b610238610450366004612aa2565b6001600160a01b0316600090815260dc602052604090205490565b610350610479366004612e96565b611c78565b60015460025460035460408051938452602084019290925290820152606001610242565b6069610350565b6104bc6104b7366004612a4b565b611d0c565b6040516102429190612eec565b61023860a35481565b6102236104e0366004612aa2565b611dd7565b60086104f081612161565b60008267ffffffffffffffff81111561050b5761050b612eff565b604051908082528060200260200182016040528015610534578160200160208202803683370190505b50905060005b838110156105b157600085858381811061055657610556612f15565b905060200201602081019061056b9190612aa2565b6001600160a01b038116600090815260dc6020526040812055835190915083908390811061059b5761059b612f15565b600060209182029290920101525060010161053a565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c234808484836040516105e593929190612f69565b60405180910390a150505050565b6000610664826106036008611c78565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610640573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103359190612f99565b92915050565b6106726121c6565b61067e84848484612222565b50505050565b61068c6121c6565b6000610698600a611c78565b6040517fdb6693a20000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063db6693a29060240160a060405180830381865afa1580156106f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061071d919061303a565b905060006107c061072e600b611c78565b60408085015190517f988ef53c0000000000000000000000000000000000000000000000000000000081526001600160a01b03918216600482015291169063988ef53c90602401602060405180830381865afa158015610792573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107b69190612f99565b83608001516122cd565b905060006107ce6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610810573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108349190612f99565b60385490915061084484436130d8565b11158061087457506001600160a01b038516600090815260376020908152604080832084845290915290205460ff165b156108ab576040517f5c61141600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600081815260376020908152604080832085845290915290819020805460ff19166001179055517f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d99061090c906004908590613101565b60405180910390a2603954604051630bde081360e21b81526001600160a01b0387811660048301526000602483018190526044830193909352606482019290925290831690632f78204c90608401600060405180830381600087803b15801561097457600080fd5b505af1158015610988573d6000803e3d6000fd5b505050505050505050565b61099b6121c6565b600084846040516109ad92919061311f565b60405180910390209050600083836040516109c992919061311f565b604080519182900390912060008481526004602052919091205490915060ff1680610a02575060008181526004602052604090205460ff165b15610a205760405163f27b8ec960e01b815260040160405180910390fd5b610a2d87878787876122e4565b15610b97576000610a3e6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa49190612f99565b6000858152600460205260408082208054600160ff19918216811790925587845292829020805490931617909155519091506001600160a01b038a16907f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d990610b11906003908590613101565b60405180910390a260025460018054604051630bde081360e21b81526001600160a01b038d8116600483015260248201949094526044810191909152606481019190915290831690632f78204c90608401600060405180830381600087803b158015610b7c57600080fd5b505af1158015610b90573d6000803e3d6000fd5b5050505050505b50505050505050565b61011354600290610100900460ff16158015610bc457506101135460ff8083169116105b610c2c5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b610113805461ffff191660ff831617610100179055600054610c59906008906001600160a01b03166123d5565b606c54610c71906005906001600160a01b03166123d5565b610c7c6004836123d5565b603554610c9490600a906001600160a01b03166123d5565b6000805473ffffffffffffffffffffffffffffffffffffffff19908116909155606c8054821690556035805482169055603680549091169055610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b61011354600390610100900460ff16158015610d6757506101135460ff8083169116105b610dca5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805461ffff191660ff831617610100179055610dea600f836123d5565b610df8600154600254612486565b610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610d08565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610d3c565b6008610e6b81612161565b60003390506000816001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610eb0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ed49190612f99565b90506000826001600160a01b0316634de2b73588886040518363ffffffff1660e01b8152600401610f0692919061312f565b600060405180830381865afa158015610f23573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610f4b9190810190613177565b90506000610f596005611c78565b6001600160a01b031663ba303755898986436040518563ffffffff1660e01b8152600401610f8a9493929190613214565b600060405180830381865afa158015610fa7573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610fcf9190810190613177565b905060008767ffffffffffffffff811115610fec57610fec612eff565b604051908082528060200260200182016040528015611015578160200160208202803683370190505b50905060005b888110156111305760008a8a8381811061103757611037612f15565b905060200201602081019061104c9190612aa2565b9050600061105a828b610e37565b9050600086848151811061107057611070612f15565b60200260200101519050600086858151811061108e5761108e612f15565b60200260200101519050600082806110a35750815b6110b8576110b360dd54856124c6565b6110bb565b60005b6001600160a01b038616600090815260dc602052604090205460de549192506110e59183906124e0565b6001600160a01b038616600090815260dc60205260409020819055875188908890811061111457611114612f15565b602002602001018181525050856001019550505050505061101b565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c2348089898360405161116493929190612f69565b60405180910390a1505050505050505050565b61117f6121c6565b61118982826124fd565b5050565b6111956121c6565b61119e8161253d565b61118982826123d5565b61011354610100900460ff16158080156111ca575061011354600160ff909116105b806111e55750303b1580156111e557506101135460ff166001145b6112485760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805460ff19166001179055801561126d57610113805461ff0019166101001790555b61127860088b6123d5565b61128360058a6123d5565b61128e6004886123d5565b611299600a896123d5565b6112b286356020880135604089013560608a0135612222565b6112c1853560208701356124fd565b6112d584356020860135604087013561258c565b6112ee83356020850135604086013560608701356125e1565b6113078235602084013560408501356060860135612686565b801561134e57610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6113626121c6565b6111898282612486565b600861137781612161565b826001036113c857836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96005846040516113bb929190613101565b60405180910390a261067e565b8260020361067e57836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960068460405161140c929190613101565b60405180910390a250505050565b6114226121c6565b61067e84848484612686565b6114366121c6565b61144183838361258c565b505050565b61144e6121c6565b61067e848484846125e1565b61146333612755565b600003611493576000356001600160e01b0319166003604051620f948f60ea1b8152600401610c2392919061323b565b600061149f600f611c78565b6040517ff46609400000000000000000000000000000000000000000000000000000000081526001600160a01b038a8116600483015291925060009183169063f466094090602401600060405180830381865afa158015611504573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261152c91908101906132fa565b60a0015190508080519060200120888860405161154a92919061311f565b604051809103902014611597576040517f053265f10000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b6040516bffffffffffffffffffffffff1960608b901b1660208201526034810187905260009060540160408051601f1981840301815291815281516020928301206000818152601f90935291205490915060ff16156116095760405163f27b8ec960e01b815260040160405180910390fd5b61167f89898080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250506040805180820182528c935091508a90600290839083908082843760009201919091525061167191508a9050613413565b61167a896134eb565b6127e6565b1561134e576000818152601f60205260408120805460ff191660011790556116a76008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116e9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061170d9190612f99565b90508b6001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960088360405161174b929190613101565b60405180910390a2601e54601d54604051630bde081360e21b81526001600160a01b038f81166004830152602482019390935260448101919091526001606482015290831690632f78204c90608401600060405180830381600087803b1580156117b457600080fd5b505af11580156117c8573d6000803e3d6000fd5b50505050505050505050505050505050565b60006117e66008611c78565b6040517fa0c3f2d20000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301529192509082169063a0c3f2d290602401602060405180830381865afa158015611849573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061186d9190613544565b61189a576000356001600160e01b0319166008604051620f948f60ea1b8152600401610c2392919061323b565b6040517f04d971ab0000000000000000000000000000000000000000000000000000000081526001600160a01b0383811660048301523360248301528216906304d971ab90604401602060405180830381865afa1580156118ff573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119239190613544565b611950576000356001600160e01b0319166004604051620f948f60ea1b8152600401610c2392919061323b565b6040517f96585fc20000000000000000000000000000000000000000000000000000000081526001600160a01b03838116600483015260009182918416906396585fc290602401606060405180830381865afa1580156119b4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119d8919061355f565b925050915081611a14576040517f6cd31b5900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000836001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611a54573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a789190612f99565b6001600160a01b038616600090815260db6020908152604080832084845290915290205490915060ff1615611ad9576040517f7674d6a900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260dc602052604081205460df54909190611b029085613594565b905080821015611b3e576040517f8c5cb26e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040517f15b5ebde0000000000000000000000000000000000000000000000000000000081526001600160a01b038881166004830152602482018590528716906315b5ebde90604401600060405180830381600087803b158015611ba157600080fd5b505af1158015611bb5573d6000803e3d6000fd5b505050506001600160a01b038716600090815260dc602052604081208054839290611be19084906130d8565b90915550506001600160a01b038716600090815260a4602090815260408083208684529091528120556001600160a01b038716600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a250505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115611caf57611caf6130eb565b60ff1681526020810191909152604001600020546001600160a01b0316905080611d0757816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c2391906135bf565b919050565b60608167ffffffffffffffff811115611d2757611d27612eff565b604051908082528060200260200182016040528015611d50578160200160208202803683370190505b50905060005b8151811015611dd05760dc6000858584818110611d7557611d75612f15565b9050602002016020810190611d8a9190612aa2565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611dbd57611dbd612f15565b6020908102919091010152600101611d56565b5092915050565b60a3544311611e12576040517f557fd09100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b4360a355334114611e46576000356001600160e01b0319166002604051620f948f60ea1b8152600401610c2392919061323b565b611e4f8161286f565b1561215e576000611e606008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611ea2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ec69190612f99565b6001600160a01b038416600090815260a460209081526040808320848452909152812080546001019081905560a85492935091611f049043906129b7565b905060a6548203611fcd57846001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600285604051611f4b929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0387811660048301526024820184905260448201929092526000606482015290851690632f78204c90608401600060405180830381600087803b158015611fb057600080fd5b505af1158015611fc4573d6000803e3d6000fd5b50505050612159565b60a5548203612159576000611fe28685610d14565b9050806120a257856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600186604051612025929190613101565b60405180910390a2604051630bde081360e21b81526001600160a01b038781166004830152600060248301819052604483018190526064830152861690632f78204c90608401600060405180830381600087803b15801561208557600080fd5b505af1158015612099573d6000803e3d6000fd5b50505050612157565b856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96007866040516120de929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0388811660048301526024820185905260448201929092526001606482015290861690632f78204c90608401600060405180830381600087803b15801561214357600080fd5b505af115801561134e573d6000803e3d6000fd5b505b505050505b50565b61216a81611c78565b6001600160a01b0316336001600160a01b03161461215e576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c23939291906135cd565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314612220576000356001600160e01b0319166001604051620f948f60ea1b8152600401610c2392919061323b565b565b82841180612231575061271084115b8061223d575061271083115b15612274576040517f397c357e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b606d849055606e839055606f82905560708190556040805185815260208101859052908101839052606081018290527fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b906080016105e5565b6000818310156122dd5781610d3c565b5090919050565b6040516000906067906001908390612308908a908a908a908a908a9060240161362b565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7fc3567700000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b602083016020828483895afa61238257600094505b503d61238d57600093505b836123c4576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5115159a9950505050505050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561240b5761240b6130eb565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115612459576124596130eb565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b601d829055601e81905560408051838152602081018390527f381ec200df2ed0875638486318f9f8a84e3550bdc686bf1400c9371a18d087f09101610d08565b60008183116124d6576000610d3c565b610d3c82846130d8565b60006124f56124ef848661366d565b836129d2565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a9101610d08565b806001600160a01b03163b60000361215e576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c23565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b9060600160405180910390a1505050565b60a65460a554111561262d576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b60a584905560a683905560a782905560a88190556040805185815260208101859052908101839052606081018290527f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa98906080016105e5565b828411156126c0576040517f112af4d100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108111156126fc576040517fe0b2228c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60dd84905560de83905560df82905560e08190556040805185815260208101859052908101839052606081018290527fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b906080016105e5565b6000612761600a611c78565b6040517fd78392f80000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063d78392f890602401602060405180830381865afa1580156127c2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106649190612f99565b604051600090606990600190839061280a908a908a908a908a908a906024016136f1565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7b47d06b00000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b6000336001600160a01b03831614801590612914575061288f6008611c78565b6040517f65244ece0000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015291909116906365244ece90602401602060405180830381865afa1580156128f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129149190613544565b801561066457506129256005611c78565b6040517f0fbeb37f0000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301524360248301529190911690630fbeb37f90604401602060405180830381865afa15801561298c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129b09190613544565b1592915050565b6000816000036129c8576000610d3c565b610d3c828461366d565b60008183106122dd5781610d3c565b60405180602001604052806001906020820280368337509192915050565b60008083601f840112612a1157600080fd5b50813567ffffffffffffffff811115612a2957600080fd5b6020830191508360208260051b8501011115612a4457600080fd5b9250929050565b60008060208385031215612a5e57600080fd5b823567ffffffffffffffff811115612a7557600080fd5b612a81858286016129ff565b90969095509350505050565b6001600160a01b038116811461215e57600080fd5b600060208284031215612ab457600080fd5b8135610d3c81612a8d565b60008060008060808587031215612ad557600080fd5b5050823594602084013594506040840135936060013592509050565b60008083601f840112612b0357600080fd5b50813567ffffffffffffffff811115612b1b57600080fd5b602083019150836020828501011115612a4457600080fd5b600080600080600060608688031215612b4b57600080fd5b8535612b5681612a8d565b9450602086013567ffffffffffffffff80821115612b7357600080fd5b612b7f89838a01612af1565b90965094506040880135915080821115612b9857600080fd5b50612ba588828901612af1565b969995985093965092949392505050565b60008060408385031215612bc957600080fd5b8235612bd481612a8d565b946020939093013593505050565b600080600060408486031215612bf757600080fd5b833567ffffffffffffffff811115612c0e57600080fd5b612c1a868287016129ff565b909790965060209590950135949350505050565b60008060408385031215612c4157600080fd5b50508035926020909101359150565b803560108110611d0757600080fd5b60008060408385031215612c7257600080fd5b612c7b83612c50565b91506020830135612c8b81612a8d565b809150509250929050565b806080810183101561066457600080fd5b806040810183101561066457600080fd5b60008060008060008060008060006102a08a8c031215612cd757600080fd5b8935612ce281612a8d565b985060208a0135612cf281612a8d565b975060408a0135612d0281612a8d565b965060608a0135612d1281612a8d565b9550612d218b60808c01612c96565b9450612d318b6101008c01612ca7565b93506101a08a018b811115612d4557600080fd5b6101408b019350612d568c82612c96565b925050612d678b6102208c01612c96565b90509295985092959850929598565b600080600060608486031215612d8b57600080fd5b8335612d9681612a8d565b95602085013595506040909401359392505050565b600080600060608486031215612dc057600080fd5b505081359360208301359350604090920135919050565b600080600080600080600060e0888a031215612df257600080fd5b8735612dfd81612a8d565b9650602088013567ffffffffffffffff80821115612e1a57600080fd5b612e268b838c01612af1565b909850965060408a01359550869150612e428b60608c01612ca7565b945060a08a0135915080821115612e5857600080fd5b612e648b838c01612ca7565b935060c08a0135915080821115612e7a57600080fd5b50612e878a828b01612ca7565b91505092959891949750929550565b600060208284031215612ea857600080fd5b610d3c82612c50565b600081518084526020808501945080840160005b83811015612ee157815187529582019590820190600101612ec5565b509495945050505050565b602081526000610d3c6020830184612eb1565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b8183526000602080850194508260005b85811015612ee1578135612f4e81612a8d565b6001600160a01b031687529582019590820190600101612f3b565b604081526000612f7d604083018587612f2b565b8281036020840152612f8f8185612eb1565b9695505050505050565b600060208284031215612fab57600080fd5b5051919050565b60405160c0810167ffffffffffffffff81118282101715612fd557612fd5612eff565b60405290565b6040805190810167ffffffffffffffff81118282101715612fd557612fd5612eff565b604051601f8201601f1916810167ffffffffffffffff8111828210171561302757613027612eff565b604052919050565b8051611d0781612a8d565b600060a0828403121561304c57600080fd5b60405160a0810181811067ffffffffffffffff8211171561306f5761306f612eff565b604052825161307d81612a8d565b8152602083015161308d81612a8d565b602082015260408301516130a081612a8d565b6040820152606083810151908201526080928301519281019290925250919050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610664576106646130c2565b634e487b7160e01b600052602160045260246000fd5b6040810160098410613115576131156130eb565b9281526020015290565b8183823760009101908152919050565b6020815260006124f5602083018486612f2b565b600067ffffffffffffffff82111561315d5761315d612eff565b5060051b60200190565b80518015158114611d0757600080fd5b6000602080838503121561318a57600080fd5b825167ffffffffffffffff8111156131a157600080fd5b8301601f810185136131b257600080fd5b80516131c56131c082613143565b612ffe565b81815260059190911b820183019083810190878311156131e457600080fd5b928401925b82841015613209576131fa84613167565b825292840192908401906131e9565b979650505050505050565b606081526000613228606083018688612f2b565b6020830194909452506040015292915050565b6001600160e01b03198316815260408101600b831061325c5761325c6130eb565b8260208301529392505050565b600067ffffffffffffffff82111561328357613283612eff565b50601f01601f191660200190565b60005b838110156132ac578181015183820152602001613294565b50506000910152565b600082601f8301126132c657600080fd5b81516132d46131c082613269565b8181528460208386010111156132e957600080fd5b6124f5826020830160208701613291565b60006020828403121561330c57600080fd5b815167ffffffffffffffff8082111561332457600080fd5b9083019060c0828603121561333857600080fd5b613340612fb2565b825161334b81612a8d565b8152602083015161335b81612a8d565b6020820152604083015161336e81612a8d565b604082015261337f6060840161302f565b60608201526133906080840161302f565b608082015260a0830151828111156133a757600080fd5b6133b3878286016132b5565b60a08301525095945050505050565b600082601f8301126133d357600080fd5b81356133e16131c082613269565b8181528460208386010111156133f657600080fd5b816020850160208301376000918101602001919091529392505050565b600061341d612fdb565b80604084013681111561342f57600080fd5b845b818110156134e157803567ffffffffffffffff808211156134525760008081fd5b9087019036601f8301126134665760008081fd5b813560206134766131c083613143565b82815260059290921b840181019181810190368411156134965760008081fd5b8286015b848110156134ce578035868111156134b25760008081fd5b6134c03686838b01016133c2565b84525091830191830161349a565b5089525090960195505050602001613431565b5090949350505050565b60006134f5612fdb565b80604084013681111561350757600080fd5b845b818110156134e157803567ffffffffffffffff8111156135295760008081fd5b613535368289016133c2565b85525060209384019301613509565b60006020828403121561355657600080fd5b610d3c82613167565b60008060006060848603121561357457600080fd5b61357d84613167565b925060208401519150604084015190509250925092565b8082028115828204841417610664576106646130c2565b601081106135bb576135bb6130eb565b9052565b6020810161066482846135ab565b6001600160e01b031984168152606081016135eb60208301856135ab565b6001600160a01b0383166040830152949350505050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b038616815260606020820152600061364e606083018688613602565b8281036040840152613661818587613602565b98975050505050505050565b80820180821115610664576106646130c2565b60008151808452613698816020860160208601613291565b601f01601f19169290920160200192915050565b600082604081018360005b60028110156136e65783830387526136d0838351613680565b60209788019790935091909101906001016136b7565b509095945050505050565b60c08152600061370460c0830188613680565b60208781850152604084018760005b600281101561373057815183529183019190830190600101613713565b505050838203608085015281604081018760005b60028110156137b1578583038452815180518085529086019086850190600581901b8601880160005b8281101561379b57601f19888303018452613789828651613680565b948a0194938a0193915060010161376d565b5096880196955050509185019150600101613744565b505085810360a08701526137c581886136ac565b9b9a505050505050505050505056fea26469706673582212203dbb57dc8e95a92b94b022dfe41ffd6257773156df8af8a6f5401ce4ee74766764736f6c6343000815003300000000000000000000000000000000000000000000000000000000000000 + ├─ [2895930] → new SlashIndicator@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + │ ├─ emit Initialized(version: 255) + │ └─ ← 14346 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(4) [staticcall] + │ └─ ← ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3] + ├─ [0] VM::load(ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [78265] ronin-mainnet.SlashIndicator::upgradeToAndCall(SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], 0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6)  + │ ├─ emit Upgraded(param0: SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA]) + │ ├─ [66548] SlashIndicator::initializeV2(ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ ├─ emit ContractUpdated(contractType: 4, addr: ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) + │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], SlashIndicator, SlashIndicatorLogic, 0x, 3)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, SlashIndicatorLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(6) [staticcall] + │ └─ ← Profile + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(6) [staticcall] + │ └─ ← ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035] + ├─ [0] ronin-mainnet.SlashIndicator::initializeV3(ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035])  + │ ├─ [0] SlashIndicator::initializeV3(ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 15, addr: ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) + │ │ ├─ emit FastFinalitySlashingConfigsUpdated(slashFastFinalityAmount: 250000000000000000000000 [2.5e23], fastFinalityJailUntilBlock: 115792089237316195423570985008687907853269984665640564039457584007913129639935 [1.157e77]) + │ │ ├─ emit Initialized(version: 3) + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(11) [staticcall] + │ └─ ← RoninTrustedOrganization + ├─ [0] GeneralConfig::getContractFileName(11) [staticcall] + │ └─ ← RoninTrustedOrganization.sol:RoninTrustedOrganization + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000004 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(RoninTrustedOrganization.sol:RoninTrustedOrganization) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000206b608060405234801561001057600080fd5b5061204b806100206000396000f3fe608060405234801561001057600080fd5b50600436106101825760003560e01c806396c82e57116100d8578063cc7e6b3b1161008c578063db6693a211610066578063db6693a21461035a578063e75235b81461037a578063f09267c21461038557600080fd5b8063cc7e6b3b146102fb578063d78392f81461030e578063dafae4081461033757600080fd5b8063b505a07c116100bd578063b505a07c146102b8578063b7f67e97146102cb578063b9c36209146102d357600080fd5b806396c82e571461029d578063a85c7d6e146102a557600080fd5b8063562419111161013a5780637c37103c116101145780637c37103c1461026f5780637de5dedd14610282578063903bb3c51461028a57600080fd5b80635624191114610220578063691845a914610249578063708236251461025c57600080fd5b8063150740051161016b57806315074005146101c257806341feed1c146101d7578063520fce621461020057600080fd5b80630e777c06146101875780630ed285df146101ad575b600080fd5b61019a610195366004611aef565b610398565b6040519081526020015b60405180910390f35b6101c06101bb366004611ba9565b610404565b005b6101ca61041a565b6040516101a49190611beb565b61019a6101e5366004611c8f565b6001600160a01b031660009081526005602052604090205490565b61021361020e366004611aef565b610606565b6040516101a49190611caa565b61019a61022e366004611c8f565b6001600160a01b031660009081526007602052604090205490565b61019a610257366004611aef565b6106ca565b61021361026a366004611aef565b61072f565b6101c061027d366004611ce2565b6107f3565b61019a61094a565b61019a610298366004611aef565b610987565b60035461019a565b6101c06102b3366004611aef565b6109ec565b6101c06102c6366004611ba9565b610a96565b60095461019a565b6102e66102e1366004611d33565b610b35565b604080519283526020830191909152016101a4565b610213610309366004611aef565b610b56565b61019a61031c366004611c8f565b6001600160a01b031660009081526006602052604090205490565b61034a610345366004611d55565b610c1a565b60405190151581526020016101a4565b61036d610368366004611c8f565b610c41565b6040516101a49190611d6e565b6001546002546102e6565b61036d610393366004611d55565b610cf9565b6000805b828110156103fd57600760008585848181106103ba576103ba611dbc565b90506020020160208101906103cf9190611c8f565b6001600160a01b031681526020810191909152604001600020546103f39083611de8565b915060010161039c565b5092915050565b61040c610dff565b6104168282610e75565b5050565b60095460609067ffffffffffffffff81111561043857610438611dfb565b60405190808252806020026020018201604052801561049157816020015b6040805160a0810182526000808252602080830182905292820181905260608201819052608082015282526000199092019101816104565790505b5090506000805b825181101561060157600981815481106104b4576104b4611dbc565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104e7576104e7611dbc565b60209081029190910101516001600160a01b039091169052600a80548290811061051357610513611dbc565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061054357610543611dbc565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b818154811061057a5761057a611dbc565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106105aa576105aa611dbc565b6020908102919091018101516001600160a01b0392831660409182015291841660009081526005909152205483518490839081106105ea576105ea611dbc565b602090810291909101015160600152600101610498565b505090565b60608167ffffffffffffffff81111561062157610621611dfb565b60405190808252806020026020018201604052801561064a578160200160208202803683370190505b50905060005b81518110156103fd576005600085858481811061066f5761066f611dbc565b90506020020160208101906106849190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106106b7576106b7611dbc565b6020908102919091010152600101610650565b6000805b828110156103fd57600560008585848181106106ec576106ec611dbc565b90506020020160208101906107019190611c8f565b6001600160a01b031681526020810191909152604001600020546107259083611de8565b91506001016106ce565b60608167ffffffffffffffff81111561074a5761074a611dfb565b604051908082528060200260200182016040528015610773578160200160208202803683370190505b50905060005b81518110156103fd576007600085858481811061079857610798611dbc565b90506020020160208101906107ad9190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107e0576107e0611dbc565b6020908102919091010152600101610779565b600054610100900460ff16158080156108135750600054600160ff909116105b8061082d5750303b15801561082d575060005460ff166001145b6108be576040517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084015b60405180910390fd5b6000805460ff1916600117905580156108e1576000805461ff0019166101001790555b83156108f1576108f18585610e75565b6108fb8383610eea565b50508015610943576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546109649190611e11565b61096e9190611de8565b6109789190611e28565b6109829190611e3b565b905090565b6000805b828110156103fd57600660008585848181106109a9576109a9611dbc565b90506020020160208101906109be9190611c8f565b6001600160a01b031681526020810191909152604001600020546109e29083611de8565b915060010161098b565b6109f4610dff565b6000819003610a16576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610a5857610a50838383818110610a3657610a36611dbc565b9050602002016020810190610a4b9190611c8f565b610f99565b600101610a19565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a78282604051610a8a929190611e5d565b60405180910390a15050565b610a9e610dff565b6000819003610ac0576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610b0357610afb838383818110610ae057610ae0611dbc565b905060a00201803603810190610af69190611ea9565b611308565b600101610ac3565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610a8a929190611f3a565b600080610b40610dff565b610b4a8484610eea565b915091505b9250929050565b60608167ffffffffffffffff811115610b7157610b71611dfb565b604051908082528060200260200182016040528015610b9a578160200160208202803683370190505b50905060005b81518110156103fd5760066000858584818110610bbf57610bbf611dbc565b9050602002016020810190610bd49190611c8f565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610c0757610c07611dbc565b6020908102919091010152600101610ba0565b6000600354600154610c2c9190611e11565b600254610c399084611e11565b101592915050565b6040805160a0810182526000808252602082018190529181018290526060810182905260808101829052905b600954811015610cc657826001600160a01b031660098281548110610c9457610c94611dbc565b6000918252602090912001546001600160a01b031603610cbe57610cb781610cf9565b9392505050565b600101610c6d565b506040517fe57fdbef00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040805160a081018252600080825260208201819052918101829052606081018290526080810191909152600060098381548110610d3957610d39611dbc565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610d8657610d86611dbc565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610db757610db7611dbc565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610e73576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108b5929190611fc3565b565b60005b81811015610eb857610eb0838383818110610e9557610e95611dbc565b905060a00201803603810190610eab9190611ea9565b61162f565b600101610e78565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610a8a929190611f3a565b60008082841115610f35576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b03811660009081526005602052604081205490819003610fde576040516349f748eb60e01b81526001600160a01b03831660048201526024016108b5565b600954600090815b8181101561103557846001600160a01b03166009828154811061100b5761100b611dbc565b6000918252602090912001546001600160a01b03160361102d57809250611035565b600101610fe6565b5082600360008282546110489190611e28565b90915550506001600160a01b038416600090815260086020908152604080832083905560059091528120556009611080600183611e28565b8154811061109057611090611dbc565b600091825260209091200154600980546001600160a01b0390921691849081106110bc576110bc611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b0316021790555060098054806110fb576110fb611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a848154811061113a5761113a611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a61116c600183611e28565b8154811061117c5761117c611dbc565b600091825260209091200154600a80546001600160a01b0390921691849081106111a8576111a8611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a8054806111e7576111e7611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b848154811061122657611226611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b611258600183611e28565b8154811061126857611268611dbc565b600091825260209091200154600b80546001600160a01b03909216918490811061129457611294611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b8054806112d3576112d3611fff565b6000828152602090208101600019908101805473ffffffffffffffffffffffffffffffffffffffff1916905501905550505050565b611311816118eb565b80516001600160a01b03166000908152600560205260408120549081900361135a5781516040516349f748eb60e01b81526001600160a01b0390911660048201526024016108b5565b60095460005b818110156116295783600001516001600160a01b03166009828154811061138957611389611dbc565b6000918252602090912001546001600160a01b0316036116215782600360008282546113b59190611e28565b90915550506060840151600380546000906113d1908490611de8565b9250508190555083602001516001600160a01b0316600a82815481106113f9576113f9611dbc565b6000918252602090912001546001600160a01b0316146114d4576020808501516001600160a01b03166000908152600690915260409020541561144f576040516346da180960e01b815260040160405180910390fd5b60066000600a838154811061146657611466611dbc565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a8054839081106114a5576114a5611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b82815481106114f5576114f5611dbc565b6000918252602090912001546001600160a01b0316146115cf576040808501516001600160a01b031660009081526007602052205415611548576040516346da180960e01b815260040160405180910390fd5b60076000600b838154811061155f5761155f611dbc565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b8054839081106115a0576115a0611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b600101611360565b50505050565b60808101511561166b576040517f94e1670800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611674816118eb565b80516001600160a01b0316600090815260056020526040902054156116d35780516040517fada9a3530000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6020808201516001600160a01b0316600090815260069091526040902054156117395760208101516040517ffebc5eb20000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6040808201516001600160a01b03166000908152600760205220541561179c5760408082015190517f0f69702d0000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af909101805473ffffffffffffffffffffffffffffffffffffffff199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916118e3908490611de8565b909155505050565b8060600151600003611937576040517ffe2371460000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b604080516003808252608082019092526000916020820160608036833701905050905081600001518160008151811061197257611972611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160200151816001815181106119aa576119aa611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160400151816002815181106119e2576119e2611dbc565b60200260200101906001600160a01b031690816001600160a01b031681525050611a0b81611a50565b15610416576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b60008151600003611a6357506000919050565b60005b6001835103811015611ae657600181015b8351811015611add57838181518110611a9257611a92611dbc565b60200260200101516001600160a01b0316848381518110611ab557611ab5611dbc565b60200260200101516001600160a01b031603611ad5575060019392505050565b600101611a77565b50600101611a66565b50600092915050565b60008060208385031215611b0257600080fd5b823567ffffffffffffffff80821115611b1a57600080fd5b818501915085601f830112611b2e57600080fd5b813581811115611b3d57600080fd5b8660208260051b8501011115611b5257600080fd5b60209290920196919550909350505050565b60008083601f840112611b7657600080fd5b50813567ffffffffffffffff811115611b8e57600080fd5b60208301915083602060a083028501011115610b4f57600080fd5b60008060208385031215611bbc57600080fd5b823567ffffffffffffffff811115611bd357600080fd5b611bdf85828601611b64565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b81811015611c6757611c548385516001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b9284019260a09290920191600101611c07565b50909695505050505050565b80356001600160a01b0381168114611c8a57600080fd5b919050565b600060208284031215611ca157600080fd5b610cb782611c73565b6020808252825182820181905260009190848201906040850190845b81811015611c6757835183529284019291840191600101611cc6565b60008060008060608587031215611cf857600080fd5b843567ffffffffffffffff811115611d0f57600080fd5b611d1b87828801611b64565b90989097506020870135966040013595509350505050565b60008060408385031215611d4657600080fd5b50508035926020909101359150565b600060208284031215611d6757600080fd5b5035919050565b60a08101611db682846001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b92915050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b80820180821115611db657611db6611dd2565b634e487b7160e01b600052604160045260246000fd5b8082028115828204841417611db657611db6611dd2565b81810381811115611db657611db6611dd2565b600082611e5857634e487b7160e01b600052601260045260246000fd5b500490565b60208082528181018390526000908460408401835b86811015611e9e576001600160a01b03611e8b84611c73565b1682529183019190830190600101611e72565b509695505050505050565b600060a08284031215611ebb57600080fd5b60405160a0810181811067ffffffffffffffff82111715611eec57634e487b7160e01b600052604160045260246000fd5b604052611ef883611c73565b8152611f0660208401611c73565b6020820152611f1760408401611c73565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b87811015611fb6576001600160a01b0380611f6a84611c73565b16845280611f79878501611c73565b168685015280611f8a868501611c73565b168486015250606082810135908401526080808301359084015260a09283019290910190600101611f50565b5090979650505050505050565b6001600160e01b03198316815260408101600b8310611ff257634e487b7160e01b600052602160045260246000fd5b8260208301529392505050565b634e487b7160e01b600052603160045260246000fdfea26469706673582212203322efc2dc5067897fa0ebf0e71848432953790436ddeae3b329f243ac407aea64736f6c63430008150033000000000000000000000000000000000000000000 + ├─ [1655136] → new RoninTrustedOrganization@0x47c5e40890bcE4a473A49D7501808b9633F29782 + │ └─ ← 8267 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(11) [staticcall] + │ └─ ← ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090] + ├─ [0] VM::load(ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [9246] ronin-mainnet.RoninTrustedOrganization::upgradeTo(RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782])  + │ ├─ emit Upgraded(param0: RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782], RoninTrustedOrganization, RoninTrustedOrganizationLogic, 0x, 4)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, RoninTrustedOrganizationLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(2) [staticcall] + │ └─ ← BridgeTracking + ├─ [0] GeneralConfig::getContractFileName(2) [staticcall] + │ └─ ← BridgeTracking.sol:BridgeTracking + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000005 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(BridgeTracking.sol:BridgeTracking) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001d64608060405234801561001057600080fd5b5061001961001e565b6100eb565b600154600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60015460ff600160a01b909104811610156100e9576001805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611c6a806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100df5760003560e01c8063c7c4fea91161008c578063de981f1b11610066578063de981f1b1461018e578063e2a75f36146101b9578063f67e8152146101cc578063f84bd121146101ec57600080fd5b8063c7c4fea914610155578063ca21287e14610168578063d25ed4c61461017b57600080fd5b80634ac0bcda116100bd5780634ac0bcda146101145780635cd8a76b1461013a578063865e6fd31461014257600080fd5b80631794bb3c146100e4578063229f88ea146100f95780633b1544551461010c575b600080fd5b6100f76100f23660046116c6565b6101f4565b005b6100f7610107366004611716565b610352565b6100f76104fa565b610127610122366004611740565b6105d5565b6040519081526020015b60405180910390f35b6100f76105f3565b6100f761015036600461177f565b610757565b6100f76101633660046117ab565b610776565b6100f76101763660046117eb565b610b8c565b610127610189366004611847565b610cbe565b6101a161019c366004611860565b610cf3565b6040516001600160a01b039091168152602001610131565b6101276101c7366004611847565b610d82565b6101df6101da36600461187b565b610dac565b6040516101319190611935565b600254610127565b600154600160a81b900460ff161580801561021a575060018054600160a01b900460ff16105b8061023a5750303b15801561023a575060018054600160a01b900460ff16145b6102a25760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b600180547fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff16600160a01b17905580156102ea576001805460ff60a81b1916600160a81b1790555b6102f5600285610df3565b610300600884610df3565b6002829055801561034c576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b600261035d81610ea4565b610365610f09565b6000600a600085600281111561037d5761037d611948565b600281111561038e5761038e611948565b815260200190815260200160002060008481526020019081526020016000209050806000015460000361034c576103c3610f17565b60006103cf6008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561040c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610430919061195e565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928892849260ff1990921691849081111561048d5761048d611948565b02179055506001808201869055830160005b81548110156104e2576104da88888484815481106104bf576104bf611977565b6000918252602090912001546001600160a01b0316876111b9565b60010161049f565b506104f1600185016000611639565b50505050505050565b600461050581610ea4565b600019600b54146105585760405162461bcd60e51b815260206004820152601260248201527f616c726561647920696e697420726570203200000000000000000000000000006044820152606401610299565b6105626008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561059f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105c3919061195e565b600b556105d260046000610df3565b50565b60006105ea83836105e586611346565b61146c565b90505b92915050565b600154600290600160a81b900460ff1615801561061e575060015460ff808316600160a01b90920416105b6106815760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610299565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790556000546106c1906002906001600160a01b0316610df3565b6001546106d9906008906001600160a01b0316610df3565b6000805473ffffffffffffffffffffffffffffffffffffffff19169055600180547fffffffffffffffffffff00ff000000000000000000000000000000000000000016905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b61075f6114c2565b61076881611536565b6107728282610df3565b5050565b600261078181610ea4565b610789610f09565b60006107956008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f6919061195e565b9050610800610f17565b6000600a600087600281111561081857610818611948565b600281111561082957610829611948565b81526020019081526020016000206000868152602001908152602001600020905080600001546000036108985760019081018054918201815560009081526020902001805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0385161790555061034c565b6108a4868686856111b9565b600b54828110156104f157600b8381556000906108c090610cf3565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa1580156108fd573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261092591908101906119ae565b905060006109338383611585565b9050600061094084610d82565b9050600061094d85610cbe565b9050600061095b600c610cf3565b9050600080826001600160a01b0316878786888c604051602401610983959493929190611a73565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff16634dca592560e01b179052516109cd9190611b0c565b6000604051808303816000865af19150503d8060008114610a0a576040519150601f19603f3d011682016040523d82523d6000602084013e610a0f565b606091505b509150915081610a6657604051634dca592560e01b906001600160a01b038516907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610a5d908590611b28565b60405180910390a35b6000610a72600d610cf3565b9050806001600160a01b0316888887898d604051602401610a97959493929190611a73565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166335e5b7eb60e11b17905251610ae19190611b0c565b6000604051808303816000865af19150503d8060008114610b1e576040519150601f19603f3d011682016040523d82523d6000602084013e610b23565b606091505b50909350915082610b7b576040516335e5b7eb60e11b906001600160a01b038316907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610b72908690611b28565b60405180910390a35b505050505050505050505050505050565b600154600390600160a81b900460ff16158015610bb7575060015460ff808316600160a01b90920416105b610c1a5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610299565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055610c4d600b86610df3565b610c58600c85610df3565b610c63600d84610df3565b610c6e600483610df3565b600019600b556001805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050505050565b600081815260096020526040902060010154610cd982611346565b15610cee57600654610ceb9082611b5b565b90505b919050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610d2a57610d2a611948565b60ff1681526020810191909152604001600020546001600160a01b0316905080610cee57816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016102999190611b90565b600081815260096020526040902054610d9a82611346565b15610cee57600454610ceb9082611b5b565b6060610deb8484848080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061158592505050565b949350505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610e2957610e29611948565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115610e7757610e77611948565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610ead81610cf3565b6001600160a01b0316336001600160a01b0316146105d2576000356001600160e01b03191681336040517f8383e63400000000000000000000000000000000000000000000000000000000815260040161029993929190611b9e565b600254431015610f1557005b565b6000610f236008610cf3565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015610f6d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f91919061195e565b9050806003600001541015610772576000826001600160a01b031663468c96ae6003600001546001610fc39190611b5b565b6040518263ffffffff1660e01b8152600401610fe191815260200190565b6040805180830381865afa158015610ffd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110219190611bd3565b6003849055600081815260096020526040812060045481549395509093509183919061104e908490611b5b565b909155505060065460018201805460009061106a908490611b5b565b90915550600090505b6008548110156110fa5760088054600091908390811061109557611095611977565b60009182526020808320909101546001600160a01b03168083526007825260408084205460028801909352832080549194509192906110d5908490611b5b565b90915550506001600160a01b0316600090815260076020526040812055600101611073565b5060005b60045481101561118c5760006003600101828154811061112057611120611977565b6000918252602082206002918202018054909350600a91839160ff169081111561114c5761114c611948565b600281111561115d5761115d611948565b8152602080820192909252604090810160009081206001958601548252909252902060030185905550016110fe565b5061119960046000611657565b600060058181556006829055906111b1600882611639565b505050505050565b6000600a60008660028111156111d1576111d1611948565b60028111156111e2576111e2611948565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff1615611225575061034c565b6001600160a01b03831660009081526002820160205260408120805460ff191660011790556003820154908190036112ff576001600160a01b03841660009081526007602052604081205490036112cf57600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee301805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0386161790555b6006805460019081019091556001600160a01b0385166000908152600760205260409020805490910190556111b1565b8281036111b157600090815260096020908152604080832060018082018054820190556001600160a01b039790971684526002019091529020805490930190925550505050565b6000806113536008610cf3565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa15801561139d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113c1919061195e565b9050600080836001600160a01b031663468c96ae60036000015460016113e79190611b5b565b6040518263ffffffff1660e01b815260040161140591815260200190565b6040805180830381865afa158015611421573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114459190611bd3565b9150915081801561145557508086145b8015611462575060035483115b9695505050505050565b60008381526009602090815260408083206001600160a01b038616845260020190915290205481156114bb576001600160a01b038316600090815260076020526040902054610deb9082611b5b565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610f15576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610299929190611c06565b806001600160a01b03163b6000036105d2576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610299565b80516060908067ffffffffffffffff8111156115a3576115a361198d565b6040519080825280602002602001820160405280156115cc578160200160208202803683370190505b50915060006115da85611346565b905060005b828110156116305761160b868683815181106115fd576115fd611977565b60200260200101518461146c565b84828151811061161d5761161d611977565b60209081029190910101526001016115df565b50505092915050565b50805460008255906000526020600020908101906105d29190611678565b50805460008255600202906000526020600020908101906105d29190611691565b5b8082111561168d5760008155600101611679565b5090565b5b8082111561168d57805460ff1916815560006001820155600201611692565b6001600160a01b03811681146105d257600080fd5b6000806000606084860312156116db57600080fd5b83356116e6816116b1565b925060208401356116f6816116b1565b929592945050506040919091013590565b803560038110610cee57600080fd5b6000806040838503121561172957600080fd5b61173283611707565b946020939093013593505050565b6000806040838503121561175357600080fd5b823591506020830135611765816116b1565b809150509250929050565b803560108110610cee57600080fd5b6000806040838503121561179257600080fd5b61179b83611770565b91506020830135611765816116b1565b6000806000606084860312156117c057600080fd5b6117c984611707565b92506020840135915060408401356117e0816116b1565b809150509250925092565b6000806000806080858703121561180157600080fd5b843561180c816116b1565b9350602085013561181c816116b1565b9250604085013561182c816116b1565b9150606085013561183c816116b1565b939692955090935050565b60006020828403121561185957600080fd5b5035919050565b60006020828403121561187257600080fd5b6105ea82611770565b60008060006040848603121561189057600080fd5b83359250602084013567ffffffffffffffff808211156118af57600080fd5b818601915086601f8301126118c357600080fd5b8135818111156118d257600080fd5b8760208260051b85010111156118e757600080fd5b6020830194508093505050509250925092565b600081518084526020808501945080840160005b8381101561192a5781518752958201959082019060010161190e565b509495945050505050565b6020815260006105ea60208301846118fa565b634e487b7160e01b600052602160045260246000fd5b60006020828403121561197057600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b8051610cee816116b1565b600060208083850312156119c157600080fd5b825167ffffffffffffffff808211156119d957600080fd5b818501915085601f8301126119ed57600080fd5b8151818111156119ff576119ff61198d565b8060051b604051601f19603f83011681018181108582111715611a2457611a2461198d565b604052918252848201925083810185019188831115611a4257600080fd5b938501935b82851015611a6757611a58856119a3565b84529385019392850192611a47565b98975050505050505050565b60a0808252865190820181905260009060209060c0840190828a01845b82811015611ab55781516001600160a01b031684529284019290840190600101611a90565b50505083810382850152611ac981896118fa565b6040850197909752505050606081019290925260809091015292915050565b60005b83811015611b03578181015183820152602001611aeb565b50506000910152565b60008251611b1e818460208701611ae8565b9190910192915050565b6020815260008251806020840152611b47816040850160208701611ae8565b601f01601f19169190910160400192915050565b808201808211156105ed57634e487b7160e01b600052601160045260246000fd5b60108110611b8c57611b8c611948565b9052565b602081016105ed8284611b7c565b6001600160e01b03198416815260608101611bbc6020830185611b7c565b6001600160a01b0383166040830152949350505050565b60008060408385031215611be657600080fd5b82518015158114611bf657600080fd5b6020939093015192949293505050565b6001600160e01b03198316815260408101600b8310611c2757611c27611948565b826020830152939250505056fea264697066735822122089b80e8f38115da71d00f5612b6a2886ec719ca6c6b5fda4aaf8ad9791668fae64736f6c6343000815003300000000000000000000000000000000000000000000000000000000 + ├─ [1479938] → new BridgeTracking@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + │ ├─ emit Initialized(version: 255) + │ └─ ← 7274 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(2) [staticcall] + │ └─ ← ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2] + ├─ [0] VM::load(ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [59673] ronin-mainnet.BridgeTracking::upgradeToAndCall(BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f]) + │ ├─ [48032] BridgeTracking::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 2, addr: ronin-mainnet.RoninGatewayV3: [0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df]) + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], BridgeTracking, BridgeTrackingLogic, 0x, 5)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, BridgeTrackingLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::warp(1696244594 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139076 [2.813e7])  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::numberOfBlocksInEpoch() [staticcall] + │ ├─ [0] RoninValidatorSet::numberOfBlocksInEpoch() [delegatecall] + │ │ └─ ← 200 + │ └─ ← 200 + ├─ [0] VM::warp(1696330994 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139199 [2.813e7])  + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::wrapUpEpoch()  + │ ├─ [0] RoninValidatorSet::wrapUpEpoch() [delegatecall] + │ │ ├─ [0] ronin-mainnet.FastFinalityTracking::468d24be(000000000000000000000000000000000000000000000000000000000002259800000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000016000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf380000000000000000000000009b959d27840a31988410ee69991bcf0110d61f0200000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac206840000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000d11d9842babd5209b9b1155e46f5878c989125b7000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab5000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d000000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b0100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8) [staticcall] + │ │ │ ├─ [0] 0x241e507363d674c77a9930F31ea26BBc8857949c::468d24be(000000000000000000000000000000000000000000000000000000000002259800000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000016000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf380000000000000000000000009b959d27840a31988410ee69991bcf0110d61f0200000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac206840000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000d11d9842babd5209b9b1155e46f5878c989125b7000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab5000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d000000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b0100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ [0] 0xab4BC28137a9535838a27fBE59044F6eE3D68428::fallback{value: 169807176758141357622}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169807176758141357622 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, recipient: 0xab4BC28137a9535838a27fBE59044F6eE3D68428, amount: 169807176758141357622 [1.698e20]) + │ │ ├─ [0] 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4::fallback{value: 118963578955331395475}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 118963578955331395475 [1.189e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x9B959D27840a31988410Ee69991BCF0110D61F02, recipient: 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4, amount: 118963578955331395475 [1.189e20]) + │ │ ├─ [0] 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2::fallback{value: 169879446172168538675}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169879446172168538675 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, recipient: 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2, amount: 169879446172168538675 [1.698e20]) + │ │ ├─ [0] 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72::fallback{value: 135925354685204004300}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6E46924371d0e910769aaBE0d867590deAC20684, recipient: 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72, amount: 135925354685204004300 [1.359e20]) + │ │ ├─ [0] 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8::fallback{value: 169870705637003507268}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169870705637003507268 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, recipient: 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8, amount: 169870705637003507268 [1.698e20]) + │ │ ├─ [0] 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9::fallback{value: 170136480416710407898}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170136480416710407898 [1.701e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xFc3e31519B551bd594235dd0eF014375a87C4e21, recipient: 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9, amount: 170136480416710407898 [1.701e20]) + │ │ ├─ [0] 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3::fallback{value: 340436100948920512964}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xE07D7e56588a6FD860c5073c70a099658C060F3D, recipient: 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3, amount: 340436100948920512964 [3.404e20]) + │ │ ├─ [0] 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888::fallback{value: 340325252087546507482}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, recipient: 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888, amount: 340325252087546507482 [3.403e20]) + │ │ ├─ [0] 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034::fallback{value: 339817976993460557814}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x52349003240770727900b06a3B3a90f5c0219ADe, recipient: 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034, amount: 339817976993460557814 [3.398e20]) + │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 340374055555383969820}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, recipient: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 340374055555383969820 [3.403e20]) + │ │ ├─ [0] 0x2d593A0087029501eE419b9415DeC3fAC195FE4A::fallback{value: 340363726701776549276}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 340363726701776549276 [3.403e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xd11D9842baBd5209b9B1155e46f5878c989125b7, recipient: 0x2d593A0087029501eE419b9415DeC3fAC195FE4A, amount: 340363726701776549276 [3.403e20]) + │ │ ├─ [0] 0xD8FCC2BC2da24e7d74af0078408E6394d7080776::fallback{value: 339728192236459901442}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 339728192236459901442 [3.397e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, recipient: 0xD8FCC2BC2da24e7d74af0078408E6394d7080776, amount: 339728192236459901442 [3.397e20]) + │ │ ├─ [0] 0xE5718182af678C7d65c286851934273AA39e67d6::fallback{value: 84815024893111142653}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84815024893111142653 [8.481e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, recipient: 0xE5718182af678C7d65c286851934273AA39e67d6, amount: 84815024893111142653 [8.481e19]) + │ │ ├─ [0] 0xa27a1095015dC037C92403F4B26196b04f342961::fallback{value: 85096491629164641003}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85096491629164641003 [8.509e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, recipient: 0xa27a1095015dC037C92403F4B26196b04f342961, amount: 85096491629164641003 [8.509e19]) + │ │ ├─ [0] 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814::fallback{value: 85089196191471422275}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85089196191471422275 [8.508e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, recipient: 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814, amount: 85089196191471422275 [8.508e19]) + │ │ ├─ [0] 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434::fallback{value: 85177254352471927923}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, recipient: 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434, amount: 85177254352471927923 [8.517e19]) + │ │ ├─ [0] 0x9305E94C367e04b508cB9919f9dce3B60058A740::fallback{value: 84968697635262370274}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84968697635262370274 [8.496e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, recipient: 0x9305E94C367e04b508cB9919f9dce3B60058A740, amount: 84968697635262370274 [8.496e19]) + │ │ ├─ [0] 0xA1FBA3752cf39647f1028a4c61791611a78588aB::fallback{value: 84955525293728741846}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, recipient: 0xA1FBA3752cf39647f1028a4c61791611a78588aB, amount: 84955525293728741846 [8.495e19]) + │ │ ├─ [0] 0x69134fB518A13403F4725a15ff60f5B688894c42::fallback{value: 169880292287037425572}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, recipient: 0x69134fB518A13403F4725a15ff60f5B688894c42, amount: 169880292287037425572 [1.698e20]) + │ │ ├─ [0] 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F::fallback{value: 170227489474005394791}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170227489474005394791 [1.702e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, recipient: 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F, amount: 170227489474005394791 [1.702e20]) + │ │ ├─ [0] 0x9B0612E43855ef9a7c329ee89653bA45273B550e::fallback{value: 169909652573519158189}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x61089875fF9e506ae78C7FE9f7c388416520E386, recipient: 0x9B0612E43855ef9a7c329ee89653bA45273B550e, amount: 169909652573519158189 [1.699e20]) + │ │ ├─ [0] 0x72A69B04B59C36fCED19ac54209beF878e84FcBF::fallback{value: 169862575167464156156}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, recipient: 0x72A69B04B59C36fCED19ac54209beF878e84FcBF, amount: 169862575167464156156 [1.698e20]) + │ │ ├─ [0] ronin-mainnet.Staking::fallback{value: 33235944893664027916805}()  + │ │ │ ├─ [0] Staking::receive() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4])  + │ │ │ ├─ [0] Staking::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4]) [delegatecall] + │ │ │ │ ├─ emit PoolsUpdated(period: 19632 [1.963e4], poolAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], aRps: [66357646962488955 [6.635e16], 95431207368377915 [9.543e16], 95695598399621230 [9.569e16], 94573200455822051 [9.457e16], 97687248220171528 [9.768e16], 97310118461513347 [9.731e16], 93829791800558853 [9.382e16], 99884465958207150 [9.988e16], 99093477004188600 [9.909e16], 97216470633378110 [9.721e16], 100780733232959799 [1.007e17], 99144578508031030 [9.914e16], 93318776012821131 [9.331e16], 94447227634309187 [9.444e16], 98467985935188233 [9.846e16], 88199764422009158 [8.819e16], 93079390018252421 [9.307e16], 67225014440065554 [6.722e16], 94805313929688703 [9.48e16], 97239053863980682 [9.723e16], 98902645602159682 [9.89e16], 99019423310445352 [9.901e16]], shares: [10190748510465558475599875 [1.019e25], 7206104688158066377918315 [7.206e24], 6881867025193447219128274 [6.881e24], 6781274466483249341608615 [6.781e24], 6658249476098351649251578 [6.658e24], 6503464654044309321751691 [6.503e24], 5903862198409162686318766 [5.903e24], 5813275267619519038407189 [5.813e24], 5784491179033799937345365 [5.784e24], 5778443231451247986081315 [5.778e24], 5741644343444817691866731 [5.741e24], 5761256007661259154805105 [5.761e24], 7389521338803830815958367 [7.389e24], 7188192519136884811285316 [7.188e24], 7047161408616008536704042 [7.047e24], 7015615166482386890314536 [7.015e24], 6993506329773885059751580 [6.993e24], 6906329454934638339591820 [6.906e24], 6718763510770822301943622 [6.718e24], 6452840193432170260900982 [6.452e24], 6396343690109009473179767 [6.396e24], 6365969656770395353461256 [6.365e24]]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit StakingRewardDistributed(totalAmount: 33235944893664027916805 [3.323e22], consensusAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], amounts: [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]]) + │ │ ├─ [0] ronin-mainnet.StakingVesting::receiveRON{value: 1243911719922200000000}()  + │ │ │ ├─ [0] 0xf07121671F929d89eA6CaEE8e3D26BD7eD63CFeb::receiveRON() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit DeprecatedRewardRecycled(recipientAddr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816], amount: 1243911719922200000000 [1.243e21]) + │ │ ├─ [0] ronin-mainnet.SlashIndicator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4])  + │ │ │ ├─ [0] SlashIndicator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4]) [delegatecall] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriodStartAtBlock() [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::currentPeriodStartAtBlock() [delegatecall] + │ │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [delegatecall] + │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [staticcall] + │ │ │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ ├─ emit CreditScoresUpdated(validators: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], creditScores: [600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::waitingSecsToRevoke() [staticcall] + │ │ │ ├─ [0] Staking::waitingSecsToRevoke() [delegatecall] + │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ └─ ← 604800 [6.048e5] + │ │ ├─ [0] ronin-mainnet.Staking::minValidatorStakingAmount() [staticcall] + │ │ │ ├─ [0] Staking::minValidatorStakingAmount() [delegatecall] + │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ ├─ [0] ronin-mainnet.Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ ├─ [0] ronin-mainnet.Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ ├─ [0] ronin-mainnet.RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ ├─ [0] 0x0000000000000000000000000000000000000068::pickValidatorSet([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1], [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]], [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0], 22, 12) [staticcall] + │ │ │ └─ ← [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe] + │ │ ├─ emit ValidatorSetUpdated(period: 19633 [1.963e4], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [staticcall] + │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ emit BlockProducerSetUpdated(period: 19633 [1.963e4], epoch: 140697 [1.406e5], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ emit WrappedUpEpoch(periodNumber: 19632 [1.963e4], epochNumber: 140696 [1.406e5], periodEnding: true) + │ │ └─ ← () + │ └─ ← () + └─ ← () + + +Script ran successfully. + +== Logs == + Skipping artifact generation for: MockPrecompile + Skipping artifact generation for: RoninValidatorSetLogic + Skipping artifact generation for: StakingLogic + Skipping artifact generation for: SlashIndicatorLogic + Skipping artifact generation for: RoninTrustedOrganizationLogic + Skipping artifact generation for: BridgeTrackingLogic +========================== +Simulated On-chain Traces: + + [954922] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + └─ ← 4176 bytes of code + + [4654308] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + ├─ emit Initialized(version: 255) + └─ ← 21229 bytes of code + + [112436] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], 0x5cd8a76b)  + ├─ emit Upgraded(param0: RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3]) + ├─ [81147] RoninValidatorSet::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 9, addr: ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758]) + │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ ├─ emit ContractUpdated(contractType: 6, addr: ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3]) + │ ├─ emit ContractUpdated(contractType: 7, addr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816]) + │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [3579805] → new Staking@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + ├─ emit Initialized(version: 255) + └─ ← 16154 bytes of code + + [61800] ronin-mainnet.Staking::upgradeToAndCall(Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x5cd8a76b)  + ├─ emit Upgraded(param0: Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + ├─ [24636] Staking::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [3169482] → new SlashIndicator@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + ├─ emit Initialized(version: 255) + └─ ← 14346 bytes of code + + [113086] ronin-mainnet.SlashIndicator::upgradeToAndCall(SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], 0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6)  + ├─ emit Upgraded(param0: SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA]) + ├─ [66548] SlashIndicator::initializeV2(ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) [delegatecall] + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ ├─ emit ContractUpdated(contractType: 4, addr: ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) + │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [1834812] → new RoninTrustedOrganization@0x47c5e40890bcE4a473A49D7501808b9633F29782 + └─ ← 8267 bytes of code + + [32595] ronin-mainnet.RoninTrustedOrganization::upgradeTo(RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782])  + ├─ emit Upgraded(param0: RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + └─ ← () + + [1649050] → new BridgeTracking@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + ├─ emit Initialized(version: 255) + └─ ← 7274 bytes of code + + [91756] ronin-mainnet.BridgeTracking::upgradeToAndCall(BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], 0x5cd8a76b)  + ├─ emit Upgraded(param0: BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f]) + ├─ [48032] BridgeTracking::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 2, addr: ronin-mainnet.RoninGatewayV3: [0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df]) + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + +========================== + +Chain 2020 + +Estimated gas price: 20 gwei + +Estimated total gas used for script: 21130262 + +Estimated amount required: 0.42260524 ETH + +========================== + +SIMULATION COMPLETE. To broadcast these transactions, add --broadcast and wallet configuration(s) to the previous command. See forge script --help for more. + +Transactions saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/broadcast/20231003_REP002AndREP003_RON_NonConditional.s.sol/2020/dry-run/run-latest.json + +Sensitive values saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/cache_foundry/20231003_REP002AndREP003_RON_NonConditional.s.sol/2020/dry-run/run-latest.json + diff --git a/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.log b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.log new file mode 100644 index 000000000..a5394fd21 --- /dev/null +++ b/logs/migrations/REP002-REP003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.log @@ -0,0 +1,731 @@ +- skipping the remapping +Compiling 2 files with 0.8.21 +Solc 0.8.21 finished in 7.44s +Compiler run successful! +Traces: + [9223372036854775807] Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods::run()  + ├─ [0] GeneralConfig::getContractName(7) [staticcall] + │ └─ ← MockPrecompile + ├─ [0] GeneralConfig::getContractFileName(7) [staticcall] + │ └─ ← MockPrecompile.sol:MockPrecompile + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000000 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(MockPrecompile.sol:MockPrecompile) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001070608060405234801561001057600080fd5b50611050806100206000396000f3fe608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c6343000815003300000000000000000000000000000000 + ├─ [836070] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + │ └─ ← 4176 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] VM::label(MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile)  + │ └─ ← () + ├─ [0] GeneralConfig::setAddress(3, 7, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1])  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, MockPrecompile: [0xBd770416a3345F91E4B34576cb804a576fa48EB1], MockPrecompile, MockPrecompile, 0x, 0)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, MockPrecompile) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::etch(0x0000000000000000000000000000000000000068, 0x608060405234801561001057600080fd5b506004361061004c5760003560e01c80637794151214610051578063788341af1461007a5780637b47d06b1461008d5780637fc35677146100b7575b600080fd5b61006461005f366004610c1f565b6100d0565b6040516100719190610cb9565b60405180910390f35b610064610088366004610d06565b61010a565b6100a761009b366004610dbd565b60019695505050505050565b6040519015158152602001610071565b6100a76100c5366004610e68565b600195945050505050565b60606100dd86868661011f565b809550819250505060006100f2848351610349565b90506101008286838661035f565b5095945050505050565b60606101168383610527565b90505b92915050565b60608084518451148015610134575084518351145b6101855760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e67746800000060448201526064015b60405180910390fd5b8451600003610198575083905081610341565b6000855167ffffffffffffffff8111156101b4576101b4610acb565b60405190808252806020026020018201604052801561020957816020015b6101f660405180606001604052806000815260200160008152602001600081525090565b8152602001906001900390816101d25790505b50905060005b81518110156102b757604051806060016040528088838151811061023557610235610ee9565b60200260200101516001600160a01b0316815260200187838151811061025d5761025d610ee9565b6020026020010151815260200186838151811061027c5761027c610ee9565b602002602001015181525082828151811061029957610299610ee9565b602002602001018190525080806102af90610f15565b91505061020f565b506102d1816000600184516102cc9190610f2e565b610704565b5060005b8151811015610338578181815181106102f0576102f0610ee9565b60200260200101516000015187828151811061030e5761030e610ee9565b6001600160a01b03909216602092830291909101909101528061033081610f15565b9150506102d5565b50858492509250505b935093915050565b60008183106103585781610116565b5090919050565b6000845167ffffffffffffffff81111561037b5761037b610acb565b6040519080825280602002602001820160405280156103a4578160200160208202803683370190505b50905060008060005b87518110156104ab5760008782815181106103ca576103ca610ee9565b60200260200101511180156103de57508482105b15610440578781815181106103f5576103f5610ee9565b602002602001015188838061040990610f15565b94508151811061041b5761041b610ee9565b60200260200101906001600160a01b031690816001600160a01b031681525050610499565b87818151811061045257610452610ee9565b602002602001015184848061046690610f15565b95508151811061047857610478610ee9565b60200260200101906001600160a01b031690816001600160a01b0316815250505b806104a381610f15565b9150506103ad565b5060009150805b8581101561051b5783836104c581610f15565b9450815181106104d7576104d7610ee9565b60200260200101518882815181106104f1576104f1610ee9565b6001600160a01b03909216602092830291909101909101528061051381610f15565b9150506104b2565b50505091909352505050565b6060825182511461057a5760405162461bcd60e51b815260206004820152601d60248201527f536f7274696e673a20696e76616c6964206172726179206c656e677468000000604482015260640161017c565b825160000361058a575081610119565b6000835167ffffffffffffffff8111156105a6576105a6610acb565b6040519080825280602002602001820160405280156105eb57816020015b60408051808201909152600080825260208201528152602001906001900390816105c45790505b50905060005b815181101561067a57604051806040016040528086838151811061061757610617610ee9565b60200260200101516001600160a01b0316815260200185838151811061063f5761063f610ee9565b602002602001015181525082828151811061065c5761065c610ee9565b6020026020010181905250808061067290610f15565b9150506105f1565b506106948160006001845161068f9190610f2e565b6108ae565b5060005b81518110156106fb578181815181106106b3576106b3610ee9565b6020026020010151600001518582815181106106d1576106d1610ee9565b6001600160a01b0390921660209283029190910190910152806106f381610f15565b915050610698565b50929392505050565b606082828082036107195785925050506108a7565b60008660026107288888610f41565b6107329190610f68565b61073c9088610fa4565b8151811061074c5761074c610ee9565b602002602001015190505b818313610874575b806020015187848151811061077657610776610ee9565b602002602001015160200151111561079a578261079281610fcc565b93505061075f565b8682815181106107ac576107ac610ee9565b602002602001015160200151816020015111156107d557816107cd81610ffd565b92505061079a565b81831361086f576108188784815181106107f1576107f1610ee9565b602002602001015188848151811061080b5761080b610ee9565b6020026020010151610a47565b88858151811061082a5761082a610ee9565b6020026020010189858151811061084357610843610ee9565b602002602001018290528290525050828061085d90610fcc565b935050818061086b90610ffd565b9250505b610757565b8186121561088a57610887878784610704565b96505b848312156108a05761089d878487610704565b96505b8693505050505b9392505050565b606082828082036108c35785925050506108a7565b60008660026108d28888610f41565b6108dc9190610f68565b6108e69088610fa4565b815181106108f6576108f6610ee9565b602002602001015190505b818313610a1e575b806020015187848151811061092057610920610ee9565b6020026020010151602001511115610944578261093c81610fcc565b935050610909565b86828151811061095657610956610ee9565b6020026020010151602001518160200151111561097f578161097781610ffd565b925050610944565b818313610a19576109c287848151811061099b5761099b610ee9565b60200260200101518884815181106109b5576109b5610ee9565b6020026020010151610a9e565b8885815181106109d4576109d4610ee9565b602002602001018985815181106109ed576109ed610ee9565b6020026020010182905282905250508280610a0790610fcc565b9350508180610a1590610ffd565b9250505b610901565b81861215610a3457610a318787846108ae565b96505b848312156108a05761089d8784876108ae565b610a6b60405180606001604052806000815260200160008152602001600081525090565b610a8f60405180606001604052806000815260200160008152602001600081525090565b509091905081815b9250929050565b60408051808201909152600080825260208201526040805180820190915260008082526020820152610a8f565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff81118282101715610b0a57610b0a610acb565b604052919050565b600067ffffffffffffffff821115610b2c57610b2c610acb565b5060051b60200190565b80356001600160a01b0381168114610b4d57600080fd5b919050565b600082601f830112610b6357600080fd5b81356020610b78610b7383610b12565b610ae1565b82815260059290921b84018101918181019086841115610b9757600080fd5b8286015b84811015610bb957610bac81610b36565b8352918301918301610b9b565b509695505050505050565b600082601f830112610bd557600080fd5b81356020610be5610b7383610b12565b82815260059290921b84018101918181019086841115610c0457600080fd5b8286015b84811015610bb95780358352918301918301610c08565b600080600080600060a08688031215610c3757600080fd5b853567ffffffffffffffff80821115610c4f57600080fd5b610c5b89838a01610b52565b96506020880135915080821115610c7157600080fd5b610c7d89838a01610bc4565b95506040880135915080821115610c9357600080fd5b50610ca088828901610bc4565b9598949750949560608101359550608001359392505050565b6020808252825182820181905260009190848201906040850190845b81811015610cfa5783516001600160a01b031683529284019291840191600101610cd5565b50909695505050505050565b60008060408385031215610d1957600080fd5b823567ffffffffffffffff80821115610d3157600080fd5b610d3d86838701610b52565b93506020850135915080821115610d5357600080fd5b50610d6085828601610bc4565b9150509250929050565b60008083601f840112610d7c57600080fd5b50813567ffffffffffffffff811115610d9457600080fd5b602083019150836020828501011115610a9757600080fd5b806040810183101561011957600080fd5b60008060008060008060c08789031215610dd657600080fd5b863567ffffffffffffffff80821115610dee57600080fd5b610dfa8a838b01610d6a565b909850965060208901359550869150610e168a60408b01610dac565b94506080890135915080821115610e2c57600080fd5b610e388a838b01610dac565b935060a0890135915080821115610e4e57600080fd5b50610e5b89828a01610dac565b9150509295509295509295565b600080600080600060608688031215610e8057600080fd5b610e8986610b36565b9450602086013567ffffffffffffffff80821115610ea657600080fd5b610eb289838a01610d6a565b90965094506040880135915080821115610ecb57600080fd5b50610ed888828901610d6a565b969995985093965092949392505050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201610f2757610f27610eff565b5060010190565b8181038181111561011957610119610eff565b8181036000831280158383131683831282161715610f6157610f61610eff565b5092915050565b600082610f8557634e487b7160e01b600052601260045260246000fd5b600160ff1b821460001984141615610f9f57610f9f610eff565b500590565b8082018281126000831280158216821582161715610fc457610fc4610eff565b505092915050565b60007f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8203610f2757610f27610eff565b6000600160ff1b820361101257611012610eff565b50600019019056fea26469706673582212207573aa68a4aab964562d69d73ff4884959d734362941f0c0b63c13a9025bc22564736f6c63430008150033)  + │ └─ ← () + ├─ [0] VM::makePersistent(0x0000000000000000000000000000000000000068)  + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(1) [staticcall] + │ └─ ← RoninValidatorSet + ├─ [0] GeneralConfig::getContractFileName(1) [staticcall] + │ └─ ← RoninValidatorSet.sol:RoninValidatorSet + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000001 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(RoninValidatorSet.sol:RoninValidatorSet) [staticcall] + │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000053e160806040523480156200001157600080fd5b506200001c62000022565b620000e4565b600054610100900460ff16156200008f5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff9081161015620000e2576000805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b6152ed80620000f46000396000f3fe6080604052600436106103855760003560e01c806365244ece116101d1578063a3d545f511610102578063c94aaa02116100a0578063e5125a1d1161006f578063e5125a1d14610a00578063edb194bb14610a20578063eeb629a814610a82578063f883afaf14610a9757610394565b8063c94aaa021461098b578063d09f1ab4146109ab578063dd716ad3146109c0578063de981f1b146109e057610394565b8063afc69d73116100dc578063afc69d731461092c578063b7ab4db514610941578063ba77b06c14610956578063c3c8b5d61461096b57610394565b8063a3d545f5146108d7578063a66c0f77146108f7578063a7c2f1191461090c57610394565b8063823a7b9c1161016f57806387c891bd1161014957806387c891bd146108565780638d559c381461086b57806396585fc21461087f578063a0c3f2d21461089f57610394565b8063823a7b9c146107f6578063865e6fd314610816578063873a5a701461083657610394565b8063690b7536116101ab578063690b7536146107a45780636aa1c2ef146107b957806372e46810146107ce5780637593ff71146107d657610394565b806365244ece1461074d5780636558954f1461076d5780636611f8431461078457610394565b80633101cfcb116102b65780634de2b735116102545780635248184a116102235780635248184a146106ec5780635cd8a76b1461070e578063605239a114610723578063612c8d981461073857610394565b80634de2b735146106825780634ee4d72b146106af5780634f2a693f146106c457806352091f17146106e457610394565b80633b3159b6116102905780633b3159b6146105e1578063468c96ae1461060957806349096d26146106405780634d8df0631461066257610394565b80633101cfcb1461058157806331a8aef5146105a1578063367ec12b146105c157610394565b8063217f35c2116103235780632924de71116102fd5780632924de71146104ff578063297a8fca1461051f5780632d784a98146105345780632f78204c1461056157610394565b8063217f35c21461049d57806323c65eb0146104b257806328bde1e1146104d257610394565b80630f43a6771161035f5780630f43a6771461040a57806311662dc2146104205780631196ab661461045d57806315b5ebde1461047d57610394565b8063038278841461039c57806304d971ab146103c557806306040618146103f557610394565b3661039457610392610ab7565b005b610392610ab7565b3480156103a857600080fd5b506103b26104b081565b6040519081526020015b60405180910390f35b3480156103d157600080fd5b506103e56103e036600461484b565b610b36565b60405190151581526020016103bc565b34801561040157600080fd5b506103b2610b5d565b34801561041657600080fd5b506103b260aa5481565b34801561042c57600080fd5b5061044061043b366004614884565b610b6d565b6040805193151584526020840192909252908201526060016103bc565b34801561046957600080fd5b506103926104783660046148b0565b610bf0565b34801561048957600080fd5b50610392610498366004614884565b610c04565b3480156104a957600080fd5b506103e5610d23565b3480156104be57600080fd5b506103e56104cd366004614884565b610d38565b3480156104de57600080fd5b506104f26104ed3660046148c9565b610d5c565b6040516103bc91906148e6565b34801561050b57600080fd5b506103e561051a3660046148c9565b610e3c565b34801561052b57600080fd5b506004546103b2565b34801561054057600080fd5b5061055461054f3660046148c9565b610e48565b6040516103bc9190614944565b34801561056d57600080fd5b5061039261057c366004614969565b610ec3565b34801561058d57600080fd5b5061039261059c3660046148c9565b6110e3565b3480156105ad57600080fd5b506103e56105bc366004614884565b6111cc565b3480156105cd57600080fd5b506103926105dc3660046149c4565b6111f8565b3480156105ed57600080fd5b5060685b6040516001600160a01b0390911681526020016103bc565b34801561061557600080fd5b506106296106243660046148b0565b611384565b6040805192151583526020830191909152016103bc565b34801561064c57600080fd5b506106556113c2565b6040516103bc9190614ace565b34801561066e57600080fd5b5061039261067d3660046148b0565b6114a2565b34801561068e57600080fd5b506106a261069d366004614ae1565b6114b3565b6040516103bc9190614b56565b3480156106bb57600080fd5b5060e4546103b2565b3480156106d057600080fd5b506103926106df3660046148b0565b611565565b610392611576565b3480156106f857600080fd5b5061070161199c565b6040516103bc9190614b9c565b34801561071a57600080fd5b50610392611af0565b34801561072f57600080fd5b506072546103b2565b34801561074457600080fd5b506076546103b2565b34801561075957600080fd5b506103e56107683660046148c9565b611c82565b34801561077957600080fd5b506103b26201518081565b34801561079057600080fd5b5061039261079f3660046148b0565b611cbc565b3480156107b057600080fd5b5060e5546103b2565b3480156107c557600080fd5b506001546103b2565b610392611ccd565b3480156107e257600080fd5b506103e56107f13660046148b0565b611f7f565b34801561080257600080fd5b506103926108113660046148b0565b611fa3565b34801561082257600080fd5b50610392610831366004614c3d565b611fb4565b34801561084257600080fd5b506103e56108513660046148c9565b611fd3565b34801561086257600080fd5b506002546103b2565b34801561087757600080fd5b5060666105f1565b34801561088b57600080fd5b5061044061089a3660046148c9565b61200d565b3480156108ab57600080fd5b506103e56108ba3660046148c9565b6001600160a01b0316600090815260746020526040902054151590565b3480156108e357600080fd5b506103b26108f23660046148b0565b612029565b34801561090357600080fd5b5060e6546103b2565b34801561091857600080fd5b50610392610927366004614884565b612034565b34801561093857600080fd5b506103b26122d5565b34801561094d57600080fd5b50610655612318565b34801561096257600080fd5b506106556123bf565b34801561097757600080fd5b5061039261098636600461484b565b612421565b34801561099757600080fd5b506103926109a63660046148b0565b612678565b3480156109b757600080fd5b5060a9546103b2565b3480156109cc57600080fd5b506103926109db366004614884565b612689565b3480156109ec57600080fd5b506105f16109fb366004614c59565b612741565b348015610a0c57600080fd5b50610392610a1b366004614c74565b6127d0565b348015610a2c57600080fd5b50610554610a3b3660046148c9565b6040805180820190915260008082526020820152506001600160a01b0316600090815260776020908152604091829020825180840190935280548352600101549082015290565b348015610a8e57600080fd5b5060ad546103b2565b348015610aa357600080fd5b50610392610ab2366004614ca9565b612914565b610ac16007612741565b6001600160a01b0316336001600160a01b031614158015610afd5750610ae76009612741565b6001600160a01b0316336001600160a01b031614155b15610b34576040517fffcb451300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b6001600160a01b038281166000908152607560205260409020548116908216145b92915050565b6000610b6860035490565b905090565b6001600160a01b0382166000908152603a60205260408120548190819084811015610ba357600080600093509350935050610be9565b60019350610bb18582614d10565b610bbc906001614d23565b9250610bc785612029565b610bd082612029565b610bda9190614d10565b610be5906001614d23565b9150505b9250925092565b610bf8612b9a565b610c0181612c0e565b50565b6006610c0f81612c7e565b6001600160a01b0383166000908152603c60205260409020544311610c70576040517f53e0424d0000000000000000000000000000000000000000000000000000000081526001600160a01b03841660048201526024015b60405180910390fd5b6001600160a01b038316600081815260386020908152604080832086845282528083208054600160ff199182168117909255948452603783528184208785529092529091208054909216909155610cc79043614d10565b6001600160a01b0384166000818152603a6020526040908190209290925590517f6bb2436cb6b6eb65d5a52fac2ae0373a77ade6661e523ef3004ee2d5524e6c6e90610d169085815260200190565b60405180910390a2505050565b6000610b68610d3142612ce3565b6003541090565b6001600160a01b0382166000908152603a60205260408120548211155b9392505050565b6040805160e08101825260008082526020808301829052828401829052606083018290526080830182905260a0830182905260c083018290526001600160a01b0385168252607490529190912054610dc75760405163a64b34ad60e01b815260040160405180910390fd5b506001600160a01b03908116600090815260756020908152604091829020825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c082015290565b6000610b578243610d38565b604080518082018252600080825260209182018190526001600160a01b038416815260e882528281208351808501909452805484526001015491830182905203610ebe576040517fe1fba9e200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b6006610ece81612c7e565b6000610ed8610b5d565b6001600160a01b03871660008181526037602090815260408083208584528252808320805460ff1916600117905592825260e181528282205460e090915291902054919250610f2691614d23565b60e46000828254610f379190614d23565b90915550506001600160a01b038616600090815260e06020908152604080832083905560e18252808320839055603a909152902054610f77908690612cf2565b6001600160a01b0387166000908152603a60205260409020558315611032576000610fa26009612741565b60405163138ac02f60e11b81526001600160a01b038981166004830152602482018890529190911690632715805e906044016020604051808303816000875af1158015610ff3573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110179190614d36565b90508060e4600082825461102b9190614d23565b9091555050505b8215611076576001600160a01b0386166000908152603c602052604090205461105c908690612cf2565b6001600160a01b0387166000908152603c60205260409020555b6001600160a01b0386166000818152603a6020908152604080832054815190815291820188905260019082015260608101919091528291907f54ce99c5ce1fc9f61656d4a0fb2697974d0c973ac32eecaefe06fcf18b8ef68a9060800160405180910390a3505050505050565b600054600390610100900460ff16158015611105575060005460ff8083169116105b6111685760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055611187600e83612d09565b6000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b6001600160a01b038216600090815260376020908152604080832084845290915281205460ff16610d55565b600054610100900460ff16158080156112185750600054600160ff909116105b806112325750303b158015611232575060005460ff166001145b6112955760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805460ff1916600117905580156112b8576000805461ff0019166101001790555b6112c360068e612d09565b6112ce60098d612d09565b6112d960078c612d09565b6112e460058b612d09565b6112ef600a8a612d09565b6112f887612dad565b61130186612de2565b61130a85612e17565b61131384612c0e565b61131d8235612e88565b61132a6020830135612ebd565b60018390558015611375576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050505050565b60008061139043612029565b831115806113ab575060008381526005602052604090205415155b600093845260056020526040909320549293915050565b606060aa5467ffffffffffffffff8111156113df576113df614d65565b604051908082528060200260200182016040528015611408578160200160208202803683370190505b5090506000805b825181101561149c57600081815260ab6020526040902054611439906001600160a01b0316611c82565b1561149457600081815260ab60205260409020546001600160a01b0316838361146181614d7b565b94508151811061147357611473614d4f565b60200260200101906001600160a01b031690816001600160a01b0316815250505b60010161140f565b50815290565b6114aa612b9a565b610c0181612ebd565b60608167ffffffffffffffff8111156114ce576114ce614d65565b6040519080825280602002602001820160405280156114f7578160200160208202803683370190505b50905060005b8281101561155e5761153484848381811061151a5761151a614d4f565b905060200201602081019061152f91906148c9565b612ef2565b82828151811061154657611546614d4f565b911515602092830291909101909101526001016114fd565b5092915050565b61156d612b9a565b610c0181612de2565b61157e612f13565b600061158933611c82565b801561159b575061159933612ef2565b155b80156115db57506115d9336115ae610b5d565b6001600160a01b03919091166000908152603760209081526040808320938352929052205460ff1690565b155b90506000806115ea6007612741565b6040517f0634f5b90000000000000000000000000000000000000000000000000000000081528415156004820152600060248201526001600160a01b039190911690630634f5b9906044016080604051808303816000875af1158015611654573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906116789190614d94565b935050925050826116cf573460e460008282546116959190614d23565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90610d16903490600190614de9565b604080513481526020810184905233917f0ede5c3be8625943fa64003cd4b91230089411249f3059bac6500873543ca9b1910160405180910390a26000611714610b5d565b905060006117228434614d23565b905060006127106117338584614e0d565b61173d9190614e3a565b9050600061174b8284614d10565b905060008260e260008282546117619190614d23565b909155505033600090815260386020908152604080832088845290915290205460ff161561186c5760006117956006612741565b6001600160a01b031663c6391fa26040518163ffffffff1660e01b8152600401608060405180830381865afa1580156117d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906117f69190614e4e565b9350505050612710818461180a9190614e0d565b6118149190614e3a565b91508160e460008282546118289190614d23565b909155505060405133907f4042bb9a70998f80a86d9963f0d2132e9b11c8ad94d207c6141c8e34b05ce53e90611862908590600290614de9565b60405180910390a2505b6118768183614d10565b91506000806118856009612741565b6001600160a01b0316634530d2026040518163ffffffff1660e01b81526004016040805180830381865afa1580156118c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906118e59190614e84565b33600090815260756020526040812060040154929450909250906119139061190d9084612f4c565b84612cf2565b905060006127106119248784614e0d565b61192e9190614e3a565b33600090815260e06020526040812080549293508392909190611952908490614d23565b90915550600090506119648288614d10565b33600090815260e16020526040812080549293508392909190611988908490614d23565b909155505050505050505050505050505050565b60735460609067ffffffffffffffff8111156119ba576119ba614d65565b604051908082528060200260200182016040528015611a2157816020015b6040805160e08101825260008082526020808301829052928201819052606082018190526080820181905260a0820181905260c082015282526000199092019101816119d85790505b50905060005b8151811015611aec576075600060738381548110611a4757611a47614d4f565b60009182526020808320909101546001600160a01b039081168452838201949094526040928301909120825160e081018452815485168152600182015485169281019290925260028101548416928201929092526003820154909216606083015260048101546080830152600581015460a08301526006015460c08201528251839083908110611ad957611ad9614d4f565b6020908102919091010152600101611a27565b5090565b600054600290610100900460ff16158015611b12575060005460ff8083169116105b611b755760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c67565b6000805461ffff191660ff831617610100179055607154611ba1906009906001600160a01b0316612d09565b606f54611bb9906005906001600160a01b0316612d09565b607054611bd1906006906001600160a01b0316612d09565b606d54611be9906007906001600160a01b0316612d09565b60a854611c0190600a906001600160a01b0316612d09565b607180546001600160a01b0319908116909155606f8054821690556070805482169055606d805482169055606e80548216905560a8805490911690556000805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6001600160a01b038116600090815260ac6020526040812054610b579060019060ff166003811115611cb657611cb6614dd3565b90612f5b565b611cc4612b9a565b610c0181612e88565b611cd5612f13565b611cde43611f7f565b611d14576040517f6c74eecf00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611d1d43612029565b611d28600254612029565b10611d5f576040517f2458f64100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b436002556000611d6e42612ce3565b90506000611d7d826003541090565b90506000611d89612318565b905060606000611d9843612029565b90506000611da7826001614d23565b90506000611db3610b5d565b9050611dbf8386612f8e565b8515611f1957600080611dd283886130fd565b91509150611de2838884846132e9565b611dea61340c565b611df2613560565b6000611dfe6006612741565b6040517f7680850c0000000000000000000000000000000000000000000000000000000081529091506001600160a01b03821690637680850c90611e48908b908890600401614ea8565b600060405180830381600087803b158015611e6257600080fd5b505af1158015611e76573d6000803e3d6000fd5b50505050611e838a6136bc565b8051919950975015611f07576040517f07c2d2f60000000000000000000000000000000000000000000000000000000081526001600160a01b038216906307c2d2f690611ed4908a90600401614ace565b600060405180830381600087803b158015611eee57600080fd5b505af1158015611f02573d6000803e3d6000fd5b505050505b611f12436001614d23565b6004555050505b611f2487838761384d565b82817f0195462033384fec211477c56217da64a58bd405e0bed331ba4ded67e4ae4ce788604051611f59911515815260200190565b60405180910390a350600090815260056020526040902085905550505060039190915550565b600060018054611f8f9190614d10565b600154611f9c9084614eca565b1492915050565b611fab612b9a565b610c0181612dad565b611fbc612b9a565b611fc581613ae9565b611fcf8282612d09565b5050565b600080611fde610b5d565b6001600160a01b038416600090815260376020908152604080832084845290915290205490915060ff16610d55565b600080600061201c8443610b6d565b9250925092509193909250565b6000610b5782613b38565b600961203f81612c7e565b6001600160a01b038316600090815260e860205260409020600181015415612093576040517f2bd5598800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600061209f8442614d23565b6001600160a01b03861660009081526075602052604090209091506120c49082613b53565b6001600160a01b0385166000818152603b602052604080822084905560e554905163138ac02f60e11b815260048101939093526024830152903390632715805e906044016020604051808303816000875af1158015612127573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061214b9190614d36565b9050801561228a57600060e654426121639190614d23565b60e78054600180820183556000929092527f6cb0db1d7354dfb4a1464318006df0643cafe2002a86a29ff8560f900fef28a10180546001600160a01b0319166001600160a01b038b16179055838655850181905590506121ea7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b031690565b6001600160a01b03888116600081815260756020526040908190206002015490517fa2fae5700000000000000000000000000000000000000000000000000000000081526004810192909252821660248201524260448201526064810184905291169063a2fae57090608401600060405180830381600087803b15801561227057600080fd5b505af1158015612284573d6000803e3d6000fd5b50505050505b856001600160a01b03167f77a1a819870c0f4d04c3ca4cc2881a0393136abc28bd651af50aedade94a27c4826040516122c591815260200190565b60405180910390a2505050505050565b6000805b60aa54811015611aec57600081815260ab6020526040902054612304906001600160a01b0316611c82565b15612310576001909101905b6001016122d9565b606060aa5467ffffffffffffffff81111561233557612335614d65565b60405190808252806020026020018201604052801561235e578160200160208202803683370190505b50905060005b8151811015611aec57600081815260ab602052604090205482516001600160a01b0390911690819084908490811061239e5761239e614d4f565b6001600160a01b039092166020928302919091019091015250600101612364565b6060607380548060200260200160405190810160405280929190818152602001828054801561241757602002820191906000526020600020905b81546001600160a01b031681526001909101906020018083116123f9575b5050505050905090565b612429612b9a565b6001600160a01b038216600090815260e8602052604090206001015415611fcf5760e7548060005b828110156124a057846001600160a01b031660e7828154811061247657612476614d4f565b6000918252602090912001546001600160a01b031603612498578091506124a0565b600101612451565b508181036124ae5750505050565b6001600160a01b038416600090815260e860205260409020548015612671576001600160a01b038516600090815260e8602052604081208181556001908101919091558311156125705760e7612505600185614d10565b8154811061251557612515614d4f565b60009182526020909120015460e780546001600160a01b03909216918490811061254157612541614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061258157612581614ede565b60008281526020808220830160001990810180546001600160a01b03191690559092019092556001600160a01b038716825260e9905260409020805460ff191660011790556125d384826104b0613bdc565b1561262c57836001600160a01b0316856001600160a01b03167f7229136a18186c71a86246c012af3bb1df6460ef163934bbdccd6368abdd41e48360405161261d91815260200190565b60405180910390a35050505050565b604080518281524760208201526001600160a01b0380871692908816917f3747d14eb72ad3e35cba9c3e00dab3b8d15b40cac6bdbd08402356e4f69f30a1910161261d565b5050505050565b612680612b9a565b610c0181612e17565b600961269481612c7e565b61269d83613c3c565b156126d4576040517f030081e700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152607560205260409020600581015415612728576040517ffab9167300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61273b816127368542614d23565b613b53565b50505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561277857612778614dd3565b60ff1681526020810191909152604001600020546001600160a01b0316905080610ebe57816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c679190614f08565b60096127db81612c7e565b6001600160a01b0384166000908152607760205260409020541561282b576040517f5e65b9ba00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b61271082111561284e57604051631b8454a360e21b815260040160405180910390fd5b60765483101561288a576040517ffa0ae69300000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b03841660009081526077602052604081209062015180856128b28242614e3a565b6128bc9190614d23565b6128c69190614e0d565b8083556001830185905560408051828152602081018790529192506001600160a01b038816917f6ebafd1bb6316b2f63198a81b05cff2149c6eaae1784466a6d062b4391900f2191016122c5565b600961291f81612c7e565b607354607254811061295d576040517f8616841b00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260746020526040902054156129ad576040517f8ad9cdf900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108311156129d057604051631b8454a360e21b815260040160405180910390fd5b60005b607354811015612ac957600060756000607384815481106129f6576129f6614d4f565b60009182526020808320909101546001600160a01b03908116845290830193909352604090910190208054909250811690891603612a6b576040517ffc3d8c750000000000000000000000000000000000000000000000000000000081526001600160a01b0389166004820152602401610c67565b60028101546001600160a01b0390811690871603612ac0576040517f5a674fce0000000000000000000000000000000000000000000000000000000081526001600160a01b0387166004820152602401610c67565b506001016129d3565b506001600160a01b038581166000818152607460209081526040808320861990556073805460018082019092557ff79bde9ddd17963ebce6f7d021d60de7c2bd0db944d23c900c0c0e775f5300520180546001600160a01b031990811687179091556075909352818420805484168d881690811782559181018054851687179055600281018054909416968b1696871790935560048301899055905191949093909290917f1ca451a9920472b99355a9cf74185bf017604a7849c113f020888ecec9db93669190a450505050505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610b34576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610c67929190614f16565b6001811015612c49576040517f17b8970f00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60768190556040518181527f266d432ffe659e3565750d26ec685b822a58041eee724b67a5afec3168a2526790602001611c77565b612c8781612741565b6001600160a01b0316336001600160a01b031614610c01576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c6793929190614f37565b6000610b576201518083614e3a565b600081831015612d025781610d55565b5090919050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115612d3f57612d3f614dd3565b60ff168152602081019190915260400160002080546001600160a01b0319166001600160a01b03928316179055811682600f811115612d8057612d80614dd3565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b60a98190556040518181527fb5464c05fd0e0f000c535850116cda2742ee1f7b34384cb920ad7b8e802138b590602001611c77565b60728190556040518181527f82d5dc32d1b741512ad09c32404d7e7921e8934c6222343d95f55f7a2b9b2ab490602001611c77565b60a954811115612e53576040517faa8119d200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60ad8190556040518181527fa9588dc77416849bd922605ce4fc806712281ad8a8f32d4238d6c8cca548e15e90602001611c77565b60e58190556040518181527f17a6c3eb965cdd7439982da25abf85be88f0f772ca33198f548e2f99fee0289a90602001611c77565b60e68190556040518181527f0a50c66137118f386332efb949231ddd3946100dbf880003daca37ddd9e0662b90602001611c77565b6001600160a01b0381166000908152603a6020526040812054431115610b57565b334114610b34576040517f09f358fd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000818310612d025781610d55565b6000816003811115612f6f57612f6f614dd3565b836003811115612f8157612f81614dd3565b1660ff1615159392505050565b6000612f9a600e612741565b6001600160a01b031663468d24be84846040518363ffffffff1660e01b8152600401612fc7929190614f6c565b600060405180830381865afa158015612fe4573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261300c9190810190614fe2565b90506000825160015461301f9190614e0d565b60e25490915060009081805b86518110156130ce578486828151811061304757613047614d4f565b60200260200101518461305a9190614e0d565b6130649190614e3a565b93508360e3600089848151811061307d5761307d614d4f565b60200260200101516001600160a01b03166001600160a01b0316815260200190815260200160002060008282546130b49190614d23565b909155506130c490508483614d23565b915060010161302b565b506130d98183614d10565b60e460008282546130ea9190614d23565b9091555050600060e25550505050505050565b60006060600080845167ffffffffffffffff81111561311e5761311e614d65565b604051908082528060200260200182016040528015613147578160200160208202803683370190505b50925060005b85518110156132df5785818151811061316857613168614d4f565b6020908102919091018101516001600160a01b03808216600090815260759093526040909220600201549094501691506131a183612ef2565b1580156131d257506001600160a01b03831660009081526037602090815260408083208a845290915290205460ff16155b15613250576001600160a01b038316600090815260e160205260409020546131fa9086614d23565b6001600160a01b038416600090815260e1602052604090205485519196509085908390811061322b5761322b614d4f565b6020026020010181815250506132418383613cd5565b61324b8383613d9d565b6132a7565b6001600160a01b038316600090815260e3602090815260408083205460e183528184205460e09093529220546132869190614d23565b6132909190614d23565b60e460008282546132a19190614d23565b90915550505b6001600160a01b038316600090815260e16020908152604080832083905560e0825280832083905560e390915281205560010161314d565b5050509250929050565b60006132f56009612741565b90508215612671576133078184613e58565b156133c8576040517facd79c460000000000000000000000000000000000000000000000000000000081526001600160a01b0382169063acd79c469061335590879086908a906004016150a8565b600060405180830381600087803b15801561336f57600080fd5b505af1158015613383573d6000803e3d6000fd5b505050507f9e242ca1ef9dde96eb71ef8d19a3f0f6a619b63e4c0d3998771387103656d0878385846040516133ba939291906150de565b60405180910390a15061273b565b7fe5668ec1bb2b6bb144a50f810e388da4b1d7d3fc05fcb9d588a1aac59d248f89838584476040516133fd9493929190615113565b60405180910390a15050505050565b60e754600080805b8383101561273b5760e7838154811061342f5761342f614d4f565b60009182526020808320909101546001600160a01b031680835260e8909152604090912060018101549193509150421061355557805460e48054600090613477908490614d23565b90915550506001600160a01b038216600090815260e8602052604081208181556001018190556134a685615150565b945084111561351d5760e784815481106134c2576134c2614d4f565b60009182526020909120015460e780546001600160a01b0390921691859081106134ee576134ee614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b60e780548061352e5761352e614ede565b600082815260209020810160001990810180546001600160a01b0319169055019055613414565b600190920191613414565b60e4548015610c015760006135756007612741565b600060e481905560408051600481526024810182526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f59f778df00000000000000000000000000000000000000000000000000000000179052905192935090916001600160a01b0384169185916135f09190615167565b60006040518083038185875af1925050503d806000811461362d576040519150601f19603f3d011682016040523d82523d6000602084013e613632565b606091505b50509050801561367757816001600160a01b03167fc447c884574da5878be39c403db2245c22530c99b579ea7bcbb3720e1d110dc884604051610d1691815260200190565b604080518481524760208201526001600160a01b038416917fa0561a59abed308fcd0556834574739d778cc6229018039a24ddda0f86aa0b739101610d16565b505050565b6060806136c883613eb4565b905060006136d66009612741565b6001600160a01b03166391f8723f60736040518263ffffffff1660e01b81526004016137029190615196565b600060405180830381865afa15801561371f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526137479190810190614fe2565b90506000613755600a612741565b6001600160a01b031663520fce6260736040518263ffffffff1660e01b81526004016137819190615196565b600060405180830381865afa15801561379e573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526137c69190810190614fe2565b90506000613835607380548060200260200160405190810160405280929190818152602001828054801561382357602002820191906000526020600020905b81546001600160a01b03168152600190910190602001808311613805575b5050505050848460a95460ad546143dc565b90955090506138458582886144ed565b505050915091565b60006138596005612741565b6001600160a01b031663fdadda8183613873436001614d23565b6040518363ffffffff1660e01b8152600401613890929190614ea8565b600060405180830381865afa1580156138ad573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526138d591908101906151da565b905060005b8251811015613aa25760008382815181106138f7576138f7614d4f565b6020908102919091018101516001600160a01b0381166000908152603b90925260408220549092504211159061392c83611c82565b9050600061395f8461393f436001614d23565b6001600160a01b03919091166000908152603a6020526040902054101590565b80613980575085858151811061397757613977614d4f565b60200260200101515b806139885750825b159050811580156139965750805b15613a11576001600160a01b038416600090815260ac60205260409020546139d59060019060ff1660038111156139cf576139cf614dd3565b9061462d565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613a0757613a07614dd3565b0217905550613a93565b818015613a1c575080155b15613a93576001600160a01b038416600090815260ac6020526040902054613a5b9060019060ff166003811115613a5557613a55614dd3565b90614668565b6001600160a01b038516600090815260ac60205260409020805460ff19166001836003811115613a8d57613a8d614dd3565b02179055505b846001019450505050506138da565b5082847f283b50d76057d5f828df85bc87724c6af604e9b55c363a07c9faa2a2cd688b82613ace6113c2565b604051613adb9190614ace565b60405180910390a350505050565b806001600160a01b03163b600003610c01576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c67565b600060015482613b489190614e3a565b610b57906001614d23565b60018201546001600160a01b0316600090815260746020526040902054613b8d5760405163a64b34ad60e01b815260040160405180910390fd5b6005820181905560018201546040518281526001600160a01b03909116907fb9a1e33376bfbda9092f2d1e37662c1b435aab0d3fa8da3acc8f37ee222f99e79060200160405180910390a25050565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613c2c576040519150601f19603f3d011682016040523d82523d6000602084013e613c31565b606091505b509095945050505050565b600080613c49600a612741565b6040517f41feed1c0000000000000000000000000000000000000000000000000000000081526001600160a01b03858116600483015291909116906341feed1c90602401602060405180830381865afa158015613caa573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613cce9190614d36565b1192915050565b6001600160a01b038216600090815260e0602052604090205480156136b757613d0182826104b0613bdc565b15613d5857816001600160a01b0316836001600160a01b03167f1ce7a1c4702402cd393500acb1de5bd927727a54e144a587d328f1b679abe4ec83604051613d4b91815260200190565b60405180910390a3505050565b604080518281524760208201526001600160a01b0380851692908616917f6c69e09ee5c5ac33c0cd57787261c5bade070a392ab34a4b5487c6868f723f6e9101613d4b565b6001600160a01b038216600090815260e3602052604090205480156136b757613dc982826104b0613bdc565b15613e1357816001600160a01b0316836001600160a01b03167f0c4d6a43fc8470dee97db74874b5685e412cc517d9bdecfde1623c5e835b18e483604051613d4b91815260200190565b604080518281524760208201526001600160a01b0380851692908616917f98697ee35f04a599a814432016fff3968c483d2d88dacb484926b9358f8e7cf99101613d4b565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114613ea5576040519150601f19603f3d011682016040523d82523d6000602084013e613eaa565b606091505b5090949350505050565b60606000613ec26009612741565b90506000816001600160a01b031663af2454296040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f04573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f289190614d36565b90506000826001600160a01b031663909791dd6040518163ffffffff1660e01b8152600401602060405180830381865afa158015613f6a573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190613f8e9190614d36565b90506000836001600160a01b03166342ef3c3460736040518263ffffffff1660e01b8152600401613fbf9190615196565b600060405180830381865afa158015613fdc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526140049190810190614fe2565b60735490915060008167ffffffffffffffff81111561402557614025614d65565b60405190808252806020026020018201604052801561404e578160200160208202803683370190505b50965060008060005b84831015614314576073838154811061407257614072614d4f565b60009182526020808320909101546001600160a01b0316808352607590915260409091206006810154885192945090925015159088908890869081106140ba576140ba614d4f565b6020026020010151101561412857806141235760006140d98a42614d23565b600684018190556040518181529091506001600160a01b038516907f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a342759060200160405180910390a2505b61417b565b801561417b578160060160009055826001600160a01b03167f88f854e137380c14d63f6ed99781bf13402167cf55bac49bcd44d4f2d6a34275600060405161417291815260200190565b60405180910390a25b60008260050154600014158015614196575042836005015411155b806141b957506001600160a01b038416600090815260e9602052604090205460ff165b9050600083600601546000141580156141d6575042846006015411155b905081806141e15750805b1561427357886141f089615150565b9850888151811061420357614203614d4f565b602002602001015189878151811061421d5761421d614d4f565b602002602001018181525050848d888060010199508151811061424257614242614d4f565b60200260200101906001600160a01b031690816001600160a01b03168152505061426b856146a4565b505050614057565b6001600160a01b038516600090815260776020526040902054801580159061429b5750428111155b15614304576001600160a01b0386166000818152607760209081526040808320600181018054918590559390935560048901839055518281529192917f86d576c20e383fc2413ef692209cc48ddad5e52f25db5b32f8f7ec5076461ae9910160405180910390a2505b5050600190940193506140579050565b50505080875280156143d1577f4eaf233b9dc25a5552c1927feee1412eea69add17c2485c831c2e60e234f3c918760405161434f9190614ace565b60405180910390a16040517fe22d1c9d0000000000000000000000000000000000000000000000000000000081526001600160a01b0387169063e22d1c9d9061439e908a908c90600401614ea8565b600060405180830381600087803b1580156143b857600080fd5b505af11580156143cc573d6000803e3d6000fd5b505050505b505050505050919050565b60606000806068905060008888888888604051602401614400959493929190615269565b60408051601f19818403018152919052602080820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f779415120000000000000000000000000000000000000000000000000000000017905281518b51929350600192909160009161447191614e0d565b61447c906040614d23565b90506020840181888483895afa61449257600093505b503d61449d57600092505b602087019650826144da576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8651955050505050509550959350505050565b815b60aa5481101561454157600081815260ab6020818152604080842080546001600160a01b0316855260ac8352908420805460ff19169055928490525280546001600160a01b03191690556001016144ef565b5060005b8281101561458157600081815260ab60209081526040808320546001600160a01b0316835260ac9091529020805460ff19169055600101614545565b5060005b828110156145f55760008482815181106145a1576145a1614d4f565b6020908102919091018101516001600160a01b0316600081815260ac83526040808220805460ff1916600317905585825260ab9093529190912080546001600160a01b031916909117905550600101614585565b508160aa81905550807f3d0eea40644a206ec25781dd5bb3b60eb4fa1264b993c3bddf3c73b14f29ef5e84604051610d169190614ace565b600081600381111561464157614641614dd3565b83600381111561465357614653614dd3565b1760ff166003811115610d5557610d55614dd3565b600081600381111561467c5761467c614dd3565b1983600381111561468f5761468f614dd3565b1660ff166003811115610d5557610d55614dd3565b6001600160a01b038116600090815260e960209081526040808320805460ff191690556074909152812054610c01918391908190036146e1575050565b6001600160a01b038216600090815260756020908152604080832080546001600160a01b03199081168255600180830180548316905560028301805483169055600383018054909216909155600482018590556005820185905560069091018490556074835281842084905560779092528220828155810182905560738054909161476b91614d10565b8154811061477b5761477b614d4f565b6000918252602090912001546001600160a01b039081169150831681146147fe576001600160a01b03811660009081526074602052604090208290556073805482919084199081106147cf576147cf614d4f565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b607380548061480f5761480f614ede565b600082815260209020810160001990810180546001600160a01b0319169055019055505050565b6001600160a01b0381168114610c0157600080fd5b6000806040838503121561485e57600080fd5b823561486981614836565b9150602083013561487981614836565b809150509250929050565b6000806040838503121561489757600080fd5b82356148a281614836565b946020939093013593505050565b6000602082840312156148c257600080fd5b5035919050565b6000602082840312156148db57600080fd5b8135610d5581614836565b60e08101610b5782846001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b815181526020808301519082015260408101610b57565b8015158114610c0157600080fd5b6000806000806080858703121561497f57600080fd5b843561498a81614836565b9350602085013592506040850135915060608501356149a88161495b565b939692955090935050565b8060408101831015610b5757600080fd5b6000806000806000806000806000806000806101a08d8f0312156149e757600080fd5b8c356149f281614836565b9b5060208d0135614a0281614836565b9a5060408d0135614a1281614836565b995060608d0135614a2281614836565b985060808d0135614a3281614836565b975060a08d0135614a4281614836565b965060c08d0135955060e08d013594506101008d013593506101208d013592506101408d01359150614a788e6101608f016149b3565b90509295989b509295989b509295989b565b600081518084526020808501945080840160005b83811015614ac35781516001600160a01b031687529582019590820190600101614a9e565b509495945050505050565b602081526000610d556020830184614a8a565b60008060208385031215614af457600080fd5b823567ffffffffffffffff80821115614b0c57600080fd5b818501915085601f830112614b2057600080fd5b813581811115614b2f57600080fd5b8660208260051b8501011115614b4457600080fd5b60209290920196919550909350505050565b6020808252825182820181905260009190848201906040850190845b81811015614b90578351151583529284019291840191600101614b72565b50909695505050505050565b6020808252825182820181905260009190848201906040850190845b81811015614b9057614c1b8385516001600160a01b03808251168352806020830151166020840152806040830151166040840152806060830151166060840152506080810151608083015260a081015160a083015260c081015160c08301525050565b9284019260e09290920191600101614bb8565b803560108110610ebe57600080fd5b60008060408385031215614c5057600080fd5b61486983614c2e565b600060208284031215614c6b57600080fd5b610d5582614c2e565b600080600060608486031215614c8957600080fd5b8335614c9481614836565b95602085013595506040909401359392505050565b60008060008060808587031215614cbf57600080fd5b8435614cca81614836565b93506020850135614cda81614836565b92506040850135614cea81614836565b9396929550929360600135925050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610b5757610b57614cfa565b80820180821115610b5757610b57614cfa565b600060208284031215614d4857600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b600060018201614d8d57614d8d614cfa565b5060010190565b60008060008060808587031215614daa57600080fd5b8451614db58161495b565b60208601516040870151606090970151919890975090945092505050565b634e487b7160e01b600052602160045260246000fd5b8281526040810160038310614e0057614e00614dd3565b8260208301529392505050565b8082028115828204841417610b5757610b57614cfa565b634e487b7160e01b600052601260045260246000fd5b600082614e4957614e49614e24565b500490565b60008060008060808587031215614e6457600080fd5b505082516020840151604085015160609095015191969095509092509050565b60008060408385031215614e9757600080fd5b505080516020909101519092909150565b604081526000614ebb6040830185614a8a565b90508260208301529392505050565b600082614ed957614ed9614e24565b500690565b634e487b7160e01b600052603160045260246000fd5b60108110614f0457614f04614dd3565b9052565b60208101610b578284614ef4565b6001600160e01b03198316815260408101600b8310614e0057614e00614dd3565b6001600160e01b03198416815260608101614f556020830185614ef4565b6001600160a01b0383166040830152949350505050565b828152604060208201526000614f856040830184614a8a565b949350505050565b604051601f8201601f1916810167ffffffffffffffff81118282101715614fb657614fb6614d65565b604052919050565b600067ffffffffffffffff821115614fd857614fd8614d65565b5060051b60200190565b60006020808385031215614ff557600080fd5b825167ffffffffffffffff81111561500c57600080fd5b8301601f8101851361501d57600080fd5b805161503061502b82614fbe565b614f8d565b81815260059190911b8201830190838101908783111561504f57600080fd5b928401925b8284101561506d57835182529284019290840190615054565b979650505050505050565b600081518084526020808501945080840160005b83811015614ac35781518752958201959082019060010161508c565b6060815260006150bb6060830186614a8a565b82810360208401526150cd8186615078565b915050826040830152949350505050565b8381526060602082015260006150f76060830185614a8a565b82810360408401526151098185615078565b9695505050505050565b84815260806020820152600061512c6080830186614a8a565b828103604084015261513e8186615078565b91505082606083015295945050505050565b60008161515f5761515f614cfa565b506000190190565b6000825160005b81811015615188576020818601810151858301520161516e565b506000920191825250919050565b6020808252825482820181905260008481528281209092916040850190845b81811015614b905783546001600160a01b0316835260019384019392850192016151b5565b600060208083850312156151ed57600080fd5b825167ffffffffffffffff81111561520457600080fd5b8301601f8101851361521557600080fd5b805161522361502b82614fbe565b81815260059190911b8201830190838101908783111561524257600080fd5b928401925b8284101561506d57835161525a8161495b565b82529284019290840190615247565b60a08152600061527c60a0830188614a8a565b828103602084015261528e8188615078565b905082810360408401526152a28187615078565b6060840195909552505060800152939250505056fea2646970667358221220e1fa978536e3e7e5a867331abd0de9fa2550e65c5dc601ff991cba8430538f4f64736f6c6343000815003300000000000000000000000000000000000000000000000000000000000000 + ├─ [4274288] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + │ ├─ emit Initialized(version: 255) + │ └─ ← 21229 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(1) [staticcall] + │ └─ ← ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f] + ├─ [0] VM::load(ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [86968] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3]) + │ ├─ [81147] RoninValidatorSet::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 9, addr: ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758]) + │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ ├─ emit ContractUpdated(contractType: 6, addr: ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3]) + │ │ ├─ emit ContractUpdated(contractType: 7, addr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816]) + │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], RoninValidatorSet, RoninValidatorSetLogic, 0x, 1)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, RoninValidatorSetLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(10) [staticcall] + │ └─ ← FastFinalityTracking + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(10) [staticcall] + │ └─ ← ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576] + ├─ [0] ronin-mainnet.RoninValidatorSet::initializeV3(ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576])  + │ ├─ [0] RoninValidatorSet::initializeV3(ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 14, addr: ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576]) + │ │ ├─ emit Initialized(version: 3) + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(5) [staticcall] + │ └─ ← Staking + ├─ [0] GeneralConfig::getContractFileName(5) [staticcall] + │ └─ ← Staking.sol:Staking + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000002 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(Staking.sol:Staking) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000401360806040523480156200001157600080fd5b5060016000556200002162000027565b620000e9565b60d154610100900460ff1615620000945760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60d15460ff9081161015620000e75760d1805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b613f1a80620000f96000396000f3fe6080604052600436106102bf5760003560e01c80636bd8f8041161016e578063aa15a6fd116100cb578063d01b8eed1161007f578063e22d1c9d11610064578063e22d1c9d14610821578063f92ad21914610841578063f9f031df14610861576102d1565b8063d01b8eed14610790578063de981f1b14610801576102d1565b8063af245429116100b0578063af2454291461070a578063c2a672e01461071f578063c50870031461073f576102d1565b8063aa15a6fd146106d7578063acd79c46146106f7576102d1565b8063909791dd11610122578063924f081e11610107578063924f081e146106775780639488e4e914610697578063969ffc14146106b7576102d1565b8063909791dd1461064257806391f8723f14610657576102d1565b8063865e6fd311610153578063865e6fd3146105c9578063888b9ae9146105e9578063895ab74214610609576102d1565b80636bd8f8041461055f57806376664b651461057f576102d1565b806342e0c4081161021c5780635c19a95c116101d05780636558954f116101b55780636558954f14610508578063679a6e431461051f5780636b0916951461053f576102d1565b80635c19a95c146104e05780635cd8a76b146104f3576102d1565b80634530d202116102015780634530d202146104785780634d99dd16146104a057806357473447146104c0576102d1565b806342e0c4081461040d57806342ef3c3414610458576102d1565b80631658c86e116102735780632715805e116102585780632715805e146103ba5780632baae125146103da5780633d8e846e146103ed576102d1565b80631658c86e1461038757806326476204146103a7576102d1565b8063095f6475116102a4578063095f64751461031a578063097e4a9d146103475780630dccaf4614610367576102d1565b806303827884146102dc5780630682e8fa14610305576102d1565b366102d15760086102cf81610881565b005b60086102cf81610881565b3480156102e857600080fd5b506102f26104b081565b6040519081526020015b60405180910390f35b34801561031157600080fd5b506038546102f2565b34801561032657600080fd5b5061033a6103353660046136cb565b6108f2565b6040516102fc9190613772565b34801561035357600080fd5b506102f261036236600461379a565b610a2b565b34801561037357600080fd5b506102cf6103823660046137f1565b610ae1565b34801561039357600080fd5b506102cf6103a2366004613842565b610c1a565b6102cf6103b5366004613842565b610ca3565b3480156103c657600080fd5b506102f26103d5366004613866565b610cdc565b6102cf6103e83660046137f1565b610d6d565b3480156103f957600080fd5b5061033a610408366004613892565b610ef8565b34801561041957600080fd5b50610448610428366004613842565b6001600160a01b039081166000908152603a602052604090205416151590565b60405190151581526020016102fc565b34801561046457600080fd5b5061033a6104733660046138e7565b611051565b34801561048457600080fd5b50606e54606d54604080519283526020830191909152016102fc565b3480156104ac57600080fd5b506102cf6104bb366004613866565b61111e565b3480156104cc57600080fd5b506102cf6104db366004613929565b6111ca565b6102cf6104ee366004613842565b6111dc565b3480156104ff57600080fd5b506102cf61124a565b34801561051457600080fd5b506102f26201518081565b34801561052b57600080fd5b506102cf61053a36600461394b565b61136c565b34801561054b57600080fd5b506102f261055a366004613964565b61137d565b34801561056b57600080fd5b506102cf61057a36600461399d565b6113c4565b34801561058b57600080fd5b506102f261059a366004613964565b6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b3480156105d557600080fd5b506102cf6105e43660046139ed565b611479565b3480156105f557600080fd5b506102cf61060436600461394b565b611494565b34801561061557600080fd5b506102f2610624366004613842565b6001600160a01b031660009081526037602052604090206003015490565b34801561064e57600080fd5b50606c546102f2565b34801561066357600080fd5b5061033a6106723660046138e7565b6114a5565b34801561068357600080fd5b506102cf610692366004613a09565b611546565b3480156106a357600080fd5b506102cf6106b23660046136cb565b611639565b3480156106c357600080fd5b506102cf6106d236600461394b565b611798565b3480156106e357600080fd5b506102cf6106f2366004613842565b6117a9565b6102cf610705366004613a3e565b611832565b34801561071657600080fd5b506039546102f2565b34801561072b57600080fd5b506102cf61073a366004613866565b611886565b34801561074b57600080fd5b5061077861075a366004613842565b6001600160a01b039081166000908152603a60205260409020541690565b6040516001600160a01b0390911681526020016102fc565b34801561079c57600080fd5b506107dc6107ab366004613842565b6001600160a01b03808216600090815260376020526040902060018101546002820154600390920154921693909250565b604080516001600160a01b0390941684526020840192909252908201526060016102fc565b34801561080d57600080fd5b5061077861081c366004613ab2565b6119a2565b34801561082d57600080fd5b506102cf61083c366004613acd565b611a36565b34801561084d57600080fd5b506102cf61085c366004613b19565b611c07565b34801561086d57600080fd5b506102f261087c3660046138e7565b611d54565b61088a816119a2565b6001600160a01b0316336001600160a01b0316146108ef576000356001600160e01b03191681336040517f8383e6340000000000000000000000000000000000000000000000000000000081526004016108e693929190613b87565b60405180910390fd5b50565b6060838214610914576040516376081a7b60e11b815260040160405180910390fd5b8367ffffffffffffffff81111561092d5761092d613bbc565b604051908082528060200260200182016040528015610956578160200160208202803683370190505b50905060005b8151811015610a22576037600087878481811061097b5761097b613bd2565b90506020020160208101906109909190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002060040160008585848181106109c7576109c7613bd2565b90506020020160208101906109dc9190613842565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610a0f57610a0f613bd2565b602090810291909101015260010161095c565b50949350505050565b6000600260005403610a7f5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005581610a8e81611e04565b336000908152603a60205260409020546001600160a01b031615610ac757604051632fc6bfb160e21b81523360048201526024016108e6565b610ad333868686611ebb565b600160005595945050505050565b466107e514610b325760405162461bcd60e51b815260206004820152600260248201527f453100000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b7357832a94810e18c84a5a5e2c4dd67d012ade574f3314610b955760405162461bcd60e51b815260206004820152600260248201527f453200000000000000000000000000000000000000000000000000000000000060448201526064016108e6565b610b9f60086119a2565b60405163f883afaf60e01b81526001600160a01b0386811660048301528581166024830152848116604483015260648201849052919091169063f883afaf906084015b600060405180830381600087803b158015610bfc57600080fd5b505af1158015610c10573d6000803e3d6000fd5b5050505050505050565b80610c2481611e04565b6001600160a01b038216600090815260376020526040902033610c478282611f28565b610c5160086119a2565b6039546040517fdd716ad30000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063dd716ad390604401610be2565b610cab611f71565b80610cb581611e04565b6001600160a01b0382166000908152603760205260409020610cd8903334611fad565b5050565b60006008610ce981610881565b6001600160a01b0384166000908152603760205260409020610d0b9084612058565b915033610d1881846120f5565b610d6557604080518481524760208201526001600160a01b0380841692908816917f63701cd972aa3c7f87898aab145c972e52185beab07d6e39380a998d334cf6c8910160405180910390a35b505092915050565b600260005403610dbf5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000908155338152603a60205260409020546001600160a01b031615610dfc57604051632fc6bfb160e21b81523360048201526024016108e6565b606d54811180610e0d5750606e5481105b15610e2b57604051631b8454a360e21b815260040160405180910390fd5b3433610e3b818787878787612151565b6001600160a01b03808616600081815260376020818152604080842060018101805497891673ffffffffffffffffffffffffffffffffffffffff19988916811790915581548816871782558552603a835290842080549096168517909555929091529052610eaa818385611fad565b816001600160a01b0316866001600160a01b03167ffc1f1e73948cbc47c5b7f90e5601b7daccd9ad7173218486ccc74bdd051d05e860405160405180910390a3505060016000555050505050565b6060600080610f0760086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610f44573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f689190613be8565b90508367ffffffffffffffff811115610f8357610f83613bbc565b604051908082528060200260200182016040528015610fac578160200160208202803683370190505b50925060005b8481101561104757858582818110610fcc57610fcc613bd2565b9050602002016020810190610fe19190613842565b925061102283888461101d878c6001600160a01b0391821660009081526037602090815260408083209390941682526004909201909152205490565b6123df565b84828151811061103457611034613bd2565b6020908102919091010152600101610fb2565b5050509392505050565b60608167ffffffffffffffff81111561106c5761106c613bbc565b604051908082528060200260200182016040528015611095578160200160208202803683370190505b50905060005b8281101561111757603760008585848181106110b9576110b9613bd2565b90506020020160208101906110ce9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000206002015482828151811061110457611104613bd2565b602090810291909101015260010161109b565b5092915050565b6002600054036111705760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260009081556001600160a01b038316815260376020526040902033906111999082846124db565b6111a38183612777565b6111c057604051635ff7115760e11b815260040160405180910390fd5b5050600160005550565b6111d26127d8565b610cd8828261284c565b6111e4611f71565b806111ee81611e04565b336000908152603a60205260409020546001600160a01b03161561122757604051632fc6bfb160e21b81523360048201526024016108e6565b6001600160a01b0382166000908152603760205260409020610cd89033346128c0565b60d154600290610100900460ff1615801561126c575060d15460ff8083169116105b6112de5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805461ffff191660ff83161761010017905560365461130a906008906001600160a01b031661296f565b6036805473ffffffffffffffffffffffffffffffffffffffff1916905560d1805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b6113746127d8565b6108ef81612a20565b60006113bb838361138c612a55565b6001600160a01b038088166000908152603760209081526040808320938a1683526004909301905220546123df565b90505b92915050565b6002600054036114165760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b60026000558161142581611e04565b6001600160a01b0384166000908152603760205260409020339061144a9082856124db565b6001600160a01b038416600090815260376020526040902061146d9082856128c0565b50506001600055505050565b6114816127d8565b61148a81612ac7565b610cd8828261296f565b61149c6127d8565b6108ef81612b16565b60608167ffffffffffffffff8111156114c0576114c0613bbc565b6040519080825280602002602001820160405280156114e9578160200160208202803683370190505b50905060005b828110156111175761152184848381811061150c5761150c613bd2565b90506020020160208101906106249190613842565b82828151811061153357611533613bd2565b60209081029190910101526001016114ef565b8261155081611e04565b6001600160a01b0384166000908152603760205260409020336115738282611f28565b606d548411806115845750606e5484105b156115a257604051631b8454a360e21b815260040160405180910390fd5b6115ac60086119a2565b6040517fe5125a1d0000000000000000000000000000000000000000000000000000000081526001600160a01b0388811660048301526024820188905260448201879052919091169063e5125a1d906064015b600060405180830381600087803b15801561161957600080fd5b505af115801561162d573d6000803e3d6000fd5b50505050505050505050565b60026000540361168b5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b600260005582158061169d5750828114155b156116bb576040516376081a7b60e11b815260040160405180910390fd5b336000805b85811015611763578484828181106116da576116da613bd2565b90506020020135826116ec9190613c17565b915061175b6037600089898581811061170757611707613bd2565b905060200201602081019061171c9190613842565b6001600160a01b03166001600160a01b031681526020019081526020016000208487878581811061174f5761174f613bd2565b905060200201356124db565b6001016116c0565b5061176e8282612777565b61178b57604051635ff7115760e11b815260040160405180910390fd5b5050600160005550505050565b6117a06127d8565b6108ef81612b4b565b806117b381611e04565b6001600160a01b0382166000908152603760205260409020336117d68282611f28565b6117e060086119a2565b6039546040517fa7c2f1190000000000000000000000000000000000000000000000000000000081526001600160a01b038781166004830152602482019290925291169063a7c2f11990604401610be2565b600861183d81610881565b61187e868680806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250889250879150869050612b80565b505050505050565b6002600054036118d85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600055816118e781611e04565b81600003611921576040517f31d9f7d700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0383166000908152603760205260408120600281015433929061194c908690613c2a565b9050606c5481101561198a576040517fef0a995700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611995828487612fb1565b61176e83866104b06130b6565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f8111156119d9576119d9613b5d565b60ff1681526020810191909152604001600020546001600160a01b0316905080611a3157816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016108e69190613c3d565b919050565b6008611a4181610881565b8215611c015760005b83811015611bc657600060376000878785818110611a6a57611a6a613bd2565b9050602002016020810190611a7f9190613842565b6001600160a01b0390811682526020808301939093526040918201600090812060018101549092168152603a9093529120805473ffffffffffffffffffffffffffffffffffffffff1916905560028101549091508015611b5357611ae38282612058565b506001820154611aff906001600160a01b0316826104b06130b6565b611b535760018201548254604080518481524760208201526001600160a01b0393841693909216917f7dc5115a5aba081f5a174f56a3d02eea582824783322a4ac03f7bd388f444194910160405180910390a35b6000611b93888886818110611b6a57611b6a613bd2565b9050602002016020810190611b7f9190613842565b60018501546001600160a01b031688613116565b90508015611bb8576001830154611bb6906001600160a01b0316826104b06130b6565b505b836001019350505050611a4a565b507f4f257d3ba23679d338f1d94296086bba5724af341b7fa31aa0ff297bfcdc62d88484604051611bf8929190613c4b565b60405180910390a15b50505050565b60d154610100900460ff1615808015611c27575060d154600160ff909116105b80611c415750303b158015611c41575060d15460ff166001145b611cb35760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084016108e6565b60d1805460ff191660011790558015611cd65760d1805461ff0019166101001790555b611ce160088761296f565b611cea85612a20565b611cf560008561284c565b611cfe83612b16565b611d0782612b4b565b801561187e5760d1805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a1505050505050565b6000600260005403611da85760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016108e6565b6002600081905550611ded3384848080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b9050611df93382613296565b600160005592915050565b611e0e60086119a2565b604051635061f96960e11b81526001600160a01b038381166004830152919091169063a0c3f2d290602401602060405180830381865afa158015611e56573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611e7a9190613c99565b6108ef576040517f1fa18c8a0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b6000611efa8585858080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061324592505050565b6001600160a01b0383166000908152603760205260409020909150611f209086836128c0565b949350505050565b60018201546001600160a01b03828116911614610cd8576040517ff78cb7ae00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b34600003611fab576040517fdbf97bca00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b565b8282611fb98282611f28565b82856002016000828254611fcd9190613c17565b92505081905550611ff385858760020154868960030154611fee9190613c17565b6132e4565b6001600160a01b03808516600090815260058701602052604090819020429055865490519116907f9e71bc8eea02a63969f509818f2dafb9254532904319f9dbda79b67bd34a5f3d906120499086815260200190565b60405180910390a25050505050565b600061206883600201548361331f565b90508083600201600082825461207e9190613c2a565b90915550506001830154600284015460038501546120ae9286926001600160a01b0390911691611fee9086613335565b82546040518281526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f759060200160405180910390a292915050565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114612142576040519150601f19603f3d011682016040523d82523d6000602084013e612147565b606091505b5090949350505050565b61215f8660006104b06130b6565b6121bd576040805163338f030160e01b81526001600160a01b03881660048201526024810191909152600a60448201527f706f6f6c2061646d696e0000000000000000000000000000000000000000000060648201526084016108e6565b6121cb8360006104b06130b6565b612229576040805163338f030160e01b81526001600160a01b03851660048201526024810191909152600860448201527f747265617375727900000000000000000000000000000000000000000000000060648201526084016108e6565b606c5481101561224c57604051630a8d7fa760e21b815260040160405180910390fd5b846001600160a01b0316866001600160a01b031614158061227f5750826001600160a01b0316856001600160a01b031614155b156122b6576040517fdc1d04ff00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60408051600280825260608201835260009260208301908036833701905050905086816000815181106122eb576122eb613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050848160018151811061231f5761231f613bd2565b60200260200101906001600160a01b031690816001600160a01b0316815250506123488161334f565b1561238d576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b5061239860086119a2565b60405163f883afaf60e01b81526001600160a01b0387811660048301528681166024830152858116604483015260648201859052919091169063f883afaf906084016115ff565b6001600160a01b0380851660009081526002602090815260408083209387168352929052908120600381015484900361241a57549050611f20565b6001600160a01b03861660009081526003602081815260408084206001808452828620948701548652939092528320918201548392901561247f57805460018601549094506124699085613c2a565b85600201546124789190613cbb565b9250612487565b846001015493505b8154600090612497908690613c2a565b6124a19089613cbb565b9050670de0b6b3a76400006124b68286613c17565b6124c09190613cd2565b86546124cc9190613c17565b9b9a5050505050505050505050565b82826124e782826133ee565b82600003612521576040517ff5618d5a00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b0384166000908152600486016020526040902054831115612575576040517f34aa9a2800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600061258160086119a2565b8654604051635061f96960e11b81526001600160a01b03918216600482015291925082169063a0c3f2d290602401602060405180830381865afa1580156125cc573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125f09190613c99565b8015612683575085546040517f28bde1e10000000000000000000000000000000000000000000000000000000081526001600160a01b039182166004820152908216906328bde1e19060240160e060405180830381865afa158015612659573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061267d9190613cff565b60a00151155b80156126b657506038546001600160a01b038616600090815260058801602052604090205442916126b391613c17565b10155b156126ed576040517ff19f52bd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260048701602052604090205461272b908790879061271b908890613c2a565b878a60030154611fee9190613c2a565b85546040518581526001600160a01b03918216918716907f4d10bd049775c77bd7f255195afba5088028ecb3c7c277d393ccff7934f2f92c9060200160405180910390a3505050505050565b6000814710156127ce576040517f98c713c00000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152476024820152604481018390526064016108e6565b6113bb83836120f5565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314611fab576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108e6929190613dab565b61271081118061285b57508082115b1561287957604051631b8454a360e21b815260040160405180910390fd5b606d819055606e82905560408051838152602081018390527f677752f5bf9541b14288833909e5ec5a478103131c1ec08c4638943be5826c14910160405180910390a15050565b82826128cc82826133ee565b6001600160a01b038416600090815260048601602052604090205461290a90869086906128fa908790613c17565b868960030154611fee9190613c17565b6001600160a01b03808516600081815260058801602052604090819020429055875490519216917fe5541a6b6103d4fa7e021ed54fad39c66f27a76bd13d374cf6240ae6bd0bb72b906129609087815260200190565b60405180910390a35050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156129a5576129a5613b5d565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f8111156129f3576129f3613b5d565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b606c8190556040518181527f372bbdb8d72373b0012f84ee5a11671e5fb72b8bea902ebca93a19cb45d32be290602001611361565b6000612a6160086119a2565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015612a9e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190612ac29190613be8565b905090565b806001600160a01b03163b6000036108ef576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b03821660048201526024016108e6565b60388190556040518181527f4956b65267b8f1e642284bcb5037116c69a9c78d9ca576beeae0974737a4872a90602001611361565b60398190556040518181527f02be0b73b597f2c0f138aebee162b3b0e25d5b5a26854c15dcf79176e9a1c67890602001611361565b83518214612bc957807fae52c603227f64e4c6101dde593aa9790a16b3ac77546bd746d758511e9560a5858585604051612bbc93929190613e12565b60405180910390a2611c01565b6000806000806000885167ffffffffffffffff811115612beb57612beb613bbc565b604051908082528060200260200182016040528015612c14578160200160208202803683370190505b5090506000895167ffffffffffffffff811115612c3357612c33613bbc565b604051908082528060200260200182016040528015612c5c578160200160208202803683370190505b50905060008a5167ffffffffffffffff811115612c7b57612c7b613bbc565b604051908082528060200260200182016040528015612ca4578160200160208202803683370190505b50905060005b8b51811015612f17578b8181518110612cc557612cc5613bd2565b6020908102919091018101516001600160a01b038116600090815260038084526040808320603790955290912001549097506001600160a01b03881660009081526001602081815260408084208f855290915290912001549096508a9003612d6657868389806001019a5081518110612d4057612d40613bd2565b60200260200101906001600160a01b031690816001600160a01b03168152505050612f05565b60028101548a1115612d9457604080518082019091528681526020018a905260018101869055600281018a90555b600181015415612dde5760018101548c8c84818110612db557612db5613bd2565b90506020020135670de0b6b3a7640000612dcf9190613cbb565b612dd99190613cd2565b612de1565b60005b985088816000016000828254612df79190613c17565b9182905550905085612e098a85613c2a565b81518110612e1957612e19613bd2565b6020026020010181815250506040518060400160405280826000015481526020018b81525060016000896001600160a01b03166001600160a01b0316815260200190815260200160002060008c815260200190815260200160002060008201518160000155602082015181600101559050508581600101600001819055508060010160000154848984612eac9190613c2a565b81518110612ebc57612ebc613bd2565b6020908102919091010152868d612ed38a85613c2a565b81518110612ee357612ee3613bd2565b60200260200101906001600160a01b031690816001600160a01b031681525050505b80612f0f81613e75565b915050612caa565b508515612f6057858152858b51038b52877fee74f10cc50bf4b7e57fd36be7d46288795f3a9151dae97505b718b392ba14a382604051612f579190613e8e565b60405180910390a25b8a5115612fa457877f0e54e0485f70f0f63bc25889ddbf01ce1269ad6f07fdb2df573a0fbdb4d66f888c8585604051612f9b93929190613ea1565b60405180910390a25b5050505050505050505050565b8282612fbd8282611f28565b8460020154831115612fe257604051630a8d7fa760e21b815260040160405180910390fd5b6038546001600160a01b0385166000908152600587016020526040902054429161300b91613c17565b1115613043576040517f07b6105200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828560020160008282546130579190613c2a565b9250508190555061307885858760020154868960030154611fee9190613c2a565b84546040518481526001600160a01b03909116907f0f5bb82176feb1b5e747e28471aa92156a04d9f3ab9f45f28e2d704232b93f7590602001612049565b6000836001600160a01b0316838390604051600060405180830381858888f193505050503d8060008114613106576040519150601f19603f3d011682016040523d82523d6000602084013e61310b565b606091505b509095945050505050565b6001600160a01b0380841660009081526037602090815260408083209386168352600490930190529081205461314e858585846123df565b9150836001600160a01b0316856001600160a01b03167f0aa4d283470c904c551d18bb894d37e17674920f3261a7f854be501e25f421b78460405161319591815260200190565b60405180910390a36001600160a01b038086166000818152600260209081526040808320948916835293815283822082815592825260039052919091206131df9082868580613437565b60038181018590556001600160a01b03878116600081815260209384526040808220546001870155519081529188169290917faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad910160405180910390a350509392505050565b600080613250612a55565b905060005b8351811015610d655761328284828151811061327357613273613bd2565b60200260200101518684613116565b61328c9084613c17565b9250600101613255565b6132a08282612777565b610cd8576040517f3b97b7700000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108e6565b83546132fa906001600160a01b031684846134e2565b60038401556001600160a01b0390911660009081526004909201602052604090912055565b600081831061332e57816113bb565b5090919050565b60008183116133455760006113bb565b6113bb8284613c2a565b6000815160000361336257506000919050565b60005b60018351038110156133e557600181015b83518110156133dc5783818151811061339157613391613bd2565b60200260200101516001600160a01b03168483815181106133b4576133b4613bd2565b60200260200101516001600160a01b0316036133d4575060019392505050565b600101613376565b50600101613365565b50600092915050565b60018201546001600160a01b03808316911603610cd8576040517f9feb934700000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b828460030154101561344b57600284018190555b600061345b85600201548461331f565b9050600081866002015461346f9190613c2a565b905080156134d9576002860182905560018701548111156134bc576040517fa5ca437e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b808760010160000160008282546134d39190613c2a565b90915550505b50505050505050565b60006134ec612a55565b6001600160a01b0385166000908152600360205260409020600181015460028201549293509091831115613560576040518060400160405280613547886001600160a01b031660009081526037602052604090206003015490565b8152602090810185905281516001850155015160028301555b6001600160a01b038681166000818152600260209081526040808320948a1680845294825280832093835260378252808320948352600490940190529182205490916135ae898988856123df565b83549091508114613600578083556040518181526001600160a01b0389811691908b16907faa7c29611027fd4be148712bb54960253b7a7d5998c17769bfc424c2f5f185ad9060200160405180910390a35b61360d8584888a86613437565b845460018085019190915560038401879055850154841461367457886001600160a01b0316867f81faf50e2aaf52eaba2ab841071efb9f6f0850a3e7d008b1336e6001d3d4963c876001016000015460405161366b91815260200190565b60405180910390a35b505050505050505050565b60008083601f84011261369157600080fd5b50813567ffffffffffffffff8111156136a957600080fd5b6020830191508360208260051b85010111156136c457600080fd5b9250929050565b600080600080604085870312156136e157600080fd5b843567ffffffffffffffff808211156136f957600080fd5b6137058883890161367f565b9096509450602087013591508082111561371e57600080fd5b5061372b8782880161367f565b95989497509550505050565b600081518084526020808501945080840160005b838110156137675781518752958201959082019060010161374b565b509495945050505050565b6020815260006113bb6020830184613737565b6001600160a01b03811681146108ef57600080fd5b6000806000604084860312156137af57600080fd5b833567ffffffffffffffff8111156137c657600080fd5b6137d28682870161367f565b90945092505060208401356137e681613785565b809150509250925092565b6000806000806080858703121561380757600080fd5b843561381281613785565b9350602085013561382281613785565b9250604085013561383281613785565b9396929550929360600135925050565b60006020828403121561385457600080fd5b813561385f81613785565b9392505050565b6000806040838503121561387957600080fd5b823561388481613785565b946020939093013593505050565b6000806000604084860312156138a757600080fd5b83356138b281613785565b9250602084013567ffffffffffffffff8111156138ce57600080fd5b6138da8682870161367f565b9497909650939450505050565b600080602083850312156138fa57600080fd5b823567ffffffffffffffff81111561391157600080fd5b61391d8582860161367f565b90969095509350505050565b6000806040838503121561393c57600080fd5b50508035926020909101359150565b60006020828403121561395d57600080fd5b5035919050565b6000806040838503121561397757600080fd5b823561398281613785565b9150602083013561399281613785565b809150509250929050565b6000806000606084860312156139b257600080fd5b83356139bd81613785565b925060208401356139cd81613785565b929592945050506040919091013590565b803560108110611a3157600080fd5b60008060408385031215613a0057600080fd5b613982836139de565b600080600060608486031215613a1e57600080fd5b8335613a2981613785565b95602085013595506040909401359392505050565b600080600080600060608688031215613a5657600080fd5b853567ffffffffffffffff80821115613a6e57600080fd5b613a7a89838a0161367f565b90975095506020880135915080821115613a9357600080fd5b50613aa08882890161367f565b96999598509660400135949350505050565b600060208284031215613ac457600080fd5b6113bb826139de565b600080600060408486031215613ae257600080fd5b833567ffffffffffffffff811115613af957600080fd5b613b058682870161367f565b909790965060209590950135949350505050565b600080600080600060a08688031215613b3157600080fd5b8535613b3c81613785565b97602087013597506040870135966060810135965060800135945092505050565b634e487b7160e01b600052602160045260246000fd5b60108110613b8357613b83613b5d565b9052565b6001600160e01b03198416815260608101613ba56020830185613b73565b6001600160a01b0383166040830152949350505050565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b600060208284031215613bfa57600080fd5b5051919050565b634e487b7160e01b600052601160045260246000fd5b808201808211156113be576113be613c01565b818103818111156113be576113be613c01565b602081016113be8284613b73565b60208082528181018390526000908460408401835b86811015613c8e578235613c7381613785565b6001600160a01b031682529183019190830190600101613c60565b509695505050505050565b600060208284031215613cab57600080fd5b8151801515811461385f57600080fd5b80820281158282048414176113be576113be613c01565b600082613cef57634e487b7160e01b600052601260045260246000fd5b500490565b8051611a3181613785565b600060e08284031215613d1157600080fd5b60405160e0810181811067ffffffffffffffff82111715613d4257634e487b7160e01b600052604160045260246000fd5b604052613d4e83613cf4565b8152613d5c60208401613cf4565b6020820152613d6d60408401613cf4565b6040820152613d7e60608401613cf4565b60608201526080830151608082015260a083015160a082015260c083015160c08201528091505092915050565b6001600160e01b03198316815260408101600b8310613dcc57613dcc613b5d565b8260208301529392505050565b600081518084526020808501945080840160005b838110156137675781516001600160a01b031687529582019590820190600101613ded565b604081526000613e256040830186613dd9565b82810360208401528381527f07ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff841115613e5d57600080fd5b8360051b808660208401370160200195945050505050565b600060018201613e8757613e87613c01565b5060010190565b6020815260006113bb6020830184613dd9565b606081526000613eb46060830186613dd9565b8281036020840152613ec68186613737565b90508281036040840152613eda8185613737565b969550505050505056fea26469706673582212209c26c9b27087c4ace8fe06bea64a20c6bdad77f3bf4c4bee053bd164543bfbec64736f6c6343000815003300000000000000000000000000 + ├─ [3277977] → new Staking@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + │ ├─ emit Initialized(version: 255) + │ └─ ← 16154 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(5) [staticcall] + │ └─ ← ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758] + ├─ [0] VM::load(ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [36277] ronin-mainnet.Staking::upgradeToAndCall(Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + │ ├─ [24636] Staking::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], Staking, StakingLogic, 0x, 2)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, StakingLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(0) [staticcall] + │ └─ ← ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6] + ├─ [0] GeneralConfig::getContractName(4) [staticcall] + │ └─ ← SlashIndicator + ├─ [0] GeneralConfig::getContractFileName(4) [staticcall] + │ └─ ← SlashIndicator.sol:SlashIndicator + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000003 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(SlashIndicator.sol:SlashIndicator) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000390160806040523480156200001157600080fd5b506200001c62000022565b620000e7565b61011354610100900460ff1615620000905760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b6101135460ff9081161015620000e557610113805460ff191660ff9081179091556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b61380a80620000f76000396000f3fe608060405234801561001057600080fd5b506004361061020b5760003560e01c806399103f7b1161012a578063d1cf4343116100bd578063df4b6ee01161008c578063f1001e7811610071578063f1001e78146104a9578063f562b3c4146104c9578063fd422cd0146104d257600080fd5b8063df4b6ee01461047e578063e9bb1666146104a257600080fd5b8063d1cf43431461041c578063d1f992f71461042f578063d3dd2bdf14610442578063de981f1b1461046b57600080fd5b8063c6391fa2116100f9578063c6391fa2146103d2578063ccbb72ed146103e3578063cf39d13c146103f6578063d1737e271461040957600080fd5b806399103f7b1461038e578063a345ecb2146103a1578063c008ce39146103b4578063c2e524dc146103c757600080fd5b80633101cfcb116101a25780637680850c116101715780637680850c1461033a5780637c2b55a01461034d578063853af1b714610368578063865e6fd31461037b57600080fd5b80633101cfcb146102e75780633d48fd7d146102fa578063487e00ea1461030b57806362ffe6cb1461032757600080fd5b80631a697341116101de5780631a6973411461028b5780631e90b2a01461029e57806329b6eca9146102b157806329ddc3c0146102c457600080fd5b806307c2d2f614610210578063082e7420146102255780630e1512ac1461024b5780631079402a1461025e575b600080fd5b61022361021e366004612a4b565b6104e5565b005b610238610233366004612aa2565b6105f3565b6040519081526020015b60405180910390f35b610223610259366004612abf565b61066a565b606d54606e54606f546070545b604080519485526020850193909352918301526060820152608001610242565b610223610299366004612aa2565b610684565b6102236102ac366004612b33565b610993565b6102236102bf366004612aa2565b610ba0565b6102d76102d2366004612bb6565b610d14565b6040519015158152602001610242565b6102236102f5366004612aa2565b610d43565b60a55460a65460a75460a85461026b565b601d54601e545b60408051928352602083019190915201610242565b610238610335366004612bb6565b610e37565b610223610348366004612be2565b610e60565b60675b6040516001600160a01b039091168152602001610242565b610223610376366004612c2e565b611177565b610223610389366004612c5f565b61118d565b61022361039c366004612cb8565b6111a8565b6102236103af366004612c2e565b61135a565b6102236103c2366004612d76565b61136c565b603854603954610312565b60dd5460de5460df5460e05461026b565b6102236103f1366004612abf565b61141a565b610223610404366004612dab565b61142e565b610223610417366004612abf565b611446565b61022361042a366004612dd7565b61145a565b61022361043d366004612aa2565b6117da565b610238610450366004612aa2565b6001600160a01b0316600090815260dc602052604090205490565b610350610479366004612e96565b611c78565b60015460025460035460408051938452602084019290925290820152606001610242565b6069610350565b6104bc6104b7366004612a4b565b611d0c565b6040516102429190612eec565b61023860a35481565b6102236104e0366004612aa2565b611dd7565b60086104f081612161565b60008267ffffffffffffffff81111561050b5761050b612eff565b604051908082528060200260200182016040528015610534578160200160208202803683370190505b50905060005b838110156105b157600085858381811061055657610556612f15565b905060200201602081019061056b9190612aa2565b6001600160a01b038116600090815260dc6020526040812055835190915083908390811061059b5761059b612f15565b600060209182029290920101525060010161053a565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c234808484836040516105e593929190612f69565b60405180910390a150505050565b6000610664826106036008611c78565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610640573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103359190612f99565b92915050565b6106726121c6565b61067e84848484612222565b50505050565b61068c6121c6565b6000610698600a611c78565b6040517fdb6693a20000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063db6693a29060240160a060405180830381865afa1580156106f9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061071d919061303a565b905060006107c061072e600b611c78565b60408085015190517f988ef53c0000000000000000000000000000000000000000000000000000000081526001600160a01b03918216600482015291169063988ef53c90602401602060405180830381865afa158015610792573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107b69190612f99565b83608001516122cd565b905060006107ce6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610810573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906108349190612f99565b60385490915061084484436130d8565b11158061087457506001600160a01b038516600090815260376020908152604080832084845290915290205460ff165b156108ab576040517f5c61141600000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600081815260376020908152604080832085845290915290819020805460ff19166001179055517f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d99061090c906004908590613101565b60405180910390a2603954604051630bde081360e21b81526001600160a01b0387811660048301526000602483018190526044830193909352606482019290925290831690632f78204c90608401600060405180830381600087803b15801561097457600080fd5b505af1158015610988573d6000803e3d6000fd5b505050505050505050565b61099b6121c6565b600084846040516109ad92919061311f565b60405180910390209050600083836040516109c992919061311f565b604080519182900390912060008481526004602052919091205490915060ff1680610a02575060008181526004602052604090205460ff165b15610a205760405163f27b8ec960e01b815260040160405180910390fd5b610a2d87878787876122e4565b15610b97576000610a3e6008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015610a80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610aa49190612f99565b6000858152600460205260408082208054600160ff19918216811790925587845292829020805490931617909155519091506001600160a01b038a16907f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d990610b11906003908590613101565b60405180910390a260025460018054604051630bde081360e21b81526001600160a01b038d8116600483015260248201949094526044810191909152606481019190915290831690632f78204c90608401600060405180830381600087803b158015610b7c57600080fd5b505af1158015610b90573d6000803e3d6000fd5b5050505050505b50505050505050565b61011354600290610100900460ff16158015610bc457506101135460ff8083169116105b610c2c5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b610113805461ffff191660ff831617610100179055600054610c59906008906001600160a01b03166123d5565b606c54610c71906005906001600160a01b03166123d5565b610c7c6004836123d5565b603554610c9490600a906001600160a01b03166123d5565b6000805473ffffffffffffffffffffffffffffffffffffffff19908116909155606c8054821690556035805482169055603680549091169055610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a15050565b6001600160a01b038216600090815260db6020908152604080832084845290915281205460ff165b9392505050565b61011354600390610100900460ff16158015610d6757506101135460ff8083169116105b610dca5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805461ffff191660ff831617610100179055610dea600f836123d5565b610df8600154600254612486565b610113805461ff001916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb384740249890602001610d08565b6001600160a01b038216600090815260a460209081526040808320848452909152812054610d3c565b6008610e6b81612161565b60003390506000816001600160a01b031663297a8fca6040518163ffffffff1660e01b8152600401602060405180830381865afa158015610eb0573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610ed49190612f99565b90506000826001600160a01b0316634de2b73588886040518363ffffffff1660e01b8152600401610f0692919061312f565b600060405180830381865afa158015610f23573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610f4b9190810190613177565b90506000610f596005611c78565b6001600160a01b031663ba303755898986436040518563ffffffff1660e01b8152600401610f8a9493929190613214565b600060405180830381865afa158015610fa7573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052610fcf9190810190613177565b905060008767ffffffffffffffff811115610fec57610fec612eff565b604051908082528060200260200182016040528015611015578160200160208202803683370190505b50905060005b888110156111305760008a8a8381811061103757611037612f15565b905060200201602081019061104c9190612aa2565b9050600061105a828b610e37565b9050600086848151811061107057611070612f15565b60200260200101519050600086858151811061108e5761108e612f15565b60200260200101519050600082806110a35750815b6110b8576110b360dd54856124c6565b6110bb565b60005b6001600160a01b038616600090815260dc602052604090205460de549192506110e59183906124e0565b6001600160a01b038616600090815260dc60205260409020819055875188908890811061111457611114612f15565b602002602001018181525050856001019550505050505061101b565b507f8c02b2ccee964dc50649a48bd0a0446f0f9e88ecdb72d099f4ace07c39c2348089898360405161116493929190612f69565b60405180910390a1505050505050505050565b61117f6121c6565b61118982826124fd565b5050565b6111956121c6565b61119e8161253d565b61118982826123d5565b61011354610100900460ff16158080156111ca575061011354600160ff909116105b806111e55750303b1580156111e557506101135460ff166001145b6112485760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610c23565b610113805460ff19166001179055801561126d57610113805461ff0019166101001790555b61127860088b6123d5565b61128360058a6123d5565b61128e6004886123d5565b611299600a896123d5565b6112b286356020880135604089013560608a0135612222565b6112c1853560208701356124fd565b6112d584356020860135604087013561258c565b6112ee83356020850135604086013560608701356125e1565b6113078235602084013560408501356060860135612686565b801561134e57610113805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050505050505050565b6113626121c6565b6111898282612486565b600861137781612161565b826001036113c857836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96005846040516113bb929190613101565b60405180910390a261067e565b8260020361067e57836001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960068460405161140c929190613101565b60405180910390a250505050565b6114226121c6565b61067e84848484612686565b6114366121c6565b61144183838361258c565b505050565b61144e6121c6565b61067e848484846125e1565b61146333612755565b600003611493576000356001600160e01b0319166003604051620f948f60ea1b8152600401610c2392919061323b565b600061149f600f611c78565b6040517ff46609400000000000000000000000000000000000000000000000000000000081526001600160a01b038a8116600483015291925060009183169063f466094090602401600060405180830381865afa158015611504573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261152c91908101906132fa565b60a0015190508080519060200120888860405161154a92919061311f565b604051809103902014611597576040517f053265f10000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b6040516bffffffffffffffffffffffff1960608b901b1660208201526034810187905260009060540160408051601f1981840301815291815281516020928301206000818152601f90935291205490915060ff16156116095760405163f27b8ec960e01b815260040160405180910390fd5b61167f89898080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250506040805180820182528c935091508a90600290839083908082843760009201919091525061167191508a9050613413565b61167a896134eb565b6127e6565b1561134e576000818152601f60205260408120805460ff191660011790556116a76008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156116e9573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061170d9190612f99565b90508b6001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d960088360405161174b929190613101565b60405180910390a2601e54601d54604051630bde081360e21b81526001600160a01b038f81166004830152602482019390935260448101919091526001606482015290831690632f78204c90608401600060405180830381600087803b1580156117b457600080fd5b505af11580156117c8573d6000803e3d6000fd5b50505050505050505050505050505050565b60006117e66008611c78565b6040517fa0c3f2d20000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301529192509082169063a0c3f2d290602401602060405180830381865afa158015611849573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061186d9190613544565b61189a576000356001600160e01b0319166008604051620f948f60ea1b8152600401610c2392919061323b565b6040517f04d971ab0000000000000000000000000000000000000000000000000000000081526001600160a01b0383811660048301523360248301528216906304d971ab90604401602060405180830381865afa1580156118ff573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119239190613544565b611950576000356001600160e01b0319166004604051620f948f60ea1b8152600401610c2392919061323b565b6040517f96585fc20000000000000000000000000000000000000000000000000000000081526001600160a01b03838116600483015260009182918416906396585fc290602401606060405180830381865afa1580156119b4573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119d8919061355f565b925050915081611a14576040517f6cd31b5900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6000836001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611a54573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a789190612f99565b6001600160a01b038616600090815260db6020908152604080832084845290915290205490915060ff1615611ad9576040517f7674d6a900000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6001600160a01b038516600090815260dc602052604081205460df54909190611b029085613594565b905080821015611b3e576040517f8c5cb26e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040517f15b5ebde0000000000000000000000000000000000000000000000000000000081526001600160a01b038881166004830152602482018590528716906315b5ebde90604401600060405180830381600087803b158015611ba157600080fd5b505af1158015611bb5573d6000803e3d6000fd5b505050506001600160a01b038716600090815260dc602052604081208054839290611be19084906130d8565b90915550506001600160a01b038716600090815260a4602090815260408083208684529091528120556001600160a01b038716600081815260db60209081526040808320878452825291829020805460ff1916600117905581518681529081018490527f7ff9f7032d565c7e8919332964b2faa33c320b53604a65d9dd1f8112e12cd39d910160405180910390a250505050505050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115611caf57611caf6130eb565b60ff1681526020810191909152604001600020546001600160a01b0316905080611d0757816040517f812281be000000000000000000000000000000000000000000000000000000008152600401610c2391906135bf565b919050565b60608167ffffffffffffffff811115611d2757611d27612eff565b604051908082528060200260200182016040528015611d50578160200160208202803683370190505b50905060005b8151811015611dd05760dc6000858584818110611d7557611d75612f15565b9050602002016020810190611d8a9190612aa2565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110611dbd57611dbd612f15565b6020908102919091010152600101611d56565b5092915050565b60a3544311611e12576040517f557fd09100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b4360a355334114611e46576000356001600160e01b0319166002604051620f948f60ea1b8152600401610c2392919061323b565b611e4f8161286f565b1561215e576000611e606008611c78565b90506000816001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa158015611ea2573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611ec69190612f99565b6001600160a01b038416600090815260a460209081526040808320848452909152812080546001019081905560a85492935091611f049043906129b7565b905060a6548203611fcd57846001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600285604051611f4b929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0387811660048301526024820184905260448201929092526000606482015290851690632f78204c90608401600060405180830381600087803b158015611fb057600080fd5b505af1158015611fc4573d6000803e3d6000fd5b50505050612159565b60a5548203612159576000611fe28685610d14565b9050806120a257856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d9600186604051612025929190613101565b60405180910390a2604051630bde081360e21b81526001600160a01b038781166004830152600060248301819052604483018190526064830152861690632f78204c90608401600060405180830381600087803b15801561208557600080fd5b505af1158015612099573d6000803e3d6000fd5b50505050612157565b856001600160a01b03167f607adba66cff84b627e3537d1c17d088a98556bccd0536a2f3590c56329023d96007866040516120de929190613101565b60405180910390a260a754604051630bde081360e21b81526001600160a01b0388811660048301526024820185905260448201929092526001606482015290861690632f78204c90608401600060405180830381600087803b15801561214357600080fd5b505af115801561134e573d6000803e3d6000fd5b505b505050505b50565b61216a81611c78565b6001600160a01b0316336001600160a01b03161461215e576000356001600160e01b03191681336040517f8383e634000000000000000000000000000000000000000000000000000000008152600401610c23939291906135cd565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314612220576000356001600160e01b0319166001604051620f948f60ea1b8152600401610c2392919061323b565b565b82841180612231575061271084115b8061223d575061271083115b15612274576040517f397c357e00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b606d849055606e839055606f82905560708190556040805185815260208101859052908101839052606081018290527fd24c671da2227c139fe1a5b34de15e5a67bef9b46e912916b9e0d025d51b3e3b906080016105e5565b6000818310156122dd5781610d3c565b5090919050565b6040516000906067906001908390612308908a908a908a908a908a9060240161362b565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7fc3567700000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b602083016020828483895afa61238257600094505b503d61238d57600093505b836123c4576040517f0fc2632100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5115159a9950505050505050505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f81111561240b5761240b6130eb565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115612459576124596130eb565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b601d829055601e81905560408051838152602081018390527f381ec200df2ed0875638486318f9f8a84e3550bdc686bf1400c9371a18d087f09101610d08565b60008183116124d6576000610d3c565b610d3c82846130d8565b60006124f56124ef848661366d565b836129d2565b949350505050565b6038829055603981905560408051838152602081018390527fbda9ec2980d7468ba6a9f363696315affca9f9770016396bdea2ac39c3e5d61a9101610d08565b806001600160a01b03163b60000361215e576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610c23565b60018390556002829055600381905560408051848152602081018490529081018290527f913da102149f952dde560cef3349db8e8002e9d580c41a7551d6d45329f4306b9060600160405180910390a1505050565b60a65460a554111561262d576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610c23565b60a584905560a683905560a782905560a88190556040805185815260208101859052908101839052606081018290527f442862e6143ad95854e7c13ff4947ec6e43bc87160e3b193e7c1abaf6e3aaa98906080016105e5565b828411156126c0576040517f112af4d100000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6127108111156126fc576040517fe0b2228c00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60dd84905560de83905560df82905560e08190556040805185815260208101859052908101839052606081018290527fe1f9c6c73554b5fa140eead3cfd4ec3e6d4824f3ed26fb25e38376f65b95470b906080016105e5565b6000612761600a611c78565b6040517fd78392f80000000000000000000000000000000000000000000000000000000081526001600160a01b038481166004830152919091169063d78392f890602401602060405180830381865afa1580156127c2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106649190612f99565b604051600090606990600190839061280a908a908a908a908a908a906024016136f1565b60408051601f198184030181529190526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f7b47d06b00000000000000000000000000000000000000000000000000000000179052805190915061236d6129e1565b6000336001600160a01b03831614801590612914575061288f6008611c78565b6040517f65244ece0000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015291909116906365244ece90602401602060405180830381865afa1580156128f0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129149190613544565b801561066457506129256005611c78565b6040517f0fbeb37f0000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301524360248301529190911690630fbeb37f90604401602060405180830381865afa15801561298c573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906129b09190613544565b1592915050565b6000816000036129c8576000610d3c565b610d3c828461366d565b60008183106122dd5781610d3c565b60405180602001604052806001906020820280368337509192915050565b60008083601f840112612a1157600080fd5b50813567ffffffffffffffff811115612a2957600080fd5b6020830191508360208260051b8501011115612a4457600080fd5b9250929050565b60008060208385031215612a5e57600080fd5b823567ffffffffffffffff811115612a7557600080fd5b612a81858286016129ff565b90969095509350505050565b6001600160a01b038116811461215e57600080fd5b600060208284031215612ab457600080fd5b8135610d3c81612a8d565b60008060008060808587031215612ad557600080fd5b5050823594602084013594506040840135936060013592509050565b60008083601f840112612b0357600080fd5b50813567ffffffffffffffff811115612b1b57600080fd5b602083019150836020828501011115612a4457600080fd5b600080600080600060608688031215612b4b57600080fd5b8535612b5681612a8d565b9450602086013567ffffffffffffffff80821115612b7357600080fd5b612b7f89838a01612af1565b90965094506040880135915080821115612b9857600080fd5b50612ba588828901612af1565b969995985093965092949392505050565b60008060408385031215612bc957600080fd5b8235612bd481612a8d565b946020939093013593505050565b600080600060408486031215612bf757600080fd5b833567ffffffffffffffff811115612c0e57600080fd5b612c1a868287016129ff565b909790965060209590950135949350505050565b60008060408385031215612c4157600080fd5b50508035926020909101359150565b803560108110611d0757600080fd5b60008060408385031215612c7257600080fd5b612c7b83612c50565b91506020830135612c8b81612a8d565b809150509250929050565b806080810183101561066457600080fd5b806040810183101561066457600080fd5b60008060008060008060008060006102a08a8c031215612cd757600080fd5b8935612ce281612a8d565b985060208a0135612cf281612a8d565b975060408a0135612d0281612a8d565b965060608a0135612d1281612a8d565b9550612d218b60808c01612c96565b9450612d318b6101008c01612ca7565b93506101a08a018b811115612d4557600080fd5b6101408b019350612d568c82612c96565b925050612d678b6102208c01612c96565b90509295985092959850929598565b600080600060608486031215612d8b57600080fd5b8335612d9681612a8d565b95602085013595506040909401359392505050565b600080600060608486031215612dc057600080fd5b505081359360208301359350604090920135919050565b600080600080600080600060e0888a031215612df257600080fd5b8735612dfd81612a8d565b9650602088013567ffffffffffffffff80821115612e1a57600080fd5b612e268b838c01612af1565b909850965060408a01359550869150612e428b60608c01612ca7565b945060a08a0135915080821115612e5857600080fd5b612e648b838c01612ca7565b935060c08a0135915080821115612e7a57600080fd5b50612e878a828b01612ca7565b91505092959891949750929550565b600060208284031215612ea857600080fd5b610d3c82612c50565b600081518084526020808501945080840160005b83811015612ee157815187529582019590820190600101612ec5565b509495945050505050565b602081526000610d3c6020830184612eb1565b634e487b7160e01b600052604160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b8183526000602080850194508260005b85811015612ee1578135612f4e81612a8d565b6001600160a01b031687529582019590820190600101612f3b565b604081526000612f7d604083018587612f2b565b8281036020840152612f8f8185612eb1565b9695505050505050565b600060208284031215612fab57600080fd5b5051919050565b60405160c0810167ffffffffffffffff81118282101715612fd557612fd5612eff565b60405290565b6040805190810167ffffffffffffffff81118282101715612fd557612fd5612eff565b604051601f8201601f1916810167ffffffffffffffff8111828210171561302757613027612eff565b604052919050565b8051611d0781612a8d565b600060a0828403121561304c57600080fd5b60405160a0810181811067ffffffffffffffff8211171561306f5761306f612eff565b604052825161307d81612a8d565b8152602083015161308d81612a8d565b602082015260408301516130a081612a8d565b6040820152606083810151908201526080928301519281019290925250919050565b634e487b7160e01b600052601160045260246000fd5b81810381811115610664576106646130c2565b634e487b7160e01b600052602160045260246000fd5b6040810160098410613115576131156130eb565b9281526020015290565b8183823760009101908152919050565b6020815260006124f5602083018486612f2b565b600067ffffffffffffffff82111561315d5761315d612eff565b5060051b60200190565b80518015158114611d0757600080fd5b6000602080838503121561318a57600080fd5b825167ffffffffffffffff8111156131a157600080fd5b8301601f810185136131b257600080fd5b80516131c56131c082613143565b612ffe565b81815260059190911b820183019083810190878311156131e457600080fd5b928401925b82841015613209576131fa84613167565b825292840192908401906131e9565b979650505050505050565b606081526000613228606083018688612f2b565b6020830194909452506040015292915050565b6001600160e01b03198316815260408101600b831061325c5761325c6130eb565b8260208301529392505050565b600067ffffffffffffffff82111561328357613283612eff565b50601f01601f191660200190565b60005b838110156132ac578181015183820152602001613294565b50506000910152565b600082601f8301126132c657600080fd5b81516132d46131c082613269565b8181528460208386010111156132e957600080fd5b6124f5826020830160208701613291565b60006020828403121561330c57600080fd5b815167ffffffffffffffff8082111561332457600080fd5b9083019060c0828603121561333857600080fd5b613340612fb2565b825161334b81612a8d565b8152602083015161335b81612a8d565b6020820152604083015161336e81612a8d565b604082015261337f6060840161302f565b60608201526133906080840161302f565b608082015260a0830151828111156133a757600080fd5b6133b3878286016132b5565b60a08301525095945050505050565b600082601f8301126133d357600080fd5b81356133e16131c082613269565b8181528460208386010111156133f657600080fd5b816020850160208301376000918101602001919091529392505050565b600061341d612fdb565b80604084013681111561342f57600080fd5b845b818110156134e157803567ffffffffffffffff808211156134525760008081fd5b9087019036601f8301126134665760008081fd5b813560206134766131c083613143565b82815260059290921b840181019181810190368411156134965760008081fd5b8286015b848110156134ce578035868111156134b25760008081fd5b6134c03686838b01016133c2565b84525091830191830161349a565b5089525090960195505050602001613431565b5090949350505050565b60006134f5612fdb565b80604084013681111561350757600080fd5b845b818110156134e157803567ffffffffffffffff8111156135295760008081fd5b613535368289016133c2565b85525060209384019301613509565b60006020828403121561355657600080fd5b610d3c82613167565b60008060006060848603121561357457600080fd5b61357d84613167565b925060208401519150604084015190509250925092565b8082028115828204841417610664576106646130c2565b601081106135bb576135bb6130eb565b9052565b6020810161066482846135ab565b6001600160e01b031984168152606081016135eb60208301856135ab565b6001600160a01b0383166040830152949350505050565b81835281816020850137506000828201602090810191909152601f909101601f19169091010190565b6001600160a01b038616815260606020820152600061364e606083018688613602565b8281036040840152613661818587613602565b98975050505050505050565b80820180821115610664576106646130c2565b60008151808452613698816020860160208601613291565b601f01601f19169290920160200192915050565b600082604081018360005b60028110156136e65783830387526136d0838351613680565b60209788019790935091909101906001016136b7565b509095945050505050565b60c08152600061370460c0830188613680565b60208781850152604084018760005b600281101561373057815183529183019190830190600101613713565b505050838203608085015281604081018760005b60028110156137b1578583038452815180518085529086019086850190600581901b8601880160005b8281101561379b57601f19888303018452613789828651613680565b948a0194938a0193915060010161376d565b5096880196955050509185019150600101613744565b505085810360a08701526137c581886136ac565b9b9a505050505050505050505056fea26469706673582212203dbb57dc8e95a92b94b022dfe41ffd6257773156df8af8a6f5401ce4ee74766764736f6c6343000815003300000000000000000000000000000000000000000000000000000000000000 + ├─ [2895930] → new SlashIndicator@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + │ ├─ emit Initialized(version: 255) + │ └─ ← 14346 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(4) [staticcall] + │ └─ ← ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3] + ├─ [0] VM::load(ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [78265] ronin-mainnet.SlashIndicator::upgradeToAndCall(SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], 0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6)  + │ ├─ emit Upgraded(param0: SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA]) + │ ├─ [66548] SlashIndicator::initializeV2(ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ │ ├─ emit ContractUpdated(contractType: 4, addr: ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) + │ │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], SlashIndicator, SlashIndicatorLogic, 0x, 3)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, SlashIndicatorLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(6) [staticcall] + │ └─ ← Profile + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(6) [staticcall] + │ └─ ← ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035] + ├─ [0] ronin-mainnet.SlashIndicator::initializeV3(ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035])  + │ ├─ [0] SlashIndicator::initializeV3(ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 15, addr: ronin-mainnet.Profile: [0x840EBf1CA767CB690029E91856A357a43B85d035]) + │ │ ├─ emit FastFinalitySlashingConfigsUpdated(slashFastFinalityAmount: 250000000000000000000000 [2.5e23], fastFinalityJailUntilBlock: 115792089237316195423570985008687907853269984665640564039457584007913129639935 [1.157e77]) + │ │ ├─ emit Initialized(version: 3) + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(11) [staticcall] + │ └─ ← RoninTrustedOrganization + ├─ [0] GeneralConfig::getContractFileName(11) [staticcall] + │ └─ ← RoninTrustedOrganization.sol:RoninTrustedOrganization + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000004 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(RoninTrustedOrganization.sol:RoninTrustedOrganization) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000206b608060405234801561001057600080fd5b5061204b806100206000396000f3fe608060405234801561001057600080fd5b50600436106101825760003560e01c806396c82e57116100d8578063cc7e6b3b1161008c578063db6693a211610066578063db6693a21461035a578063e75235b81461037a578063f09267c21461038557600080fd5b8063cc7e6b3b146102fb578063d78392f81461030e578063dafae4081461033757600080fd5b8063b505a07c116100bd578063b505a07c146102b8578063b7f67e97146102cb578063b9c36209146102d357600080fd5b806396c82e571461029d578063a85c7d6e146102a557600080fd5b8063562419111161013a5780637c37103c116101145780637c37103c1461026f5780637de5dedd14610282578063903bb3c51461028a57600080fd5b80635624191114610220578063691845a914610249578063708236251461025c57600080fd5b8063150740051161016b57806315074005146101c257806341feed1c146101d7578063520fce621461020057600080fd5b80630e777c06146101875780630ed285df146101ad575b600080fd5b61019a610195366004611aef565b610398565b6040519081526020015b60405180910390f35b6101c06101bb366004611ba9565b610404565b005b6101ca61041a565b6040516101a49190611beb565b61019a6101e5366004611c8f565b6001600160a01b031660009081526005602052604090205490565b61021361020e366004611aef565b610606565b6040516101a49190611caa565b61019a61022e366004611c8f565b6001600160a01b031660009081526007602052604090205490565b61019a610257366004611aef565b6106ca565b61021361026a366004611aef565b61072f565b6101c061027d366004611ce2565b6107f3565b61019a61094a565b61019a610298366004611aef565b610987565b60035461019a565b6101c06102b3366004611aef565b6109ec565b6101c06102c6366004611ba9565b610a96565b60095461019a565b6102e66102e1366004611d33565b610b35565b604080519283526020830191909152016101a4565b610213610309366004611aef565b610b56565b61019a61031c366004611c8f565b6001600160a01b031660009081526006602052604090205490565b61034a610345366004611d55565b610c1a565b60405190151581526020016101a4565b61036d610368366004611c8f565b610c41565b6040516101a49190611d6e565b6001546002546102e6565b61036d610393366004611d55565b610cf9565b6000805b828110156103fd57600760008585848181106103ba576103ba611dbc565b90506020020160208101906103cf9190611c8f565b6001600160a01b031681526020810191909152604001600020546103f39083611de8565b915060010161039c565b5092915050565b61040c610dff565b6104168282610e75565b5050565b60095460609067ffffffffffffffff81111561043857610438611dfb565b60405190808252806020026020018201604052801561049157816020015b6040805160a0810182526000808252602080830182905292820181905260608201819052608082015282526000199092019101816104565790505b5090506000805b825181101561060157600981815481106104b4576104b4611dbc565b9060005260206000200160009054906101000a90046001600160a01b03169150818382815181106104e7576104e7611dbc565b60209081029190910101516001600160a01b039091169052600a80548290811061051357610513611dbc565b9060005260206000200160009054906101000a90046001600160a01b031683828151811061054357610543611dbc565b6020026020010151602001906001600160a01b031690816001600160a01b031681525050600b818154811061057a5761057a611dbc565b9060005260206000200160009054906101000a90046001600160a01b03168382815181106105aa576105aa611dbc565b6020908102919091018101516001600160a01b0392831660409182015291841660009081526005909152205483518490839081106105ea576105ea611dbc565b602090810291909101015160600152600101610498565b505090565b60608167ffffffffffffffff81111561062157610621611dfb565b60405190808252806020026020018201604052801561064a578160200160208202803683370190505b50905060005b81518110156103fd576005600085858481811061066f5761066f611dbc565b90506020020160208101906106849190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106106b7576106b7611dbc565b6020908102919091010152600101610650565b6000805b828110156103fd57600560008585848181106106ec576106ec611dbc565b90506020020160208101906107019190611c8f565b6001600160a01b031681526020810191909152604001600020546107259083611de8565b91506001016106ce565b60608167ffffffffffffffff81111561074a5761074a611dfb565b604051908082528060200260200182016040528015610773578160200160208202803683370190505b50905060005b81518110156103fd576007600085858481811061079857610798611dbc565b90506020020160208101906107ad9190611c8f565b6001600160a01b03166001600160a01b03168152602001908152602001600020548282815181106107e0576107e0611dbc565b6020908102919091010152600101610779565b600054610100900460ff16158080156108135750600054600160ff909116105b8061082d5750303b15801561082d575060005460ff166001145b6108be576040517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201527f647920696e697469616c697a656400000000000000000000000000000000000060648201526084015b60405180910390fd5b6000805460ff1916600117905580156108e1576000805461ff0019166101001790555b83156108f1576108f18585610e75565b6108fb8383610eea565b50508015610943576000805461ff0019169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b5050505050565b600060025460016002546003546001546109649190611e11565b61096e9190611de8565b6109789190611e28565b6109829190611e3b565b905090565b6000805b828110156103fd57600660008585848181106109a9576109a9611dbc565b90506020020160208101906109be9190611c8f565b6001600160a01b031681526020810191909152604001600020546109e29083611de8565b915060010161098b565b6109f4610dff565b6000819003610a16576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610a5857610a50838383818110610a3657610a36611dbc565b9050602002016020810190610a4b9190611c8f565b610f99565b600101610a19565b507f121945697ac30ee0fc67821492cb685c65f0ea4d7f1b710fde44d6e2237f43a78282604051610a8a929190611e5d565b60405180910390a15050565b610a9e610dff565b6000819003610ac0576040516316ee9d3b60e11b815260040160405180910390fd5b60005b81811015610b0357610afb838383818110610ae057610ae0611dbc565b905060a00201803603810190610af69190611ea9565b611308565b600101610ac3565b507fe887c8106c09d1770c0ef0bf8ca62c54766f18b07506801865501783376cbeda8282604051610a8a929190611f3a565b600080610b40610dff565b610b4a8484610eea565b915091505b9250929050565b60608167ffffffffffffffff811115610b7157610b71611dfb565b604051908082528060200260200182016040528015610b9a578160200160208202803683370190505b50905060005b81518110156103fd5760066000858584818110610bbf57610bbf611dbc565b9050602002016020810190610bd49190611c8f565b6001600160a01b03166001600160a01b0316815260200190815260200160002054828281518110610c0757610c07611dbc565b6020908102919091010152600101610ba0565b6000600354600154610c2c9190611e11565b600254610c399084611e11565b101592915050565b6040805160a0810182526000808252602082018190529181018290526060810182905260808101829052905b600954811015610cc657826001600160a01b031660098281548110610c9457610c94611dbc565b6000918252602090912001546001600160a01b031603610cbe57610cb781610cf9565b9392505050565b600101610c6d565b506040517fe57fdbef00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b6040805160a081018252600080825260208201819052918101829052606081018290526080810191909152600060098381548110610d3957610d39611dbc565b9060005260206000200160009054906101000a90046001600160a01b031690506040518060a00160405280826001600160a01b03168152602001600a8581548110610d8657610d86611dbc565b600091825260209182902001546001600160a01b03168252600b8054929091019186908110610db757610db7611dbc565b60009182526020808320909101546001600160a01b03908116845294909416808252600585526040808320548487015290825260089094528390205492019190915292915050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610e73576000356001600160e01b03191660016040517f3e523c000000000000000000000000000000000000000000000000000000000081526004016108b5929190611fc3565b565b60005b81811015610eb857610eb0838383818110610e9557610e95611dbc565b905060a00201803603810190610eab9190611ea9565b61162f565b600101610e78565b507fc753dbf7952c70ff6b9fa7b626403aa1d2230d97136b635bd5e85bec72bcca6c8282604051610a8a929190611f3a565b60008082841115610f35576040517f87f6f0950000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b50506001805460028054858455908490556004805493840190556040805183815260208101839052929391928592879290917f976f8a9c5bdf8248dec172376d6e2b80a8e3df2f0328e381c6db8e1cf138c0f8910160405180910390a49250929050565b6001600160a01b03811660009081526005602052604081205490819003610fde576040516349f748eb60e01b81526001600160a01b03831660048201526024016108b5565b600954600090815b8181101561103557846001600160a01b03166009828154811061100b5761100b611dbc565b6000918252602090912001546001600160a01b03160361102d57809250611035565b600101610fe6565b5082600360008282546110489190611e28565b90915550506001600160a01b038416600090815260086020908152604080832083905560059091528120556009611080600183611e28565b8154811061109057611090611dbc565b600091825260209091200154600980546001600160a01b0390921691849081106110bc576110bc611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b0316021790555060098054806110fb576110fb611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560066000600a848154811061113a5761113a611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600a61116c600183611e28565b8154811061117c5761117c611dbc565b600091825260209091200154600a80546001600160a01b0390921691849081106111a8576111a8611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600a8054806111e7576111e7611fff565b6001900381819060005260206000200160006101000a8154906001600160a01b030219169055905560076000600b848154811061122657611226611dbc565b60009182526020808320909101546001600160a01b03168352820192909252604001812055600b611258600183611e28565b8154811061126857611268611dbc565b600091825260209091200154600b80546001600160a01b03909216918490811061129457611294611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600b8054806112d3576112d3611fff565b6000828152602090208101600019908101805473ffffffffffffffffffffffffffffffffffffffff1916905501905550505050565b611311816118eb565b80516001600160a01b03166000908152600560205260408120549081900361135a5781516040516349f748eb60e01b81526001600160a01b0390911660048201526024016108b5565b60095460005b818110156116295783600001516001600160a01b03166009828154811061138957611389611dbc565b6000918252602090912001546001600160a01b0316036116215782600360008282546113b59190611e28565b90915550506060840151600380546000906113d1908490611de8565b9250508190555083602001516001600160a01b0316600a82815481106113f9576113f9611dbc565b6000918252602090912001546001600160a01b0316146114d4576020808501516001600160a01b03166000908152600690915260409020541561144f576040516346da180960e01b815260040160405180910390fd5b60066000600a838154811061146657611466611dbc565b60009182526020808320909101546001600160a01b03168352828101939093526040909101812055840151600a8054839081106114a5576114a5611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b83604001516001600160a01b0316600b82815481106114f5576114f5611dbc565b6000918252602090912001546001600160a01b0316146115cf576040808501516001600160a01b031660009081526007602052205415611548576040516346da180960e01b815260040160405180910390fd5b60076000600b838154811061155f5761155f611dbc565b60009182526020808320909101546001600160a01b031683528201929092526040908101822091909155840151600b8054839081106115a0576115a0611dbc565b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b031602179055505b50505060608101805182516001600160a01b0390811660009081526005602090815260408083209490945584518187015184168352600682528483205593519483015190911681526007909252902055565b600101611360565b50505050565b60808101511561166b576040517f94e1670800000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b611674816118eb565b80516001600160a01b0316600090815260056020526040902054156116d35780516040517fada9a3530000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6020808201516001600160a01b0316600090815260069091526040902054156117395760208101516040517ffebc5eb20000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b6040808201516001600160a01b03166000908152600760205220541561179c5760408082015190517f0f69702d0000000000000000000000000000000000000000000000000000000081526001600160a01b0390911660048201526024016108b5565b8051600980546001808201835560009283527f6e1540171b6c0c960b71a7020d9f60077f6af931a8bbf590da0223dacf75c7af909101805473ffffffffffffffffffffffffffffffffffffffff199081166001600160a01b0395861617909155606085018051865186168552600560209081526040808720929092558088018051600a805480890182559089527fc65a7bb8d6351c1cf70c95a316cc6a92839c986682d98bc35f958f4883f9d2a80180548716918a16919091179055835190518816875260068252828720558188018051600b8054978801815588527f0175b7a638427703f0dbe7bb9bbf987a2551717b34e79f33b5b1008d1fa01db99096018054909516958816959095179093558151935186168552600783528085209390935585519094168352600890528120439055905160038054919290916118e3908490611de8565b909155505050565b8060600151600003611937576040517ffe2371460000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b604080516003808252608082019092526000916020820160608036833701905050905081600001518160008151811061197257611972611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160200151816001815181106119aa576119aa611dbc565b60200260200101906001600160a01b031690816001600160a01b0316815250508160400151816002815181106119e2576119e2611dbc565b60200260200101906001600160a01b031690816001600160a01b031681525050611a0b81611a50565b15610416576040517f1ad2fb620000000000000000000000000000000000000000000000000000000081526001600160e01b03196000351660048201526024016108b5565b60008151600003611a6357506000919050565b60005b6001835103811015611ae657600181015b8351811015611add57838181518110611a9257611a92611dbc565b60200260200101516001600160a01b0316848381518110611ab557611ab5611dbc565b60200260200101516001600160a01b031603611ad5575060019392505050565b600101611a77565b50600101611a66565b50600092915050565b60008060208385031215611b0257600080fd5b823567ffffffffffffffff80821115611b1a57600080fd5b818501915085601f830112611b2e57600080fd5b813581811115611b3d57600080fd5b8660208260051b8501011115611b5257600080fd5b60209290920196919550909350505050565b60008083601f840112611b7657600080fd5b50813567ffffffffffffffff811115611b8e57600080fd5b60208301915083602060a083028501011115610b4f57600080fd5b60008060208385031215611bbc57600080fd5b823567ffffffffffffffff811115611bd357600080fd5b611bdf85828601611b64565b90969095509350505050565b6020808252825182820181905260009190848201906040850190845b81811015611c6757611c548385516001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b9284019260a09290920191600101611c07565b50909695505050505050565b80356001600160a01b0381168114611c8a57600080fd5b919050565b600060208284031215611ca157600080fd5b610cb782611c73565b6020808252825182820181905260009190848201906040850190845b81811015611c6757835183529284019291840191600101611cc6565b60008060008060608587031215611cf857600080fd5b843567ffffffffffffffff811115611d0f57600080fd5b611d1b87828801611b64565b90989097506020870135966040013595509350505050565b60008060408385031215611d4657600080fd5b50508035926020909101359150565b600060208284031215611d6757600080fd5b5035919050565b60a08101611db682846001600160a01b038082511683528060208301511660208401528060408301511660408401525060608101516060830152608081015160808301525050565b92915050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b80820180821115611db657611db6611dd2565b634e487b7160e01b600052604160045260246000fd5b8082028115828204841417611db657611db6611dd2565b81810381811115611db657611db6611dd2565b600082611e5857634e487b7160e01b600052601260045260246000fd5b500490565b60208082528181018390526000908460408401835b86811015611e9e576001600160a01b03611e8b84611c73565b1682529183019190830190600101611e72565b509695505050505050565b600060a08284031215611ebb57600080fd5b60405160a0810181811067ffffffffffffffff82111715611eec57634e487b7160e01b600052604160045260246000fd5b604052611ef883611c73565b8152611f0660208401611c73565b6020820152611f1760408401611c73565b604082015260608301356060820152608083013560808201528091505092915050565b6020808252818101839052600090604080840186845b87811015611fb6576001600160a01b0380611f6a84611c73565b16845280611f79878501611c73565b168685015280611f8a868501611c73565b168486015250606082810135908401526080808301359084015260a09283019290910190600101611f50565b5090979650505050505050565b6001600160e01b03198316815260408101600b8310611ff257634e487b7160e01b600052602160045260246000fd5b8260208301529392505050565b634e487b7160e01b600052603160045260246000fdfea26469706673582212203322efc2dc5067897fa0ebf0e71848432953790436ddeae3b329f243ac407aea64736f6c63430008150033000000000000000000000000000000000000000000 + ├─ [1655136] → new RoninTrustedOrganization@0x47c5e40890bcE4a473A49D7501808b9633F29782 + │ └─ ← 8267 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(11) [staticcall] + │ └─ ← ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090] + ├─ [0] VM::load(ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [9246] ronin-mainnet.RoninTrustedOrganization::upgradeTo(RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782])  + │ ├─ emit Upgraded(param0: RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782], RoninTrustedOrganization, RoninTrustedOrganizationLogic, 0x, 4)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, RoninTrustedOrganizationLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(2) [staticcall] + │ └─ ← BridgeTracking + ├─ [0] GeneralConfig::getContractFileName(2) [staticcall] + │ └─ ← BridgeTracking.sol:BridgeTracking + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000005 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(BridgeTracking.sol:BridgeTracking) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000001d64608060405234801561001057600080fd5b5061001961001e565b6100eb565b600154600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60015460ff600160a01b909104811610156100e9576001805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b611c6a806100fa6000396000f3fe608060405234801561001057600080fd5b50600436106100df5760003560e01c8063c7c4fea91161008c578063de981f1b11610066578063de981f1b1461018e578063e2a75f36146101b9578063f67e8152146101cc578063f84bd121146101ec57600080fd5b8063c7c4fea914610155578063ca21287e14610168578063d25ed4c61461017b57600080fd5b80634ac0bcda116100bd5780634ac0bcda146101145780635cd8a76b1461013a578063865e6fd31461014257600080fd5b80631794bb3c146100e4578063229f88ea146100f95780633b1544551461010c575b600080fd5b6100f76100f23660046116c6565b6101f4565b005b6100f7610107366004611716565b610352565b6100f76104fa565b610127610122366004611740565b6105d5565b6040519081526020015b60405180910390f35b6100f76105f3565b6100f761015036600461177f565b610757565b6100f76101633660046117ab565b610776565b6100f76101763660046117eb565b610b8c565b610127610189366004611847565b610cbe565b6101a161019c366004611860565b610cf3565b6040516001600160a01b039091168152602001610131565b6101276101c7366004611847565b610d82565b6101df6101da36600461187b565b610dac565b6040516101319190611935565b600254610127565b600154600160a81b900460ff161580801561021a575060018054600160a01b900460ff16105b8061023a5750303b15801561023a575060018054600160a01b900460ff16145b6102a25760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b600180547fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff16600160a01b17905580156102ea576001805460ff60a81b1916600160a81b1790555b6102f5600285610df3565b610300600884610df3565b6002829055801561034c576001805460ff60a81b191681556040519081527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b600261035d81610ea4565b610365610f09565b6000600a600085600281111561037d5761037d611948565b600281111561038e5761038e611948565b815260200190815260200160002060008481526020019081526020016000209050806000015460000361034c576103c3610f17565b60006103cf6008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561040c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610430919061195e565b808355600480546001818101835560009290925260029081027f8a35acfbc15ff81a39ae7d344fd709f28e8600b4aa8c65c6b64bfe7fe36bd19b018054939450928892849260ff1990921691849081111561048d5761048d611948565b02179055506001808201869055830160005b81548110156104e2576104da88888484815481106104bf576104bf611977565b6000918252602090912001546001600160a01b0316876111b9565b60010161049f565b506104f1600185016000611639565b50505050505050565b600461050581610ea4565b600019600b54146105585760405162461bcd60e51b815260206004820152601260248201527f616c726561647920696e697420726570203200000000000000000000000000006044820152606401610299565b6105626008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa15801561059f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906105c3919061195e565b600b556105d260046000610df3565b50565b60006105ea83836105e586611346565b61146c565b90505b92915050565b600154600290600160a81b900460ff1615801561061e575060015460ff808316600160a01b90920416105b6106815760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610299565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790556000546106c1906002906001600160a01b0316610df3565b6001546106d9906008906001600160a01b0316610df3565b6000805473ffffffffffffffffffffffffffffffffffffffff19169055600180547fffffffffffffffffffff00ff000000000000000000000000000000000000000016905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a150565b61075f6114c2565b61076881611536565b6107728282610df3565b5050565b600261078181610ea4565b610789610f09565b60006107956008610cf3565b6001600160a01b031663060406186040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107d2573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107f6919061195e565b9050610800610f17565b6000600a600087600281111561081857610818611948565b600281111561082957610829611948565b81526020019081526020016000206000868152602001908152602001600020905080600001546000036108985760019081018054918201815560009081526020902001805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0385161790555061034c565b6108a4868686856111b9565b600b54828110156104f157600b8381556000906108c090610cf3565b6001600160a01b0316639b19dbfd6040518163ffffffff1660e01b8152600401600060405180830381865afa1580156108fd573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f1916820160405261092591908101906119ae565b905060006109338383611585565b9050600061094084610d82565b9050600061094d85610cbe565b9050600061095b600c610cf3565b9050600080826001600160a01b0316878786888c604051602401610983959493929190611a73565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff16634dca592560e01b179052516109cd9190611b0c565b6000604051808303816000865af19150503d8060008114610a0a576040519150601f19603f3d011682016040523d82523d6000602084013e610a0f565b606091505b509150915081610a6657604051634dca592560e01b906001600160a01b038516907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610a5d908590611b28565b60405180910390a35b6000610a72600d610cf3565b9050806001600160a01b0316888887898d604051602401610a97959493929190611a73565b60408051601f198184030181529181526020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff166335e5b7eb60e11b17905251610ae19190611b0c565b6000604051808303816000865af19150503d8060008114610b1e576040519150601f19603f3d011682016040523d82523d6000602084013e610b23565b606091505b50909350915082610b7b576040516335e5b7eb60e11b906001600160a01b038316907feaa424ccc38ebcf22402729592dedf8315790e0128cb577cdeff1a3ee627f82790610b72908690611b28565b60405180910390a35b505050505050505050505050505050565b600154600390600160a81b900460ff16158015610bb7575060015460ff808316600160a01b90920416105b610c1a5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610299565b6001805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b179055610c4d600b86610df3565b610c58600c85610df3565b610c63600d84610df3565b610c6e600483610df3565b600019600b556001805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050505050565b600081815260096020526040902060010154610cd982611346565b15610cee57600654610ceb9082611b5b565b90505b919050565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f811115610d2a57610d2a611948565b60ff1681526020810191909152604001600020546001600160a01b0316905080610cee57816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016102999190611b90565b600081815260096020526040902054610d9a82611346565b15610cee57600454610ceb9082611b5b565b6060610deb8484848080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525061158592505050565b949350505050565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f811115610e2957610e29611948565b60ff1681526020810191909152604001600020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03928316179055811682600f811115610e7757610e77611948565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b610ead81610cf3565b6001600160a01b0316336001600160a01b0316146105d2576000356001600160e01b03191681336040517f8383e63400000000000000000000000000000000000000000000000000000000815260040161029993929190611b9e565b600254431015610f1557005b565b6000610f236008610cf3565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa158015610f6d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f91919061195e565b9050806003600001541015610772576000826001600160a01b031663468c96ae6003600001546001610fc39190611b5b565b6040518263ffffffff1660e01b8152600401610fe191815260200190565b6040805180830381865afa158015610ffd573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110219190611bd3565b6003849055600081815260096020526040812060045481549395509093509183919061104e908490611b5b565b909155505060065460018201805460009061106a908490611b5b565b90915550600090505b6008548110156110fa5760088054600091908390811061109557611095611977565b60009182526020808320909101546001600160a01b03168083526007825260408084205460028801909352832080549194509192906110d5908490611b5b565b90915550506001600160a01b0316600090815260076020526040812055600101611073565b5060005b60045481101561118c5760006003600101828154811061112057611120611977565b6000918252602082206002918202018054909350600a91839160ff169081111561114c5761114c611948565b600281111561115d5761115d611948565b8152602080820192909252604090810160009081206001958601548252909252902060030185905550016110fe565b5061119960046000611657565b600060058181556006829055906111b1600882611639565b505050505050565b6000600a60008660028111156111d1576111d1611948565b60028111156111e2576111e2611948565b81526020808201929092526040908101600090812087825283528181206001600160a01b038716825260028101909352205490915060ff1615611225575061034c565b6001600160a01b03831660009081526002820160205260408120805460ff191660011790556003820154908190036112ff576001600160a01b03841660009081526007602052604081205490036112cf57600880546001810182556000919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee301805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0386161790555b6006805460019081019091556001600160a01b0385166000908152600760205260409020805490910190556111b1565b8281036111b157600090815260096020908152604080832060018082018054820190556001600160a01b039790971684526002019091529020805490930190925550505050565b6000806113536008610cf3565b60405163a3d545f560e01b81524360048201529091506000906001600160a01b0383169063a3d545f590602401602060405180830381865afa15801561139d573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113c1919061195e565b9050600080836001600160a01b031663468c96ae60036000015460016113e79190611b5b565b6040518263ffffffff1660e01b815260040161140591815260200190565b6040805180830381865afa158015611421573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114459190611bd3565b9150915081801561145557508086145b8015611462575060035483115b9695505050505050565b60008381526009602090815260408083206001600160a01b038616845260020190915290205481156114bb576001600160a01b038316600090815260076020526040902054610deb9082611b5b565b9392505050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610f15576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610299929190611c06565b806001600160a01b03163b6000036105d2576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610299565b80516060908067ffffffffffffffff8111156115a3576115a361198d565b6040519080825280602002602001820160405280156115cc578160200160208202803683370190505b50915060006115da85611346565b905060005b828110156116305761160b868683815181106115fd576115fd611977565b60200260200101518461146c565b84828151811061161d5761161d611977565b60209081029190910101526001016115df565b50505092915050565b50805460008255906000526020600020908101906105d29190611678565b50805460008255600202906000526020600020908101906105d29190611691565b5b8082111561168d5760008155600101611679565b5090565b5b8082111561168d57805460ff1916815560006001820155600201611692565b6001600160a01b03811681146105d257600080fd5b6000806000606084860312156116db57600080fd5b83356116e6816116b1565b925060208401356116f6816116b1565b929592945050506040919091013590565b803560038110610cee57600080fd5b6000806040838503121561172957600080fd5b61173283611707565b946020939093013593505050565b6000806040838503121561175357600080fd5b823591506020830135611765816116b1565b809150509250929050565b803560108110610cee57600080fd5b6000806040838503121561179257600080fd5b61179b83611770565b91506020830135611765816116b1565b6000806000606084860312156117c057600080fd5b6117c984611707565b92506020840135915060408401356117e0816116b1565b809150509250925092565b6000806000806080858703121561180157600080fd5b843561180c816116b1565b9350602085013561181c816116b1565b9250604085013561182c816116b1565b9150606085013561183c816116b1565b939692955090935050565b60006020828403121561185957600080fd5b5035919050565b60006020828403121561187257600080fd5b6105ea82611770565b60008060006040848603121561189057600080fd5b83359250602084013567ffffffffffffffff808211156118af57600080fd5b818601915086601f8301126118c357600080fd5b8135818111156118d257600080fd5b8760208260051b85010111156118e757600080fd5b6020830194508093505050509250925092565b600081518084526020808501945080840160005b8381101561192a5781518752958201959082019060010161190e565b509495945050505050565b6020815260006105ea60208301846118fa565b634e487b7160e01b600052602160045260246000fd5b60006020828403121561197057600080fd5b5051919050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b8051610cee816116b1565b600060208083850312156119c157600080fd5b825167ffffffffffffffff808211156119d957600080fd5b818501915085601f8301126119ed57600080fd5b8151818111156119ff576119ff61198d565b8060051b604051601f19603f83011681018181108582111715611a2457611a2461198d565b604052918252848201925083810185019188831115611a4257600080fd5b938501935b82851015611a6757611a58856119a3565b84529385019392850192611a47565b98975050505050505050565b60a0808252865190820181905260009060209060c0840190828a01845b82811015611ab55781516001600160a01b031684529284019290840190600101611a90565b50505083810382850152611ac981896118fa565b6040850197909752505050606081019290925260809091015292915050565b60005b83811015611b03578181015183820152602001611aeb565b50506000910152565b60008251611b1e818460208701611ae8565b9190910192915050565b6020815260008251806020840152611b47816040850160208701611ae8565b601f01601f19169190910160400192915050565b808201808211156105ed57634e487b7160e01b600052601160045260246000fd5b60108110611b8c57611b8c611948565b9052565b602081016105ed8284611b7c565b6001600160e01b03198416815260608101611bbc6020830185611b7c565b6001600160a01b0383166040830152949350505050565b60008060408385031215611be657600080fd5b82518015158114611bf657600080fd5b6020939093015192949293505050565b6001600160e01b03198316815260408101600b8310611c2757611c27611948565b826020830152939250505056fea264697066735822122089b80e8f38115da71d00f5612b6a2886ec719ca6c6b5fda4aaf8ad9791668fae64736f6c6343000815003300000000000000000000000000000000000000000000000000000000 + ├─ [1479938] → new BridgeTracking@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + │ ├─ emit Initialized(version: 255) + │ └─ ← 7274 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(2) [staticcall] + │ └─ ← ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2] + ├─ [0] VM::load(ronin-mainnet.BridgeTracking: [0x3Fb325b251eE80945d3fc8c7692f5aFFCA1B8bC2], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [59673] ronin-mainnet.BridgeTracking::upgradeToAndCall(BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f]) + │ ├─ [48032] BridgeTracking::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 2, addr: ronin-mainnet.RoninGatewayV3: [0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df]) + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], BridgeTracking, BridgeTrackingLogic, 0x, 5)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, BridgeTrackingLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getContractName(13) [staticcall] + │ └─ ← StakingVesting + ├─ [0] GeneralConfig::getContractFileName(13) [staticcall] + │ └─ ← StakingVesting.sol:StakingVesting + ├─ [0] VM::getNonce(0x0000000000000000000000000000000000000000) [staticcall] + │ └─ ← 0x0000000000000000000000000000000000000000000000000000000000000006 + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [0] VM::broadcast(0x0000000000000000000000000000000000000000)  + │ └─ ← () + ├─ [0] VM::getCode(StakingVesting.sol:StakingVesting) [staticcall] + │ └─ ← 0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000e9a608060405234801561001057600080fd5b5061001961001e565b6100eb565b600054600160a81b900460ff161561008c5760405162461bcd60e51b815260206004820152602760248201527f496e697469616c697a61626c653a20636f6e747261637420697320696e697469604482015266616c697a696e6760c81b606482015260840160405180910390fd5b60005460ff600160a01b909104811610156100e9576000805460ff60a01b191660ff60a01b17905560405160ff81527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b565b610da0806100fa6000396000f3fe6080604052600436106100dd5760003560e01c80637a1ac61e1161007f578063d8209d0711610059578063d8209d071461020c578063de981f1b1461022e578063f13ba64414610266578063fa8674a11461028657600080fd5b80637a1ac61e146101b9578063865e6fd3146101cc5780639e7cb051146101ec57600080fd5b8063434a025d116100bb578063434a025d1461016f57806359f778df1461016d5780635cd8a76b1461018457806367e9941c1461019957600080fd5b80630634f5b9146100e25780630d9160e7146101295780633c3d84101461014d575b600080fd5b3480156100ee57600080fd5b506101026100fd366004610bb7565b6102a8565b60408051941515855260208501939093529183015260608201526080015b60405180910390f35b34801561013557600080fd5b5061013f60035481565b604051908152602001610120565b34801561015957600080fd5b5061016d610168366004610bea565b6103fa565b005b34801561017b57600080fd5b5060045461013f565b34801561019057600080fd5b5061016d610507565b3480156101a557600080fd5b5061016d6101b4366004610bea565b610636565b61016d6101c7366004610c1a565b61064a565b3480156101d857600080fd5b5061016d6101e7366004610c5c565b6107a9565b3480156101f857600080fd5b5061016d610207366004610bea565b6107c8565b34801561021857600080fd5b5061013f610227366004610bea565b5060015490565b34801561023a57600080fd5b5061024e610249366004610c86565b610823565b6040516001600160a01b039091168152602001610120565b34801561027257600080fd5b5061016d610281366004610bea565b6108b7565b34801561029257600080fd5b5061013f6102a1366004610bea565b5060025490565b60008060008060086102b9816108c8565b60035443116102f4576040517fe5cf958000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b4360035586610304576000610308565b6001545b93508561031657600061031a565b6002545b6004549093509150600061032e8486610ca8565b905080156103ee5733610341818361092d565b9650866103a6576040805187815260208101879052478183015290516001600160a01b0383169143917f137e697384eeada9cf7614b88e4ac940aeff18d0fef7e86bce1abdc812b95e099181900360600190a350600094508493508392506103f09050565b60408051878152602081018790526001600160a01b0383169143917f60200441f885b45b3b7f1fdc45a47bb0d0a0884a6a17722f8dd7232830de9bd2910160405180910390a3505b505b5092959194509250565b600054600390600160a81b900460ff16158015610425575060005460ff808316600160a01b90920416105b61048d5760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b60648201526084015b60405180910390fd5b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b1790556104be82610989565b6000805460ff60a81b1916905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15050565b565b600054600290600160a81b900460ff16158015610532575060005460ff808316600160a01b90920416105b6105955760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610484565b6000805460ff60a81b1960ff8416600160a01b021661ffff60a01b1990911617600160a81b17908190556105d4906008906001600160a01b03166109be565b600080547fffffffffffffffffffff00ff000000000000000000000000000000000000000016905560405160ff821681527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb3847402498906020015b60405180910390a150565b61063e610a7a565b61064781610aee565b50565b600054600160a81b900460ff161580801561067257506000546001600160a01b90910460ff16105b806106935750303b1580156106935750600054600160a01b900460ff166001145b6106f65760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610484565b600080547fffffffffffffffffffffff00ffffffffffffffffffffffffffffffffffffffff16600160a01b179055801561073e576000805460ff60a81b1916600160a81b1790555b6107496008856109be565b61075283610b23565b61075b82610aee565b80156107a3576000805460ff60a81b19169055604051600181527f7f26b83ff96e1f2b6a682f133852f6798a09c465da95921460cefb38474024989060200160405180910390a15b50505050565b6107b1610a7a565b6107ba81610b58565b6107c482826109be565b5050565b6107d0610a7a565b61271081111561081a576040517f053265f10000000000000000000000000000000000000000000000000000000081526001600160e01b0319600035166004820152602401610484565b61064781610989565b60007fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600083600f81111561085a5761085a610ccf565b60ff1681526020810191909152604001600020546001600160a01b03169050806108b257816040517f812281be0000000000000000000000000000000000000000000000000000000081526004016104849190610cf9565b919050565b6108bf610a7a565b61064781610b23565b6108d181610823565b6001600160a01b0316336001600160a01b031614610647576000356001600160e01b03191681336040517f8383e63400000000000000000000000000000000000000000000000000000000815260040161048493929190610d07565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461097a576040519150601f19603f3d011682016040523d82523d6000602084013e61097f565b606091505b5090949350505050565b60048190556040518181527f2ab16834b71343f4e1d560b325168aef35dd575d15d84c31ef788e94770995369060200161062b565b807fdea3103d22025c269050bea94c0c84688877f12fa22b7e6d2d5d78a9a49aa1cb600084600f8111156109f4576109f4610ccf565b60ff168152602081019190915260400160002080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b03928316179055811682600f811115610a4d57610a4d610ccf565b6040517f865d1c228a8ea13709cfe61f346f7ff67f1bbd4a18ff31ad3e7147350d317c5990600090a35050565b7fb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103546001600160a01b03163314610505576000356001600160e01b03191660016040517f3e523c00000000000000000000000000000000000000000000000000000000008152600401610484929190610d3c565b60028190556040518181527f57a23b4b11f619fb9dea21a5a8115bb90103c1043eb3318d773558829d25f12c9060200161062b565b60018190556040518181527f861f03c645467325a586235bb3155834f1dddf12413d0a802f416eb6d4035e6d9060200161062b565b806001600160a01b03163b600003610647576040517f2ff1928c0000000000000000000000000000000000000000000000000000000081526001600160a01b0382166004820152602401610484565b803580151581146108b257600080fd5b60008060408385031215610bca57600080fd5b610bd383610ba7565b9150610be160208401610ba7565b90509250929050565b600060208284031215610bfc57600080fd5b5035919050565b80356001600160a01b03811681146108b257600080fd5b600080600060608486031215610c2f57600080fd5b610c3884610c03565b95602085013595506040909401359392505050565b8035601081106108b257600080fd5b60008060408385031215610c6f57600080fd5b610c7883610c4d565b9150610be160208401610c03565b600060208284031215610c9857600080fd5b610ca182610c4d565b9392505050565b80820180821115610cc957634e487b7160e01b600052601160045260246000fd5b92915050565b634e487b7160e01b600052602160045260246000fd5b60108110610cf557610cf5610ccf565b9052565b60208101610cc98284610ce5565b6001600160e01b03198416815260608101610d256020830185610ce5565b6001600160a01b0383166040830152949350505050565b6001600160e01b03198316815260408101600b8310610d5d57610d5d610ccf565b826020830152939250505056fea26469706673582212204a11b64b0d483b0901f024fe7650d1033a380aa9b00f62dc51caeaf56dfe3a9f64736f6c63430008150033000000000000 + ├─ [721946] → new StakingVesting@0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9 + │ ├─ emit Initialized(version: 255) + │ └─ ← 3488 bytes of code + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(13) [staticcall] + │ └─ ← ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816] + ├─ [0] VM::load(ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816], 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103) [staticcall] + │ └─ ← 0x000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3 + ├─ [0] VM::broadcast(0x946397deDFd2f79b75a72B322944a21C3240c9c3)  + │ └─ ← () + ├─ [0] VM::resumeGasMetering()  + │ └─ ← () + ├─ [44703] ronin-mainnet.StakingVesting::upgradeToAndCall(StakingVesting: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], 0x5cd8a76b)  + │ ├─ emit Upgraded(param0: StakingVesting: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9]) + │ ├─ [33062] StakingVesting::initializeV2() [delegatecall] + │ │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ │ ├─ emit Initialized(version: 2) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::pauseGasMetering()  + │ └─ ← () + ├─ [0] LogGenerator::generateDeploymentArtifact(0x0000000000000000000000000000000000000000, StakingVesting: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], StakingVesting, StakingVestingLogic, 0x, 6)  + │ ├─ [0] GeneralConfig::getRuntimeConfig() [staticcall] + │ │ └─ ← (false, false) + │ ├─ [0] console::log(Skipping artifact generation for:, StakingVestingLogic) [staticcall] + │ │ └─ ← () + │ └─ ← () + ├─ [0] ronin-mainnet.StakingVesting::initializeV3(50)  + │ ├─ [0] StakingVesting::initializeV3(50) [delegatecall] + │ │ ├─ emit FastFinalityRewardPercentageUpdated(: 50) + │ │ ├─ emit Initialized(version: 3) + │ │ └─ ← () + │ └─ ← () + ├─ [0] GeneralConfig::getAddressFromCurrentNetwork(10) [staticcall] + │ └─ ← ronin-mainnet.FastFinalityTracking: [0xA30B2932CD8b8A89E34551Cdfa13810af38dA576] + ├─ [0] VM::warp(1696244594 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139076 [2.813e7])  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::numberOfBlocksInEpoch() [staticcall] + │ ├─ [0] RoninValidatorSet::numberOfBlocksInEpoch() [delegatecall] + │ │ └─ ← 200 + │ └─ ← 200 + ├─ [0] VM::warp(1696330994 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139199 [2.813e7])  + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::wrapUpEpoch()  + │ ├─ [0] RoninValidatorSet::wrapUpEpoch() [delegatecall] + │ │ ├─ [0] ronin-mainnet.FastFinalityTracking::468d24be(000000000000000000000000000000000000000000000000000000000002259800000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000016000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf380000000000000000000000009b959d27840a31988410ee69991bcf0110d61f0200000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac206840000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000d11d9842babd5209b9b1155e46f5878c989125b7000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab5000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d000000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b0100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8) [staticcall] + │ │ │ ├─ [0] 0x241e507363d674c77a9930F31ea26BBc8857949c::468d24be(000000000000000000000000000000000000000000000000000000000002259800000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000016000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf380000000000000000000000009b959d27840a31988410ee69991bcf0110d61f0200000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac206840000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000d11d9842babd5209b9b1155e46f5878c989125b7000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab5000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d000000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b0100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ [0] 0xab4BC28137a9535838a27fBE59044F6eE3D68428::fallback{value: 169807176758141357622}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169807176758141357622 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, recipient: 0xab4BC28137a9535838a27fBE59044F6eE3D68428, amount: 169807176758141357622 [1.698e20]) + │ │ ├─ [0] 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4::fallback{value: 118963578955331395475}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 118963578955331395475 [1.189e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x9B959D27840a31988410Ee69991BCF0110D61F02, recipient: 0x2C150A17292fd376CDaE6e6c01d5a99134A1F7f4, amount: 118963578955331395475 [1.189e20]) + │ │ ├─ [0] 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2::fallback{value: 169879446172168538675}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169879446172168538675 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, recipient: 0x4e0A599e4dFf57965e0Dd5bc680F43cc864364C2, amount: 169879446172168538675 [1.698e20]) + │ │ ├─ [0] 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72::fallback{value: 135925354685204004300}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6E46924371d0e910769aaBE0d867590deAC20684, recipient: 0xAaf13f99BDBF3bFa9209AaBFcd74C50c6D1A9e72, amount: 135925354685204004300 [1.359e20]) + │ │ ├─ [0] 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8::fallback{value: 169870705637003507268}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 169870705637003507268 [1.698e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, recipient: 0xbB38191e724baf5a1Fb2eBD0a7a32015982449a8, amount: 169870705637003507268 [1.698e20]) + │ │ ├─ [0] 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9::fallback{value: 170136480416710407898}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170136480416710407898 [1.701e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xFc3e31519B551bd594235dd0eF014375a87C4e21, recipient: 0x4abd99f9f4798C9536dAc5594a5b16916DF300b9, amount: 170136480416710407898 [1.701e20]) + │ │ ├─ [0] 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3::fallback{value: 340436100948920512964}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xE07D7e56588a6FD860c5073c70a099658C060F3D, recipient: 0x4B18CEBEB9797Ea594b5977109cc07b21c37E8c3, amount: 340436100948920512964 [3.404e20]) + │ │ ├─ [0] 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888::fallback{value: 340325252087546507482}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, recipient: 0x0edb20DD5FE4f2E6aC3F58f304AC071273893888, amount: 340325252087546507482 [3.403e20]) + │ │ ├─ [0] 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034::fallback{value: 339817976993460557814}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x52349003240770727900b06a3B3a90f5c0219ADe, recipient: 0xceA3d996Cf38120FA7a736e687F2f7306DFB0034, amount: 339817976993460557814 [3.398e20]) + │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 340374055555383969820}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, recipient: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 340374055555383969820 [3.403e20]) + │ │ ├─ [0] 0x2d593A0087029501eE419b9415DeC3fAC195FE4A::fallback{value: 340363726701776549276}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 340363726701776549276 [3.403e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xd11D9842baBd5209b9B1155e46f5878c989125b7, recipient: 0x2d593A0087029501eE419b9415DeC3fAC195FE4A, amount: 340363726701776549276 [3.403e20]) + │ │ ├─ [0] 0xD8FCC2BC2da24e7d74af0078408E6394d7080776::fallback{value: 339728192236459901442}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 339728192236459901442 [3.397e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, recipient: 0xD8FCC2BC2da24e7d74af0078408E6394d7080776, amount: 339728192236459901442 [3.397e20]) + │ │ ├─ [0] 0xE5718182af678C7d65c286851934273AA39e67d6::fallback{value: 84815024893111142653}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84815024893111142653 [8.481e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, recipient: 0xE5718182af678C7d65c286851934273AA39e67d6, amount: 84815024893111142653 [8.481e19]) + │ │ ├─ [0] 0xa27a1095015dC037C92403F4B26196b04f342961::fallback{value: 85096491629164641003}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85096491629164641003 [8.509e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, recipient: 0xa27a1095015dC037C92403F4B26196b04f342961, amount: 85096491629164641003 [8.509e19]) + │ │ ├─ [0] 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814::fallback{value: 85089196191471422275}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 85089196191471422275 [8.508e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, recipient: 0xc4209C31C9bAE0636f42bc35EC0bcaD49A3cA814, amount: 85089196191471422275 [8.508e19]) + │ │ ├─ [0] 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434::fallback{value: 85177254352471927923}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, recipient: 0x78Eed69daCc194CCf8cBf705D81f6E99dD115434, amount: 85177254352471927923 [8.517e19]) + │ │ ├─ [0] 0x9305E94C367e04b508cB9919f9dce3B60058A740::fallback{value: 84968697635262370274}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 84968697635262370274 [8.496e19]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, recipient: 0x9305E94C367e04b508cB9919f9dce3B60058A740, amount: 84968697635262370274 [8.496e19]) + │ │ ├─ [0] 0xA1FBA3752cf39647f1028a4c61791611a78588aB::fallback{value: 84955525293728741846}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, recipient: 0xA1FBA3752cf39647f1028a4c61791611a78588aB, amount: 84955525293728741846 [8.495e19]) + │ │ ├─ [0] 0x69134fB518A13403F4725a15ff60f5B688894c42::fallback{value: 169880292287037425572}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, recipient: 0x69134fB518A13403F4725a15ff60f5B688894c42, amount: 169880292287037425572 [1.698e20]) + │ │ ├─ [0] 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F::fallback{value: 170227489474005394791}()  + │ │ │ ├─ [0] GnosisSafeL2::receive() [delegatecall] + │ │ │ │ ├─ emit SafeReceived(sender: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], value: 170227489474005394791 [1.702e20]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, recipient: 0x75a6e6B7D9C63657bCec0BB493ac81D072353D5F, amount: 170227489474005394791 [1.702e20]) + │ │ ├─ [0] 0x9B0612E43855ef9a7c329ee89653bA45273B550e::fallback{value: 169909652573519158189}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x61089875fF9e506ae78C7FE9f7c388416520E386, recipient: 0x9B0612E43855ef9a7c329ee89653bA45273B550e, amount: 169909652573519158189 [1.699e20]) + │ │ ├─ [0] 0x72A69B04B59C36fCED19ac54209beF878e84FcBF::fallback{value: 169862575167464156156}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, recipient: 0x72A69B04B59C36fCED19ac54209beF878e84FcBF, amount: 169862575167464156156 [1.698e20]) + │ │ ├─ [0] ronin-mainnet.Staking::fallback{value: 33235944893664027916805}()  + │ │ │ ├─ [0] Staking::receive() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4])  + │ │ │ ├─ [0] Staking::execRecordRewards([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]], 19632 [1.963e4]) [delegatecall] + │ │ │ │ ├─ emit PoolsUpdated(period: 19632 [1.963e4], poolAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], aRps: [66357646962488955 [6.635e16], 95431207368377915 [9.543e16], 95695598399621230 [9.569e16], 94573200455822051 [9.457e16], 97687248220171528 [9.768e16], 97310118461513347 [9.731e16], 93829791800558853 [9.382e16], 99884465958207150 [9.988e16], 99093477004188600 [9.909e16], 97216470633378110 [9.721e16], 100780733232959799 [1.007e17], 99144578508031030 [9.914e16], 93318776012821131 [9.331e16], 94447227634309187 [9.444e16], 98467985935188233 [9.846e16], 88199764422009158 [8.819e16], 93079390018252421 [9.307e16], 67225014440065554 [6.722e16], 94805313929688703 [9.48e16], 97239053863980682 [9.723e16], 98902645602159682 [9.89e16], 99019423310445352 [9.901e16]], shares: [10190748510465558475599875 [1.019e25], 7206104688158066377918315 [7.206e24], 6881867025193447219128274 [6.881e24], 6781274466483249341608615 [6.781e24], 6658249476098351649251578 [6.658e24], 6503464654044309321751691 [6.503e24], 5903862198409162686318766 [5.903e24], 5813275267619519038407189 [5.813e24], 5784491179033799937345365 [5.784e24], 5778443231451247986081315 [5.778e24], 5741644343444817691866731 [5.741e24], 5761256007661259154805105 [5.761e24], 7389521338803830815958367 [7.389e24], 7188192519136884811285316 [7.188e24], 7047161408616008536704042 [7.047e24], 7015615166482386890314536 [7.015e24], 6993506329773885059751580 [6.993e24], 6906329454934638339591820 [6.906e24], 6718763510770822301943622 [6.718e24], 6452840193432170260900982 [6.452e24], 6396343690109009473179767 [6.396e24], 6365969656770395353461256 [6.365e24]]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit StakingRewardDistributed(totalAmount: 33235944893664027916805 [3.323e22], consensusAddrs: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], amounts: [1528264590823272218598 [1.528e21], 1580516120406545682805 [1.58e21], 1528915015549516848075 [1.528e21], 1563141578879846049524 [1.563e21], 1528836350733031565413 [1.528e21], 1531228323750393671094 [1.531e21], 1361744403795682051856 [1.361e21], 1361301008350186029928 [1.361e21], 1359271907973842231256 [1.359e21], 1361496222221535879280 [1.361e21], 1361454906807106197104 [1.361e21], 1358912768945839605768 [1.358e21], 1611485472969111710423 [1.611e21], 1616833340954128179097 [1.616e21], 1616694727637957023265 [1.616e21], 1618367832696966630557 [1.618e21], 1614405255069985035256 [1.614e21], 1614154980580846095134 [1.614e21], 1528922630583336830148 [1.528e21], 1532047405266048553119 [1.532e21], 1529186873161672423701 [1.529e21], 1528763176507177405404 [1.528e21]]) + │ │ ├─ [0] ronin-mainnet.StakingVesting::receiveRON{value: 1243911719922200000000}()  + │ │ │ ├─ [0] StakingVesting::receiveRON() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit DeprecatedRewardRecycled(recipientAddr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816], amount: 1243911719922200000000 [1.243e21]) + │ │ ├─ [0] ronin-mainnet.SlashIndicator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4])  + │ │ │ ├─ [0] SlashIndicator::updateCreditScores([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 19632 [1.963e4]) [delegatecall] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriodStartAtBlock() [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::currentPeriodStartAtBlock() [delegatecall] + │ │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ │ └─ ← 28126000 [2.812e7] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::checkManyJailed([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8]) [delegatecall] + │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [staticcall] + │ │ │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintainedInBlockRange([0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], 28126000 [2.812e7], 28139199 [2.813e7]) [delegatecall] + │ │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ ├─ emit CreditScoresUpdated(validators: [0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8], creditScores: [600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::waitingSecsToRevoke() [staticcall] + │ │ │ ├─ [0] Staking::waitingSecsToRevoke() [delegatecall] + │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ └─ ← 604800 [6.048e5] + │ │ ├─ [0] ronin-mainnet.Staking::minValidatorStakingAmount() [staticcall] + │ │ │ ├─ [0] Staking::minValidatorStakingAmount() [delegatecall] + │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ ├─ [0] ronin-mainnet.Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ ├─ [0] ronin-mainnet.Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ ├─ [0] ronin-mainnet.RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ ├─ [0] 0x0000000000000000000000000000000000000068::pickValidatorSet([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1], [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]], [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0], 22, 12) [staticcall] + │ │ │ └─ ← [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe] + │ │ ├─ emit ValidatorSetUpdated(period: 19633 [1.963e4], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [staticcall] + │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7]) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ emit BlockProducerSetUpdated(period: 19633 [1.963e4], epoch: 140697 [1.406e5], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ emit WrappedUpEpoch(periodNumber: 19632 [1.963e4], epochNumber: 140696 [1.406e5], periodEnding: true) + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::warp(1696330997 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139200 [2.813e7])  + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::submitBlockReward{value: 1000000}()  + │ ├─ [0] RoninValidatorSet::submitBlockReward() [delegatecall] + │ │ ├─ [0] ronin-mainnet.StakingVesting::requestBonus(true, false)  + │ │ │ ├─ [0] StakingVesting::requestBonus(true, false) [delegatecall] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::fallback{value: 2853881278540000000}()  + │ │ │ │ │ ├─ [0] RoninValidatorSet::receive() [delegatecall] + │ │ │ │ │ │ └─ ← () + │ │ │ │ │ └─ ← () + │ │ │ │ ├─ emit BonusTransferred(blockNumber: 28139200 [2.813e7], recipient: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f], blockProducerAmount: 2853881278540000000 [2.853e18], bridgeOperatorAmount: 0) + │ │ │ │ └─ ← true, 2853881278540000000 [2.853e18], 0, 50 + │ │ │ └─ ← true, 2853881278540000000 [2.853e18], 0, 50 + │ │ ├─ emit BlockRewardSubmitted(coinbaseAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, submittedAmount: 1000000 [1e6], bonusAmount: 2853881278540000000 [2.853e18]) + │ │ ├─ [0] ronin-mainnet.Staking::getCommissionRateRange() [staticcall] + │ │ │ ├─ [0] Staking::getCommissionRateRange() [delegatecall] + │ │ │ │ └─ ← 500, 2000 + │ │ │ └─ ← 500, 2000 + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.FastFinalityTracking::c245db0f(00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215)  + │ ├─ [0] 0x241e507363d674c77a9930F31ea26BBc8857949c::c245db0f(00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000001000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215) [delegatecall] + │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::epochOf(28139200 [2.813e7]) [staticcall] + │ │ │ ├─ [0] RoninValidatorSet::epochOf(28139200 [2.813e7]) [delegatecall] + │ │ │ │ └─ ← 140697 [1.406e5] + │ │ │ └─ ← 140697 [1.406e5] + │ │ └─ ← () + │ └─ ← () + ├─ [0] VM::warp(1696331000 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139201 [2.813e7])  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::numberOfBlocksInEpoch() [staticcall] + │ ├─ [0] RoninValidatorSet::numberOfBlocksInEpoch() [delegatecall] + │ │ └─ ← 200 + │ └─ ← 200 + ├─ [0] VM::warp(1696417400 [1.696e9])  + │ └─ ← () + ├─ [0] VM::roll(28139399 [2.813e7])  + │ └─ ← () + ├─ [0] VM::prank(0xEE11d2016e9f2faE606b2F12986811F4abbe6215)  + │ └─ ← () + ├─ [0] ronin-mainnet.RoninValidatorSet::wrapUpEpoch()  + │ ├─ [0] RoninValidatorSet::wrapUpEpoch() [delegatecall] + │ │ ├─ [0] ronin-mainnet.FastFinalityTracking::468d24be(00000000000000000000000000000000000000000000000000000000000225990000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000001600000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b0000000000000000000000009b959d27840a31988410ee69991bcf0110d61f02000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d00000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b01000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000022c23429e46e7944d2918f2b368b799b11c417c1000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf38000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab50000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf00000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac2068400000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade) [staticcall] + │ │ │ ├─ [0] 0x241e507363d674c77a9930F31ea26BBc8857949c::468d24be(00000000000000000000000000000000000000000000000000000000000225990000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000001600000000000000000000000005ad3ded6fcc510324af8e2631717af6da5c8b5b0000000000000000000000009b959d27840a31988410ee69991bcf0110d61f02000000000000000000000000edcafc4ad8097c2012980a2a7087d74b86bddaf9000000000000000000000000ae53daac1bf3c4633d4921b8c3f8d579e757f5bc0000000000000000000000006aaabf51c5f6d2d93212cf7dad73d67afa0148d00000000000000000000000008eec4f1c0878f73e8e09c1be78ac1465cc16544d000000000000000000000000fc3e31519b551bd594235dd0ef014375a87c4e21000000000000000000000000ca54a1700e0403dcb531f8db4ae3847758b90b01000000000000000000000000e07d7e56588a6fd860c5073c70a099658c060f3d000000000000000000000000ee11d2016e9f2fae606b2f12986811f4abbe6215000000000000000000000000210744c64eea863cf0f972e5aebc683b98fb198400000000000000000000000022c23429e46e7944d2918f2b368b799b11c417c1000000000000000000000000f41af21f0a800dc4d86efb14ad46cfb9884fdf38000000000000000000000000bd4bf317da1928cc2f9f4da9006401f3944a0ab50000000000000000000000004e7ea047ec7e95c7a02cb117128b94ccdd8356bf00000000000000000000000032d619dc6188409cebbc52f921ab306f07db085b0000000000000000000000006e46924371d0e910769aabe0d867590deac2068400000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec100000000000000000000000061089875ff9e506ae78c7fe9f7c388416520e3860000000000000000000000002bddcaae1c6ccd53e436179b3fc07307ee6f3ef8000000000000000000000000ec702628f44c31acc56c3a59555be47e1f16eb1e00000000000000000000000052349003240770727900b06a3b3a90f5c0219ade) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 567922374429659000}()  + │ │ │ └─ ← () + │ │ ├─ emit MiningRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, recipient: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 567922374429659000 [5.679e17]) + │ │ ├─ [0] 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f::fallback{value: 3243046907432}()  + │ │ │ └─ ← () + │ │ ├─ emit FastFinalityRewardDistributed(consensusAddr: 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, recipient: 0x6133F1eE848df0dc45ABC3Eb92B7627f667Ae00f, amount: 3243046907432 [3.243e12]) + │ │ ├─ [0] ronin-mainnet.Staking::fallback{value: 2271689497718636000}()  + │ │ │ ├─ [0] Staking::receive() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::execRecordRewards([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2271689497718636000 [2.271e18], 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 19633 [1.963e4])  + │ │ │ ├─ [0] Staking::execRecordRewards([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], [0, 0, 0, 0, 0, 0, 0, 0, 0, 2271689497718636000 [2.271e18], 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 19633 [1.963e4]) [delegatecall] + │ │ │ │ ├─ emit PoolsUpdated(period: 19633 [1.963e4], poolAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], aRps: [93318776012821131 [9.331e16], 95431207368377915 [9.543e16], 94447227634309187 [9.444e16], 88199764422009158 [8.819e16], 67225014440065554 [6.722e16], 97687248220171528 [9.768e16], 97310118461513347 [9.731e16], 97239053863980682 [9.723e16], 93829791800558853 [9.382e16], 97216863765127740 [9.721e16], 99144578508031030 [9.914e16], 0, 66357646962488955 [6.635e16], 98467985935188233 [9.846e16], 93079390018252421 [9.307e16], 95695598399621230 [9.569e16], 94573200455822051 [9.457e16], 94805313929688703 [9.48e16], 98902645602159682 [9.89e16], 99019423310445352 [9.901e16], 99884465958207150 [9.988e16], 99093477004188600 [9.909e16]], shares: [7389521338803830815958367 [7.389e24], 7206104688158066377918315 [7.206e24], 7188192519136884811285316 [7.188e24], 7015615166482386890314536 [7.015e24], 6906329454934638339591820 [6.906e24], 6658249476098351649251578 [6.658e24], 6503464654044309321751691 [6.503e24], 6452840193432170260900982 [6.452e24], 5903862198409162686318766 [5.903e24], 5778443231451247986081315 [5.778e24], 5761256007661259154805105 [5.761e24], 492297328025346944058796 [4.922e23], 10190748510465558475599875 [1.019e25], 7047161408616008536704042 [7.047e24], 6993506329773885059751580 [6.993e24], 6881867025193447219128274 [6.881e24], 6781274466483249341608615 [6.781e24], 6718763510770822301943622 [6.718e24], 6396343690109009473179767 [6.396e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 5784491179033799937345365 [5.784e24]]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit StakingRewardDistributed(totalAmount: 2271689497718636000 [2.271e18], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], amounts: [0, 0, 0, 0, 0, 0, 0, 0, 0, 2271689497718636000 [2.271e18], 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]) + │ │ ├─ [0] ronin-mainnet.StakingVesting::receiveRON{value: 14266163345797568}()  + │ │ │ ├─ [0] StakingVesting::receiveRON() [delegatecall] + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ emit DeprecatedRewardRecycled(recipientAddr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816], amount: 14266163345797568 [1.426e16]) + │ │ ├─ [0] ronin-mainnet.SlashIndicator::updateCreditScores([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 19633 [1.963e4])  + │ │ │ ├─ [0] SlashIndicator::updateCreditScores([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 19633 [1.963e4]) [delegatecall] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::currentPeriodStartAtBlock() [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::currentPeriodStartAtBlock() [delegatecall] + │ │ │ │ │ │ └─ ← 28139200 [2.813e7] + │ │ │ │ │ └─ ← 28139200 [2.813e7] + │ │ │ │ ├─ [0] ronin-mainnet.RoninValidatorSet::checkManyJailed([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) [staticcall] + │ │ │ │ │ ├─ [0] RoninValidatorSet::checkManyJailed([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) [delegatecall] + │ │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ │ └─ ← [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false] + │ │ │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintainedInBlockRange([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7], 28139399 [2.813e7]) [staticcall] + │ │ │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintainedInBlockRange([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139200 [2.813e7], 28139399 [2.813e7]) [delegatecall] + │ │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ │ ├─ emit CreditScoresUpdated(validators: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], creditScores: [600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600, 50, 600, 600, 600, 600, 600, 600, 600, 600, 600, 600]) + │ │ │ │ └─ ← () + │ │ │ └─ ← () + │ │ ├─ [0] ronin-mainnet.Staking::waitingSecsToRevoke() [staticcall] + │ │ │ ├─ [0] Staking::waitingSecsToRevoke() [delegatecall] + │ │ │ │ └─ ← 604800 [6.048e5] + │ │ │ └─ ← 604800 [6.048e5] + │ │ ├─ [0] ronin-mainnet.Staking::minValidatorStakingAmount() [staticcall] + │ │ │ ├─ [0] Staking::minValidatorStakingAmount() [delegatecall] + │ │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ │ └─ ← 250000000000000000000000 [2.5e23] + │ │ ├─ [0] ronin-mainnet.Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManySelfStakings([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ │ └─ ← [250000500000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 2688534000000000000000000 [2.688e24], 329000000000000000000000 [3.29e23], 260000000000000000000000 [2.6e23], 470125853113645759960344 [4.701e23], 305571056759298973983540 [3.055e23], 275000000000000000000000 [2.75e23], 270000000000000000000000 [2.7e23], 250000000000000000000000 [2.5e23], 261000000000000000000000 [2.61e23], 299893154782022156590330 [2.998e23], 250000000000000000000000 [2.5e23], 320000000000000000000000 [3.2e23], 260000000000000000000000 [2.6e23], 372814245269722552080644 [3.728e23], 290136123474308260335830 [2.901e23], 270000000000000000000000 [2.7e23], 263085000000000000000000 [2.63e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 251000000000000000000000 [2.51e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23], 250000000000000000000000 [2.5e23]] + │ │ ├─ [0] ronin-mainnet.Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] Staking::getManyStakingTotals([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ │ └─ ← [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]] + │ │ ├─ [0] ronin-mainnet.RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [staticcall] + │ │ │ ├─ [0] RoninTrustedOrganization::getConsensusWeights([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1]) [delegatecall] + │ │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ │ └─ ← [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0] + │ │ ├─ [0] 0x0000000000000000000000000000000000000068::pickValidatorSet([0x52C0dcd83aa1999BA6c3b0324C8299E30207373C, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0x52349003240770727900b06a3B3a90f5c0219ADe, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0xd11D9842baBd5209b9B1155e46f5878c989125b7, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0xD7fEf73d95ccEdb26483fd3C6C48393e50708159, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x22C23429e46e7944D2918F2B368b799b11C417C1], [259350795425189357011923 [2.593e23], 10190748510465558475599875 [1.019e25], 5903862198409162686318766 [5.903e24], 5784491179033799937345365 [5.784e24], 6365969656770395353461256 [6.365e24], 5813275267619519038407189 [5.813e24], 7047161408616008536704042 [7.047e24], 5741644343444817691866731 [5.741e24], 6396343690109009473179767 [6.396e24], 250100197473474489963170 [2.501e23], 6718763510770822301943622 [6.718e24], 6658249476098351649251578 [6.658e24], 7206104688158066377918315 [7.206e24], 5778443231451247986081315 [5.778e24], 6452840193432170260900982 [6.452e24], 6993506329773885059751580 [6.993e24], 6781274466483249341608615 [6.781e24], 7015615166482386890314536 [7.015e24], 7389521338803830815958367 [7.389e24], 6881867025193447219128274 [6.881e24], 5761256007661259154805105 [5.761e24], 7188192519136884811285316 [7.188e24], 6503464654044309321751691 [6.503e24], 6906329454934638339591820 [6.906e24], 492297328025346944058796 [4.922e23]], [0, 100, 100, 100, 0, 100, 0, 100, 0, 0, 0, 100, 100, 100, 0, 0, 100, 0, 0, 100, 100, 0, 100, 0, 0], 22, 12) [staticcall] + │ │ │ └─ ← [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe] + │ │ ├─ emit ValidatorSetUpdated(period: 19634 [1.963e4], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ [0] ronin-mainnet.Maintenance::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139400 [2.813e7]) [staticcall] + │ │ │ ├─ [0] 0xB6a13e481f060c6a9130238EEb84a3c98A0A5FEa::checkManyMaintained([0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe], 28139400 [2.813e7]) [delegatecall] + │ │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ │ └─ ← 0x000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 + │ │ ├─ emit BlockProducerSetUpdated(period: 19634 [1.963e4], epoch: 140698 [1.406e5], consensusAddrs: [0x05ad3Ded6fcc510324Af8e2631717af6dA5C8B5B, 0x9B959D27840a31988410Ee69991BCF0110D61F02, 0xedCafC4Ad8097c2012980A2a7087d74B86bDDAf9, 0xae53daAC1BF3c4633d4921B8C3F8d579e757F5Bc, 0x6aaABf51C5F6D2D93212Cf7DAD73D67AFa0148d0, 0x8Eec4F1c0878F73E8e09C1be78aC1465Cc16544D, 0xFc3e31519B551bd594235dd0eF014375a87C4e21, 0xca54a1700e0403Dcb531f8dB4aE3847758b90B01, 0xE07D7e56588a6FD860c5073c70a099658C060F3D, 0xEE11d2016e9f2faE606b2F12986811F4abbe6215, 0x210744C64Eea863Cf0f972e5AEBC683b98fB1984, 0x22C23429e46e7944D2918F2B368b799b11C417C1, 0xf41Af21F0A800dc4d86efB14ad46cfb9884FDf38, 0xbD4bf317Da1928CC2f9f4DA9006401f3944A0Ab5, 0x4E7EA047EC7E95c7a02CB117128B94CCDd8356bf, 0x32D619Dc6188409CebbC52f921Ab306F07DB085b, 0x6E46924371d0e910769aaBE0d867590deAC20684, 0x47cfcb64f8EA44d6Ea7FAB32f13EFa2f8E65Eec1, 0x61089875fF9e506ae78C7FE9f7c388416520E386, 0x2bdDcaAE1C6cCd53E436179B3fc07307ee6f3eF8, 0xeC702628F44C31aCc56C3A59555be47e1f16eB1e, 0x52349003240770727900b06a3B3a90f5c0219ADe]) + │ │ ├─ emit WrappedUpEpoch(periodNumber: 19633 [1.963e4], epochNumber: 140697 [1.406e5], periodEnding: true) + │ │ └─ ← () + │ └─ ← () + └─ ← () + + +Script ran successfully. + +== Logs == + Skipping artifact generation for: MockPrecompile + Skipping artifact generation for: RoninValidatorSetLogic + Skipping artifact generation for: StakingLogic + Skipping artifact generation for: SlashIndicatorLogic + Skipping artifact generation for: RoninTrustedOrganizationLogic + Skipping artifact generation for: BridgeTrackingLogic + Skipping artifact generation for: StakingVestingLogic +========================== +Simulated On-chain Traces: + + [954922] → new MockPrecompile@0xBd770416a3345F91E4B34576cb804a576fa48EB1 + └─ ← 4176 bytes of code + + [4654308] → new RoninValidatorSet@0x5a443704dd4B594B382c22a083e2BD3090A6feF3 + ├─ emit Initialized(version: 255) + └─ ← 21229 bytes of code + + [112436] ronin-mainnet.RoninValidatorSet::upgradeToAndCall(RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3], 0x5cd8a76b)  + ├─ emit Upgraded(param0: RoninValidatorSet: [0x5a443704dd4B594B382c22a083e2BD3090A6feF3]) + ├─ [81147] RoninValidatorSet::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 9, addr: ronin-mainnet.Staking: [0x545edb750eB8769C868429BE9586F5857A768758]) + │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ ├─ emit ContractUpdated(contractType: 6, addr: ronin-mainnet.SlashIndicator: [0xEBFFF2b32fA0dF9C5C8C5d5AAa7e8b51d5207bA3]) + │ ├─ emit ContractUpdated(contractType: 7, addr: ronin-mainnet.StakingVesting: [0xC768423A2AE2B5024cB58F3d6449A8f5DB6D8816]) + │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [3579805] → new Staking@0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D + ├─ emit Initialized(version: 255) + └─ ← 16154 bytes of code + + [61800] ronin-mainnet.Staking::upgradeToAndCall(Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D], 0x5cd8a76b)  + ├─ emit Upgraded(param0: Staking: [0x47e9Fbef8C83A1714F1951F142132E6e90F5fa5D]) + ├─ [24636] Staking::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [3169482] → new SlashIndicator@0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA + ├─ emit Initialized(version: 255) + └─ ← 14346 bytes of code + + [113086] ronin-mainnet.SlashIndicator::upgradeToAndCall(SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA], 0x29b6eca9000000000000000000000000ae01a10c4bfa12205795d2421cdd78014d0b1fe6)  + ├─ emit Upgraded(param0: SlashIndicator: [0x8Be503bcdEd90ED42Eff31f56199399B2b0154CA]) + ├─ [66548] SlashIndicator::initializeV2(ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) [delegatecall] + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit ContractUpdated(contractType: 5, addr: ronin-mainnet.Maintenance: [0x6F45C1f8d84849D497C6C0Ac4c3842DC82f49894]) + │ ├─ emit ContractUpdated(contractType: 4, addr: ronin-mainnet.GovernanceAdmin: [0xAe01a10C4bfA12205795d2421cdd78014D0b1FE6]) + │ ├─ emit ContractUpdated(contractType: 10, addr: ronin-mainnet.RoninTrustedOrganization: [0x98D0230884448B3E2f09a177433D60fb1E19C090]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [1834812] → new RoninTrustedOrganization@0x47c5e40890bcE4a473A49D7501808b9633F29782 + └─ ← 8267 bytes of code + + [32595] ronin-mainnet.RoninTrustedOrganization::upgradeTo(RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782])  + ├─ emit Upgraded(param0: RoninTrustedOrganization: [0x47c5e40890bcE4a473A49D7501808b9633F29782]) + └─ ← () + + [1649050] → new BridgeTracking@0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f + ├─ emit Initialized(version: 255) + └─ ← 7274 bytes of code + + [91756] ronin-mainnet.BridgeTracking::upgradeToAndCall(BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f], 0x5cd8a76b)  + ├─ emit Upgraded(param0: BridgeTracking: [0x29b2440db4A256B0c1E6d3B4CDcaA68E2440A08f]) + ├─ [48032] BridgeTracking::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 2, addr: ronin-mainnet.RoninGatewayV3: [0x0CF8fF40a508bdBc39fBe1Bb679dCBa64E65C7Df]) + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + [831118] → new StakingVesting@0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9 + ├─ emit Initialized(version: 255) + └─ ← 3488 bytes of code + + [74901] ronin-mainnet.StakingVesting::upgradeToAndCall(StakingVesting: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9], 0x5cd8a76b)  + ├─ emit Upgraded(param0: StakingVesting: [0x3C368B86AF00565Df7a3897Cfa9195B9434A59f9]) + ├─ [33062] StakingVesting::initializeV2() [delegatecall] + │ ├─ emit ContractUpdated(contractType: 8, addr: ronin-mainnet.RoninValidatorSet: [0x617c5d73662282EA7FfD231E020eCa6D2B0D552f]) + │ ├─ emit Initialized(version: 2) + │ └─ ← () + └─ ← () + + +========================== + +Chain 2020 + +Estimated gas price: 20 gwei + +Estimated total gas used for script: 22308086 + +Estimated amount required: 0.44616172 ETH + +========================== + +SIMULATION COMPLETE. To broadcast these transactions, add --broadcast and wallet configuration(s) to the previous command. See forge script --help for more. + +Transactions saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/broadcast/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol/2020/dry-run/run-latest.json + +Sensitive values saved to: /Users/baonq/Projects/Axie/ronin-dpos-contracts/cache_foundry/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol/2020/dry-run/run-latest.json + diff --git a/logs/storage_layout.log b/logs/storage_layout.log index 6b9d4f756..40a601917 100644 --- a/logs/storage_layout.log +++ b/logs/storage_layout.log @@ -16,6 +16,7 @@ BridgeReward:_initialized (storage_slot: 0) (offset: 0) (type: t_uint8) (numberO BridgeReward:_initializing (storage_slot: 0) (offset: 1) (type: t_bool) (numberOfBytes: 1) BridgeSlash:_initialized (storage_slot: 0) (offset: 0) (type: t_uint8) (numberOfBytes: 1) BridgeSlash:_initializing (storage_slot: 0) (offset: 1) (type: t_bool) (numberOfBytes: 1) +BridgeSlash:_startedAtPeriod (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) BridgeTracking:______deprecatedBridge (storage_slot: 0) (offset: 0) (type: t_address) (numberOfBytes: 20) BridgeTracking:______deprecatedValidator (storage_slot: 1) (offset: 0) (type: t_address) (numberOfBytes: 20) BridgeTracking:_initialized (storage_slot: 1) (offset: 20) (type: t_uint8) (numberOfBytes: 1) @@ -221,13 +222,13 @@ FastFinalityTracking:_tracker (storage_slot: 1) (offset: 0) (type: t_mapping(t_u FastFinalityTracking:_latestTrackingBlock (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) Forwarder:_roles (storage_slot: 0) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) Forwarder:_roleMembers (storage_slot: 1) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) -GatewayV2:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) -GatewayV2:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -GatewayV2:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -GatewayV2:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) -GatewayV2:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -GatewayV2:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) -GatewayV2:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) +GatewayV3:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) +GatewayV3:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +GatewayV3:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +GatewayV3:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) +GatewayV3:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +GatewayV3:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) +GatewayV3:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) GlobalCoreGovernance:round (storage_slot: 0) (offset: 0) (type: t_mapping(t_uint256t_uint256)) (numberOfBytes: 32) GlobalCoreGovernance:vote (storage_slot: 1) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(ProposalVote)_storage))) (numberOfBytes: 32) GlobalCoreGovernance:_proposalExpiryDuration (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) @@ -275,35 +276,35 @@ MainchainBridgeManager:round (storage_slot: 0) (offset: 0) (type: t_mapping(t_ui MainchainBridgeManager:vote (storage_slot: 1) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(ProposalVote)_storage))) (numberOfBytes: 32) MainchainBridgeManager:_proposalExpiryDuration (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) MainchainBridgeManager:_targetOptionsMap (storage_slot: 3) (offset: 0) (type: t_mapping(t_enum(TargetOption)t_address)) (numberOfBytes: 32) -MainchainGatewayV2:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) -MainchainGatewayV2:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) -MainchainGatewayV2:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) -MainchainGatewayV2:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) -MainchainGatewayV2:_highTierVWNum (storage_slot: 55) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:_highTierVWDenom (storage_slot: 56) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:highTierThreshold (storage_slot: 57) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:lockedThreshold (storage_slot: 58) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:unlockFeePercentages (storage_slot: 59) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:dailyWithdrawalLimit (storage_slot: 60) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:lastSyncedWithdrawal (storage_slot: 61) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:lastDateSynced (storage_slot: 62) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MainchainGatewayV2:______gap (storage_slot: 63) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) -MainchainGatewayV2:_initialized (storage_slot: 113) (offset: 0) (type: t_uint8) (numberOfBytes: 1) -MainchainGatewayV2:_initializing (storage_slot: 113) (offset: 1) (type: t_bool) (numberOfBytes: 1) -MainchainGatewayV2:_roles (storage_slot: 114) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) -MainchainGatewayV2:_roleMembers (storage_slot: 115) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) -MainchainGatewayV2:wrappedNativeToken (storage_slot: 116) (offset: 0) (type: t_contract(IWETH)) (numberOfBytes: 20) -MainchainGatewayV2:roninChainId (storage_slot: 117) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:depositCount (storage_slot: 118) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:_domainSeparator (storage_slot: 119) (offset: 0) (type: t_bytes32) (numberOfBytes: 32) -MainchainGatewayV2:_roninToken (storage_slot: 120) (offset: 0) (type: t_mapping(t_addresst_struct(MappedToken)_storage)) (numberOfBytes: 32) -MainchainGatewayV2:withdrawalHash (storage_slot: 121) (offset: 0) (type: t_mapping(t_uint256t_bytes32)) (numberOfBytes: 32) -MainchainGatewayV2:withdrawalLocked (storage_slot: 122) (offset: 0) (type: t_mapping(t_uint256t_bool)) (numberOfBytes: 32) -MainchainGatewayV2:______deprecatedBridgeOperatorAddedBlock (storage_slot: 123) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MainchainGatewayV2:______deprecatedBridgeOperators (storage_slot: 124) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) +MainchainGatewayV3:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) +MainchainGatewayV3:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) +MainchainGatewayV3:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) +MainchainGatewayV3:_highTierVWNum (storage_slot: 55) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:_highTierVWDenom (storage_slot: 56) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:highTierThreshold (storage_slot: 57) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:lockedThreshold (storage_slot: 58) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:unlockFeePercentages (storage_slot: 59) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:dailyWithdrawalLimit (storage_slot: 60) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:lastSyncedWithdrawal (storage_slot: 61) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:lastDateSynced (storage_slot: 62) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MainchainGatewayV3:______gap (storage_slot: 63) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) +MainchainGatewayV3:_initialized (storage_slot: 113) (offset: 0) (type: t_uint8) (numberOfBytes: 1) +MainchainGatewayV3:_initializing (storage_slot: 113) (offset: 1) (type: t_bool) (numberOfBytes: 1) +MainchainGatewayV3:_roles (storage_slot: 114) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) +MainchainGatewayV3:_roleMembers (storage_slot: 115) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) +MainchainGatewayV3:wrappedNativeToken (storage_slot: 116) (offset: 0) (type: t_contract(IWETH)) (numberOfBytes: 20) +MainchainGatewayV3:roninChainId (storage_slot: 117) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:depositCount (storage_slot: 118) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:_domainSeparator (storage_slot: 119) (offset: 0) (type: t_bytes32) (numberOfBytes: 32) +MainchainGatewayV3:_roninToken (storage_slot: 120) (offset: 0) (type: t_mapping(t_addresst_struct(MappedToken)_storage)) (numberOfBytes: 32) +MainchainGatewayV3:withdrawalHash (storage_slot: 121) (offset: 0) (type: t_mapping(t_uint256t_bytes32)) (numberOfBytes: 32) +MainchainGatewayV3:withdrawalLocked (storage_slot: 122) (offset: 0) (type: t_mapping(t_uint256t_bool)) (numberOfBytes: 32) +MainchainGatewayV3:______deprecatedBridgeOperatorAddedBlock (storage_slot: 123) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MainchainGatewayV3:______deprecatedBridgeOperators (storage_slot: 124) (offset: 0) (type: t_uint256) (numberOfBytes: 32) Maintenance:______deprecatedValidator (storage_slot: 0) (offset: 0) (type: t_address) (numberOfBytes: 20) Maintenance:_initialized (storage_slot: 0) (offset: 20) (type: t_uint8) (numberOfBytes: 1) Maintenance:_initializing (storage_slot: 0) (offset: 21) (type: t_bool) (numberOfBytes: 1) @@ -323,6 +324,7 @@ MockBridgeReward:_initialized (storage_slot: 0) (offset: 0) (type: t_uint8) (num MockBridgeReward:_initializing (storage_slot: 0) (offset: 1) (type: t_bool) (numberOfBytes: 1) MockBridgeSlash:_initialized (storage_slot: 0) (offset: 0) (type: t_uint8) (numberOfBytes: 1) MockBridgeSlash:_initializing (storage_slot: 0) (offset: 1) (type: t_bool) (numberOfBytes: 1) +MockBridgeSlash:_startedAtPeriod (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) MockForwarderTarget:owner (storage_slot: 0) (offset: 0) (type: t_address) (numberOfBytes: 20) MockForwarderTarget:data (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) MockGatewayForTracking:______deprecatedBridgeTracking (storage_slot: 0) (offset: 0) (type: t_address) (numberOfBytes: 20) @@ -341,32 +343,32 @@ MockRoninBridgeManager:round (storage_slot: 0) (offset: 0) (type: t_mapping(t_ui MockRoninBridgeManager:vote (storage_slot: 1) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(ProposalVote)_storage))) (numberOfBytes: 32) MockRoninBridgeManager:_proposalExpiryDuration (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) MockRoninBridgeManager:_targetOptionsMap (storage_slot: 3) (offset: 0) (type: t_mapping(t_enum(TargetOption)t_address)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) -MockRoninGatewayV2Extended:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MockRoninGatewayV2Extended:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) -MockRoninGatewayV2Extended:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MockRoninGatewayV2Extended:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) -MockRoninGatewayV2Extended:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) -MockRoninGatewayV2Extended:_initialized (storage_slot: 55) (offset: 0) (type: t_uint8) (numberOfBytes: 1) -MockRoninGatewayV2Extended:_initializing (storage_slot: 55) (offset: 1) (type: t_bool) (numberOfBytes: 1) -MockRoninGatewayV2Extended:minimumThreshold (storage_slot: 56) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:______gap (storage_slot: 57) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) -MockRoninGatewayV2Extended:_roles (storage_slot: 107) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_roleMembers (storage_slot: 108) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:withdrawalMigrated (storage_slot: 109) (offset: 0) (type: t_bool) (numberOfBytes: 1) -MockRoninGatewayV2Extended:withdrawalCount (storage_slot: 110) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MockRoninGatewayV2Extended:depositVote (storage_slot: 111) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(Vote)_storage))) (numberOfBytes: 32) -MockRoninGatewayV2Extended:mainchainWithdrewVote (storage_slot: 112) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:withdrawal (storage_slot: 113) (offset: 0) (type: t_mapping(t_uint256t_struct(Receipt)_storage)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_withdrawalSig (storage_slot: 114) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_addresst_bytes_storage))) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_mainchainToken (storage_slot: 115) (offset: 0) (type: t_mapping(t_addresst_mapping(t_uint256t_struct(MappedToken)_storage))) (numberOfBytes: 32) -MockRoninGatewayV2Extended:____deprecated0 (storage_slot: 116) (offset: 0) (type: t_address) (numberOfBytes: 20) -MockRoninGatewayV2Extended:____deprecated1 (storage_slot: 117) (offset: 0) (type: t_address) (numberOfBytes: 20) -MockRoninGatewayV2Extended:withdrawalStatVote (storage_slot: 118) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) -MockRoninGatewayV2Extended:____deprecated2 (storage_slot: 119) (offset: 0) (type: t_address) (numberOfBytes: 20) -MockRoninGatewayV2Extended:_trustedNum (storage_slot: 120) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -MockRoninGatewayV2Extended:_trustedDenom (storage_slot: 121) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) +MockRoninGatewayV3Extended:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) +MockRoninGatewayV3Extended:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) +MockRoninGatewayV3Extended:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) +MockRoninGatewayV3Extended:_initialized (storage_slot: 55) (offset: 0) (type: t_uint8) (numberOfBytes: 1) +MockRoninGatewayV3Extended:_initializing (storage_slot: 55) (offset: 1) (type: t_bool) (numberOfBytes: 1) +MockRoninGatewayV3Extended:minimumThreshold (storage_slot: 56) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:______gap (storage_slot: 57) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) +MockRoninGatewayV3Extended:_roles (storage_slot: 107) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_roleMembers (storage_slot: 108) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:___deprecated4 (storage_slot: 109) (offset: 0) (type: t_bool) (numberOfBytes: 1) +MockRoninGatewayV3Extended:withdrawalCount (storage_slot: 110) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:depositVote (storage_slot: 111) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(Vote)_storage))) (numberOfBytes: 32) +MockRoninGatewayV3Extended:mainchainWithdrewVote (storage_slot: 112) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:withdrawal (storage_slot: 113) (offset: 0) (type: t_mapping(t_uint256t_struct(Receipt)_storage)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_withdrawalSig (storage_slot: 114) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_addresst_bytes_storage))) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_mainchainToken (storage_slot: 115) (offset: 0) (type: t_mapping(t_addresst_mapping(t_uint256t_struct(MappedToken)_storage))) (numberOfBytes: 32) +MockRoninGatewayV3Extended:____deprecated0 (storage_slot: 116) (offset: 0) (type: t_address) (numberOfBytes: 20) +MockRoninGatewayV3Extended:____deprecated1 (storage_slot: 117) (offset: 0) (type: t_address) (numberOfBytes: 20) +MockRoninGatewayV3Extended:withdrawalStatVote (storage_slot: 118) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) +MockRoninGatewayV3Extended:____deprecated2 (storage_slot: 119) (offset: 0) (type: t_address) (numberOfBytes: 20) +MockRoninGatewayV3Extended:_trustedNum (storage_slot: 120) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +MockRoninGatewayV3Extended:_trustedDenom (storage_slot: 121) (offset: 0) (type: t_uint256) (numberOfBytes: 32) MockRoninValidatorSetExtended:_initialized (storage_slot: 0) (offset: 0) (type: t_uint8) (numberOfBytes: 1) MockRoninValidatorSetExtended:_initializing (storage_slot: 0) (offset: 1) (type: t_bool) (numberOfBytes: 1) MockRoninValidatorSetExtended:_numberOfBlocksInEpoch (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) @@ -553,32 +555,32 @@ RoninBridgeManager:round (storage_slot: 0) (offset: 0) (type: t_mapping(t_uint25 RoninBridgeManager:vote (storage_slot: 1) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(ProposalVote)_storage))) (numberOfBytes: 32) RoninBridgeManager:_proposalExpiryDuration (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) RoninBridgeManager:_targetOptionsMap (storage_slot: 3) (offset: 0) (type: t_mapping(t_enum(TargetOption)t_address)) (numberOfBytes: 32) -RoninGatewayV2:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) -RoninGatewayV2:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -RoninGatewayV2:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -RoninGatewayV2:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) -RoninGatewayV2:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -RoninGatewayV2:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) -RoninGatewayV2:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) -RoninGatewayV2:_initialized (storage_slot: 55) (offset: 0) (type: t_uint8) (numberOfBytes: 1) -RoninGatewayV2:_initializing (storage_slot: 55) (offset: 1) (type: t_bool) (numberOfBytes: 1) -RoninGatewayV2:minimumThreshold (storage_slot: 56) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) -RoninGatewayV2:______gap (storage_slot: 57) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) -RoninGatewayV2:_roles (storage_slot: 107) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) -RoninGatewayV2:_roleMembers (storage_slot: 108) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) -RoninGatewayV2:withdrawalMigrated (storage_slot: 109) (offset: 0) (type: t_bool) (numberOfBytes: 1) -RoninGatewayV2:withdrawalCount (storage_slot: 110) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -RoninGatewayV2:depositVote (storage_slot: 111) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(Vote)_storage))) (numberOfBytes: 32) -RoninGatewayV2:mainchainWithdrewVote (storage_slot: 112) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) -RoninGatewayV2:withdrawal (storage_slot: 113) (offset: 0) (type: t_mapping(t_uint256t_struct(Receipt)_storage)) (numberOfBytes: 32) -RoninGatewayV2:_withdrawalSig (storage_slot: 114) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_addresst_bytes_storage))) (numberOfBytes: 32) -RoninGatewayV2:_mainchainToken (storage_slot: 115) (offset: 0) (type: t_mapping(t_addresst_mapping(t_uint256t_struct(MappedToken)_storage))) (numberOfBytes: 32) -RoninGatewayV2:____deprecated0 (storage_slot: 116) (offset: 0) (type: t_address) (numberOfBytes: 20) -RoninGatewayV2:____deprecated1 (storage_slot: 117) (offset: 0) (type: t_address) (numberOfBytes: 20) -RoninGatewayV2:withdrawalStatVote (storage_slot: 118) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) -RoninGatewayV2:____deprecated2 (storage_slot: 119) (offset: 0) (type: t_address) (numberOfBytes: 20) -RoninGatewayV2:_trustedNum (storage_slot: 120) (offset: 0) (type: t_uint256) (numberOfBytes: 32) -RoninGatewayV2:_trustedDenom (storage_slot: 121) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:_paused (storage_slot: 0) (offset: 0) (type: t_bool) (numberOfBytes: 1) +RoninGatewayV3:_num (storage_slot: 1) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:_denom (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:______deprecated (storage_slot: 3) (offset: 0) (type: t_address) (numberOfBytes: 20) +RoninGatewayV3:nonce (storage_slot: 4) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:emergencyPauser (storage_slot: 5) (offset: 0) (type: t_address) (numberOfBytes: 20) +RoninGatewayV3:______gap (storage_slot: 6) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1568) +RoninGatewayV3:_initialized (storage_slot: 55) (offset: 0) (type: t_uint8) (numberOfBytes: 1) +RoninGatewayV3:_initializing (storage_slot: 55) (offset: 1) (type: t_bool) (numberOfBytes: 1) +RoninGatewayV3:minimumThreshold (storage_slot: 56) (offset: 0) (type: t_mapping(t_addresst_uint256)) (numberOfBytes: 32) +RoninGatewayV3:______gap (storage_slot: 57) (offset: 0) (type: t_array(t_uint256)_storage) (numberOfBytes: 1600) +RoninGatewayV3:_roles (storage_slot: 107) (offset: 0) (type: t_mapping(t_bytes32t_struct(RoleData)_storage)) (numberOfBytes: 32) +RoninGatewayV3:_roleMembers (storage_slot: 108) (offset: 0) (type: t_mapping(t_bytes32t_struct(AddressSet)_storage)) (numberOfBytes: 32) +RoninGatewayV3:___deprecated4 (storage_slot: 109) (offset: 0) (type: t_bool) (numberOfBytes: 1) +RoninGatewayV3:withdrawalCount (storage_slot: 110) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:depositVote (storage_slot: 111) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(Vote)_storage))) (numberOfBytes: 32) +RoninGatewayV3:mainchainWithdrewVote (storage_slot: 112) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) +RoninGatewayV3:withdrawal (storage_slot: 113) (offset: 0) (type: t_mapping(t_uint256t_struct(Receipt)_storage)) (numberOfBytes: 32) +RoninGatewayV3:_withdrawalSig (storage_slot: 114) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_addresst_bytes_storage))) (numberOfBytes: 32) +RoninGatewayV3:_mainchainToken (storage_slot: 115) (offset: 0) (type: t_mapping(t_addresst_mapping(t_uint256t_struct(MappedToken)_storage))) (numberOfBytes: 32) +RoninGatewayV3:____deprecated0 (storage_slot: 116) (offset: 0) (type: t_address) (numberOfBytes: 20) +RoninGatewayV3:____deprecated1 (storage_slot: 117) (offset: 0) (type: t_address) (numberOfBytes: 20) +RoninGatewayV3:withdrawalStatVote (storage_slot: 118) (offset: 0) (type: t_mapping(t_uint256t_struct(Vote)_storage)) (numberOfBytes: 32) +RoninGatewayV3:____deprecated2 (storage_slot: 119) (offset: 0) (type: t_address) (numberOfBytes: 20) +RoninGatewayV3:_trustedNum (storage_slot: 120) (offset: 0) (type: t_uint256) (numberOfBytes: 32) +RoninGatewayV3:_trustedDenom (storage_slot: 121) (offset: 0) (type: t_uint256) (numberOfBytes: 32) RoninGovernanceAdmin:round (storage_slot: 0) (offset: 0) (type: t_mapping(t_uint256t_uint256)) (numberOfBytes: 32) RoninGovernanceAdmin:vote (storage_slot: 1) (offset: 0) (type: t_mapping(t_uint256t_mapping(t_uint256t_struct(ProposalVote)_storage))) (numberOfBytes: 32) RoninGovernanceAdmin:_proposalExpiryDuration (storage_slot: 2) (offset: 0) (type: t_uint256) (numberOfBytes: 32) diff --git a/package.json b/package.json index ab1642f3c..2ed156f9f 100644 --- a/package.json +++ b/package.json @@ -51,7 +51,7 @@ "hardhat-gas-reporter": "^1.0.8", "hardhat-storage-layout": "^0.1.7", "husky": "^7.0.4", - "lint-staged": ">=10", + "lint-staged": "14.0.1", "prettier": "^2.5.1", "prettier-plugin-solidity": "^1.0.0-beta.19", "rimraf": "^3.0.2", diff --git a/remappings.txt b/remappings.txt index ff1d98beb..881c5ed5b 100644 --- a/remappings.txt +++ b/remappings.txt @@ -5,4 +5,5 @@ hardhat/=./node_modules/hardhat/ @ronin/contracts/=./contracts/ @ronin/test/=./test/foundry/ @prb/test/=lib/prb-test/src/ -@prb/math/=lib/prb-math/ \ No newline at end of file +@prb/math/=lib/prb-math/ +solady/=lib/solady/src \ No newline at end of file diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_Base.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_Base.s.sol new file mode 100644 index 000000000..5c33634c6 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_Base.s.sol @@ -0,0 +1,191 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { RoninGovernanceAdmin } from "@ronin/contracts/ronin/RoninGovernanceAdmin.sol"; +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { MainchainGatewayV3 } from "@ronin/contracts/mainchain/MainchainGatewayV3.sol"; +import { Staking } from "@ronin/contracts/ronin/staking/Staking.sol"; +import { Maintenance } from "@ronin/contracts/ronin/Maintenance.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { SlashIndicator } from "@ronin/contracts/ronin/slash-indicator/SlashIndicator.sol"; +import { RoninTrustedOrganization } from "@ronin/contracts/multi-chains/RoninTrustedOrganization.sol"; +import { Staking } from "@ronin/contracts/ronin/staking/Staking.sol"; +import { StakingVesting } from "@ronin/contracts/ronin/StakingVesting.sol"; +import { FastFinalityTracking } from "@ronin/contracts/ronin/fast-finality/FastFinalityTracking.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { MockPrecompile } from "@ronin/contracts/mocks/MockPrecompile.sol"; +import { MappedTokenConsumer } from "@ronin/contracts/interfaces/consumers/MappedTokenConsumer.sol"; +import { Token } from "@ronin/contracts/libraries/Token.sol"; +import { Transfer } from "@ronin/contracts/libraries/Transfer.sol"; +import { console2, BaseDeploy, ContractKey, Network } from "../BaseDeploy.s.sol"; +import { RoninValidatorSet, RoninValidatorSetTimedMigratorUpgrade } from "./contracts/RoninValidatorSetTimedMigratorUpgrade.s.sol"; +import { ProfileDeploy } from "./contracts/ProfileDeploy.s.sol"; +import { NotifiedMigratorUpgrade } from "./contracts/NotifiedMigratorUpgrade.s.sol"; + +contract Simulation__20231003_UpgradeREP002AndREP003_Base is BaseDeploy, MappedTokenConsumer { + using Transfer for *; + + Staking internal _staking; + RoninGatewayV3 internal _roninGateway; + BridgeTracking internal _bridgeTracking; + SlashIndicator internal _slashIndicator; + RoninValidatorSet internal _validatorSet; + StakingVesting internal _stakingVesting; + RoninTrustedOrganization internal _trustedOrgs; + FastFinalityTracking internal _fastFinalityTracking; + RoninGovernanceAdmin internal _roninGovernanceAdmin; + + // new contracts + BridgeSlash internal _bridgeSlash; + BridgeReward internal _bridgeReward; + RoninBridgeManager internal _roninBridgeManager; + + uint256 _depositCount; + + function _injectDependencies() internal virtual override { + _setDependencyDeployScript(ContractKey.Profile, new ProfileDeploy()); + } + + function _hookSetDepositCount() internal pure virtual returns (uint256) { + return 42127; // fork-block-number 28139075 + } + + function _hookPrankOperator() internal virtual returns (address) { + return makeAccount("detach-operator-1").addr; + } + + function _afterDepositForOnlyOnRonin(Transfer.Receipt memory) internal virtual {} + + function run() public virtual trySetUp { + { + address mockPrecompile = _deployLogic(ContractKey.MockPrecompile); + vm.etch(address(0x68), mockPrecompile.code); + vm.makePersistent(address(0x68)); + } + + _staking = Staking(_config.getAddressFromCurrentNetwork(ContractKey.Staking)); + _roninGateway = RoninGatewayV3(_config.getAddressFromCurrentNetwork(ContractKey.RoninGatewayV3)); + _bridgeTracking = BridgeTracking(_config.getAddressFromCurrentNetwork(ContractKey.BridgeTracking)); + _slashIndicator = SlashIndicator(_config.getAddressFromCurrentNetwork(ContractKey.SlashIndicator)); + _stakingVesting = StakingVesting(_config.getAddressFromCurrentNetwork(ContractKey.StakingVesting)); + _validatorSet = RoninValidatorSet(_config.getAddressFromCurrentNetwork(ContractKey.RoninValidatorSet)); + _trustedOrgs = RoninTrustedOrganization(_config.getAddressFromCurrentNetwork(ContractKey.RoninTrustedOrganization)); + _fastFinalityTracking = FastFinalityTracking( + _config.getAddressFromCurrentNetwork(ContractKey.FastFinalityTracking) + ); + _roninGovernanceAdmin = RoninGovernanceAdmin(_config.getAddressFromCurrentNetwork(ContractKey.GovernanceAdmin)); + _roninBridgeManager = RoninBridgeManager(_config.getAddressFromCurrentNetwork(ContractKey.RoninBridgeManager)); + + _depositCount = _hookSetDepositCount(); + } + + function _depositForOnBothChain(string memory userName) internal { + Account memory user = makeAccount(userName); + vm.makePersistent(user.addr); + vm.deal(user.addr, 1000 ether); + + Transfer.Request memory request = Transfer.Request( + user.addr, + address(0), + Token.Info(Token.Standard.ERC20, 0, 1 ether) + ); + + MainchainGatewayV3 mainchainGateway = MainchainGatewayV3( + _config.getAddress(Network.EthMainnet, ContractKey.MainchainGatewayV3) + ); + + // switch rpc to eth mainnet + _config.switchTo(Network.EthMainnet); + + address weth = address(mainchainGateway.wrappedNativeToken()); + MappedTokenConsumer.MappedToken memory token = mainchainGateway.getRoninToken(weth); + + Transfer.Receipt memory receipt = Transfer.Request(user.addr, weth, request.info).into_deposit_receipt( + user.addr, + mainchainGateway.depositCount(), + token.tokenAddr, + 2020 // ronin-mainnet chainId + ); + + vm.prank(user.addr); + mainchainGateway.requestDepositFor{ value: 1 ether }(request); + + // switch rpc to ronin mainnet + _config.switchTo(Network.RoninMainnet); + + address operator = _hookPrankOperator(); + vm.label(operator, "bridge-operator"); + vm.prank(operator); + _roninGateway.depositFor(receipt); + } + + function _depositForOnlyOnRonin(string memory userName) internal { + Account memory user = makeAccount(userName); + vm.makePersistent(user.addr); + vm.deal(user.addr, 1000 ether); + + Transfer.Request memory request = Transfer.Request( + user.addr, + address(0), + Token.Info(Token.Standard.ERC20, 0, 1 ether) + ); + + address weth = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2; + address roninToken = 0xc99a6A985eD2Cac1ef41640596C5A5f9F4E19Ef5; + Transfer.Receipt memory receipt = Transfer.Request(user.addr, weth, request.info).into_deposit_receipt( + user.addr, + _depositCount++, + roninToken, + 2020 // ronin-mainnet chainId + ); + receipt.mainchain.chainId = 1; + + vm.prank(_hookPrankOperator()); + _roninGateway.depositFor(receipt); + + _afterDepositForOnlyOnRonin(receipt); + } + + function _dummySwitchNetworks() internal { + _config.switchTo(Network.EthMainnet); + _config.switchTo(Network.RoninMainnet); + } + + function _wrapUpEpoch() internal { + vm.prank(block.coinbase); + _validatorSet.wrapUpEpoch(); + } + + function _fastForwardToNextDay() internal { + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + uint256 numberOfBlocksInEpoch = _validatorSet.numberOfBlocksInEpoch(); + + uint256 epochEndingBlockNumber = block.number + + (numberOfBlocksInEpoch - 1) - + (block.number % numberOfBlocksInEpoch); + uint256 nextDayTimestamp = block.timestamp + 1 days; + + // fast forward to next day + vm.warp(nextDayTimestamp); + vm.roll(epochEndingBlockNumber); + } + + function _fastForwardToNextEpoch() internal { + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + uint256 numberOfBlocksInEpoch = _validatorSet.numberOfBlocksInEpoch(); + + uint256 epochEndingBlockNumber = block.number + + (numberOfBlocksInEpoch - 1) - + (block.number % numberOfBlocksInEpoch); + + // fast forward to next day + vm.roll(epochEndingBlockNumber); + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_ETH.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_ETH.s.sol new file mode 100644 index 000000000..a7d6f1323 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_ETH.s.sol @@ -0,0 +1,32 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { RoninGovernanceAdmin } from "@ronin/contracts/ronin/RoninGovernanceAdmin.sol"; +import { MainchainBridgeManager } from "@ronin/contracts/mainchain/MainchainBridgeManager.sol"; +import { MainchainGatewayV3 } from "@ronin/contracts/mainchain/MainchainGatewayV3.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +import { MappedTokenConsumer } from "@ronin/contracts/interfaces/consumers/MappedTokenConsumer.sol"; +import { console2, BaseDeploy, ContractKey, Network } from "../BaseDeploy.s.sol"; + +contract Simulation__20231003_UpgradeREP002AndREP003_ETH is BaseDeploy, MappedTokenConsumer { + RoninGovernanceAdmin internal _mainchainGovernanceAdmin; + MainchainGatewayV3 internal _mainchainGatewayV3; + MainchainBridgeManager internal _mainchainBridgeManager; + + function run() public virtual trySetUp { + _mainchainGatewayV3 = MainchainGatewayV3(_config.getAddressFromCurrentNetwork(ContractKey.MainchainGatewayV3)); + _mainchainBridgeManager = MainchainBridgeManager( + _config.getAddressFromCurrentNetwork(ContractKey.MainchainBridgeManager) + ); + _mainchainGovernanceAdmin = RoninGovernanceAdmin(_config.getAddressFromCurrentNetwork(ContractKey.GovernanceAdmin)); + + _upgradeProxy( + ContractKey.MainchainGatewayV3, + abi.encodeCall(MainchainGatewayV3.initializeV2, (address(_mainchainBridgeManager))) + ); + vm.startPrank(address(_mainchainGovernanceAdmin)); + TransparentUpgradeableProxyV2(payable(address(_mainchainGatewayV3))).changeAdmin(address(_mainchainBridgeManager)); + vm.stopPrank(); + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON.s.sol new file mode 100644 index 000000000..73ecbd189 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON.s.sol @@ -0,0 +1,70 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import "./20231003_REP002AndREP003_Base.s.sol"; + +contract Simulation__20231003_UpgradeREP002AndREP003_RON is Simulation__20231003_UpgradeREP002AndREP003_Base { + function run() public virtual override trySetUp { + super.run(); + + _upgradeDPoSContracts(); + + // test `RoninGatewayV3` functionality + _depositForOnBothChain("before-upgrade-user"); + + // trigger conditional migration + _fastForwardToNextDay(); + _wrapUpEpoch(); + + // // test `RoninValidatorSet` functionality + // _fastForwardToNextDay(); + // _wrapUpEpoch(); + + // // test `RoninGatewayV3` functionality + // _depositForOnBothChain("after-upgrade-user"); + } + + function _upgradeDPoSContracts() internal { + { + // upgrade `RoninValidatorSet` to `RoninValidatorSetTimedMigrator` + // bump `RoninValidatorSet` to V2, V3 + new RoninValidatorSetTimedMigratorUpgrade().run(); + } + + { + // upgrade `Staking` to `NotifiedMigrator` + // bump `Staking` to V2 + bytes[] memory stakingCallDatas = new bytes[](1); + stakingCallDatas[0] = abi.encodeCall(Staking.initializeV2, ()); + Staking(new NotifiedMigratorUpgrade().run(ContractKey.Staking, stakingCallDatas)); + } + + { + // upgrade `SlashIndicator` to `NotifiedMigrator` + // bump `SlashIndicator` to V2, V3 + bytes[] memory slashIndicatorDatas = new bytes[](2); + slashIndicatorDatas[0] = abi.encodeCall( + SlashIndicator.initializeV2, + (_config.getAddressFromCurrentNetwork(ContractKey.GovernanceAdmin)) + ); + slashIndicatorDatas[1] = abi.encodeCall(SlashIndicator.initializeV3, (loadContractOrDeploy(ContractKey.Profile))); + new NotifiedMigratorUpgrade().run(ContractKey.SlashIndicator, slashIndicatorDatas); + } + + { + // upgrade `RoninTrustedOrganization` + bytes[] memory emptyCallDatas; + new NotifiedMigratorUpgrade().run(ContractKey.RoninTrustedOrganization, emptyCallDatas); + } + + { + // upgrade `BridgeTracking` to `NotifiedMigrator` + // bump `BridgeTracking` to V2 + bytes[] memory bridgeTrackingDatas = new bytes[](1); + bridgeTrackingDatas[0] = abi.encodeCall(BridgeTracking.initializeV2, ()); + _bridgeTracking = BridgeTracking( + new NotifiedMigratorUpgrade().run(ContractKey.BridgeTracking, bridgeTrackingDatas) + ); + } + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional.s.sol new file mode 100644 index 000000000..8ef3b2e89 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional.s.sol @@ -0,0 +1,82 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_Base.s.sol"; + +contract Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional is + Simulation__20231003_UpgradeREP002AndREP003_Base +{ + function run() public virtual override trySetUp { + super.run(); + + _upgradeDPoSContracts(); + + // // test `RoninGatewayV3` functionality + // _depositFor("before-upgrade-user"); + + // trigger conditional migration + _fastForwardToNextDay(); + _wrapUpEpoch(); + + // // test `RoninValidatorSet` functionality + // _fastForwardToNextDay(); + // _wrapUpEpoch(); + + // // test `RoninGatewayV3` functionality + // _depositFor("after-upgrade-user"); + } + + function _upgradeDPoSContracts() internal { + console2.log("> ", StdStyle.blue("_upgradeDPoSContracts"), "..."); + + { + // upgrade `RoninValidatorSet` + _upgradeProxy(ContractKey.RoninValidatorSet, abi.encodeCall(RoninValidatorSet.initializeV2, ())); + // bump `RoninValidatorSet` to V2, V3 + _validatorSet.initializeV3(loadContractOrDeploy(ContractKey.FastFinalityTracking)); + } + + { + // upgrade `Staking` + // bump `Staking` to V2 + _upgradeProxy(ContractKey.Staking, abi.encodeCall(Staking.initializeV2, ())); + } + + { + // upgrade `SlashIndicator` + // bump `SlashIndicator` to V2, V3 + + _upgradeProxy( + ContractKey.SlashIndicator, + abi.encodeCall(SlashIndicator.initializeV2, (address(_roninGovernanceAdmin))) + ); + _slashIndicator.initializeV3(loadContractOrDeploy(ContractKey.Profile)); + } + + { + // upgrade `RoninTrustedOrganization` + _upgradeProxy(ContractKey.RoninTrustedOrganization, EMPTY_ARGS); + } + + { + // upgrade `BridgeTracking` + // bump `BridgeTracking` to V2 + _upgradeProxy(ContractKey.BridgeTracking, abi.encodeCall(BridgeTracking.initializeV2, ())); + } + + { + // upgrade `StakingVesting` + // bump `StakingVesting` to V2, V3 + _upgradeProxy(ContractKey.StakingVesting, abi.encodeCall(StakingVesting.initializeV2, ())); + _stakingVesting.initializeV3(50); // 5% + } + + { + // upgrade `Maintenance` + // bump `Maintenance` to V2 + _upgradeProxy(ContractKey.Maintenance, abi.encodeCall(Maintenance.initializeV2, ())); + } + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade.s.sol new file mode 100644 index 000000000..6580059ef --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade.s.sol @@ -0,0 +1,193 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol"; +import { BridgeRewardDeploy } from "./contracts/BridgeRewardDeploy.s.sol"; +import { BridgeSlashDeploy } from "./contracts/BridgeSlashDeploy.s.sol"; +import { RoninBridgeManagerDeploy } from "./contracts/RoninBridgeManagerDeploy.s.sol"; + +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +contract Simulation_20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade is + Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods +{ + function _hookSetDepositCount() internal pure override returns (uint256) { + return 42213; // fork-block-number 28327195 + } + + function run() public virtual override trySetUp { + Simulation__20231003_UpgradeREP002AndREP003_Base.run(); + + // -------------- Day #1 -------------------- + _deployGatewayContracts(); + + // -------------- Day #2 (execute proposal on ronin) -------------------- + // _fastForwardToNextDay(); + // _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + _upgradeDPoSContracts(); + _upgradeGatewayContracts(); + _callInitREP2InGatewayContracts(); + _changeAdminOfGatewayContracts(); + + // -- done execute proposal + + // Deposit for + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + // _depositFor("after-upgrade-REP2"); + // _dummySwitchNetworks(); + _depositForOnlyOnRonin("after-upgrade-REP2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_a"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_b"); + + // -------------- End of Day #2 -------------------- + + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2"); // share bridge reward here + // _depositFor("after-DAY2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2_a"); + + // - deposit for + + // -------------- End of Day #3 -------------------- + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day3"); // share bridge reward here + } + + /** + * @dev Tasks: + * - Deploy BridgeReward + * - Deploy BridgeSlash + * - Deploy RoninBridgeManager + * - Top up for BridgeReward + */ + function _deployGatewayContracts() internal { + console2.log("> ", StdStyle.blue("_deployGatewayContracts"), "..."); + + uint256 bridgeManagerNonce = vm.getNonce(_sender) + 4; + address expectedRoninBridgeManager = computeCreateAddress(_sender, bridgeManagerNonce); + + _bridgeSlash = BridgeSlash( + new BridgeSlashDeploy() + .overrideArgs( + abi.encodeCall( + BridgeSlash.initialize, + ( + address(_validatorSet), + expectedRoninBridgeManager, + address(_bridgeTracking), + address(_roninGovernanceAdmin) + ) + ) + ) + .run() + ); + + _bridgeReward = BridgeReward( + new BridgeRewardDeploy() + .overrideArgs( + abi.encodeCall( + BridgeReward.initialize, + ( + expectedRoninBridgeManager, + address(_bridgeTracking), + address(_bridgeSlash), + address(_validatorSet), + address(_roninGovernanceAdmin), + 1337_133 + ) + ) + ) + .run() + ); + + RoninBridgeManager actualRoninBridgeManager = new RoninBridgeManagerDeploy().run(); + assertEq(address(actualRoninBridgeManager), expectedRoninBridgeManager); + _roninBridgeManager = actualRoninBridgeManager; + + _bridgeReward.receiveRON{ value: 100 ether }(); + } + + /** + * @dev Tasks: + * - Upgrade RoninGatewayV3 + * - Upgrade BridgeTracking + */ + function _upgradeGatewayContracts() internal { + console2.log("> ", StdStyle.blue("_upgradeGatewayContracts"), "..."); + + { + // upgrade `RoninGatewayV3` and bump to V2 + _upgradeProxy(ContractKey.RoninGatewayV3, abi.encodeCall(RoninGatewayV3.initializeV2, ())); + // bump `RoninGatewayV3` to V3 + _roninGateway.initializeV3(address(_roninBridgeManager)); + } + + { + // bump `BridgeTracking` to V3 + _bridgeTracking.initializeV3({ + bridgeManager: address(_roninBridgeManager), + bridgeSlash: address(_bridgeSlash), + bridgeReward: address(_bridgeReward), + dposGA: address(_roninGovernanceAdmin) + }); + } + } + + function _callInitREP2InGatewayContracts() internal { + console2.log("> ", StdStyle.blue("_callInitREP2InGatewayContracts"), "..."); + + vm.startPrank(address(_roninGovernanceAdmin)); + TransparentUpgradeableProxyV2(payable(address(_bridgeReward))).functionDelegateCall( + abi.encodeCall(BridgeReward.initializeREP2, ()) + ); + TransparentUpgradeableProxyV2(payable(address(_bridgeTracking))).functionDelegateCall( + abi.encodeCall(BridgeTracking.initializeREP2, ()) + ); + TransparentUpgradeableProxyV2(payable(address(_bridgeSlash))).functionDelegateCall( + abi.encodeCall(BridgeSlash.initializeREP2, ()) + ); + vm.stopPrank(); + } + + function _changeAdminOfGatewayContracts() internal { + console2.log("> ", StdStyle.blue("_changeAdminOfGatewayContracts"), "..."); + + vm.startPrank(address(_roninGovernanceAdmin)); + TransparentUpgradeableProxyV2(payable(address(_roninGateway))).changeAdmin(address(_roninBridgeManager)); + vm.stopPrank(); + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_ActualProposals.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_ActualProposals.s.sol new file mode 100644 index 000000000..4a0a623e5 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_ActualProposals.s.sol @@ -0,0 +1,158 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol"; +import { BridgeRewardDeploy } from "./contracts/BridgeRewardDeploy.s.sol"; +import { BridgeSlashDeploy } from "./contracts/BridgeSlashDeploy.s.sol"; +import { RoninBridgeManagerDeploy } from "./contracts/RoninBridgeManagerDeploy.s.sol"; + +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +contract Simulation_20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_ActualProposal is + Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods +{ + function _hookSetDepositCount() internal pure override returns (uint256) { + return 42671; // fork-block-number 28595746 + } + + function _hookPrankOperator() internal pure override returns (address) { + return 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA; + // return 0x32015E8B982c61bc8a593816FdBf03A603EEC823; + } + + function _afterDepositForOnlyOnRonin(Transfer.Receipt memory receipt) internal override { + address[21] memory operators = [ + // 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, + 0x4a4217d8751a027D853785824eF40522c512A3Fe, + 0x32cB6da260726BB2192c4085B857aFD945A215Cb, + 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E, + 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, + 0xE795F18F2F5DF5a666994e839b98263Dba86C902, + 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, + 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, + 0x063105D0E7215B703909a7274FE38393302F3134, + 0xD9d5b3E58fa693B468a20C716793B18A1195380a, + 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, + 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, + 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, + 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, + 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, + 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, + 0x332253265e36689D9830E57112CD1aaDB1A773f9, + 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, + 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, + 0x66225AcC78Be789C57a11C9a18F051C779d678B5, + 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, + 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99 + ]; + for (uint i; i < operators.length; i++) { + vm.prank(operators[i]); + _roninGateway.depositFor(receipt); + } + } + + function run() public virtual override trySetUp { + Simulation__20231003_UpgradeREP002AndREP003_Base.run(); + + // -------------- Add operators Ronin Bridge -------------------- + + vm.prank(0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6); + vm.resumeGasMetering(); + address(_roninBridgeManager).call( + hex"663ac01100000000000000000000000000000000000000000000000000000000653cba7e00000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001800000000000000000000000000000000000000000000000000000000000000bc0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000020000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000980000000000000000000000000000000000000000000000000000000000000090401a5f43f000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000003400000000000000000000000000000000000000000000000000000000000000620000000000000000000000000000000000000000000000000000000000000001600000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000016000000000000000000000000e880802580a1fbdef67ace39d1b21c5b2c74f0590000000000000000000000004b18cebeb9797ea594b5977109cc07b21c37e8c3000000000000000000000000a441f1399c8c023798586fbbbcf35f27279638a100000000000000000000000072a69b04b59c36fced19ac54209bef878e84fcbf000000000000000000000000e258f9996723b910712d6e67ada4eafc15f7f101000000000000000000000000020dd9a5e318695a61dda88db7ad077ec306e3e90000000000000000000000002d593a0087029501ee419b9415dec3fac195fe4a0000000000000000000000009b0612e43855ef9a7c329ee89653ba45273b550e00000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ad23e87306aa3c7b95ee760e86f40f3021e5fa18000000000000000000000000bacb04ea617b3e5eee0e3f6e8fcb5ba886b8395800000000000000000000000077ab649caa7b4b673c9f2cf069900df48114d79d0000000000000000000000000dca20728c8bb7173d3452559f40e95c609157990000000000000000000000000d48adbdc523681c0dee736dbdc4497e02bec210000000000000000000000000ea172676e4105e92cc52dbf45fd93b274ec96676000000000000000000000000ed448901cc62be10c5525ba19645ddca1fd9da1d0000000000000000000000008d4f4e4ba313c4332e720445d8268e087d5c19b800000000000000000000000058abcbcab52dee942491700cd0db67826bbaa8c60000000000000000000000004620fb95eabdab4bf681d987e116e0aaef1adef2000000000000000000000000c092fa0c772b3c850e676c57d8737bb39084b9ac00000000000000000000000060c4b72fc62b3e3a74e283aa9ba20d61dd4d8f1b000000000000000000000000ed3805fb65ff51a99fef4676bdbc97abeca93d1100000000000000000000000000000000000000000000000000000000000000160000000000000000000000004b3844a29cfa5824f53e2137edb6dc2b54501bea0000000000000000000000004a4217d8751a027d853785824ef40522c512a3fe00000000000000000000000032cb6da260726bb2192c4085b857afd945a215cb000000000000000000000000a91d05b7c6e684f43e8fe0c25b3c4bb1747a2a9e000000000000000000000000e38afbe7738b6ec4280a6bca1176c1c1a928a19c000000000000000000000000e795f18f2f5df5a666994e839b98263dba86c902000000000000000000000000772112c7e5dd4ed663e844e79d77c1569a2e88ce000000000000000000000000f0c48b7f020bb61e6a3500abc4b4954bde7a2039000000000000000000000000063105d0e7215b703909a7274fe38393302f3134000000000000000000000000d9d5b3e58fa693b468a20c716793b18a1195380a000000000000000000000000ff30ed09e3ae60d39bce1727ee3292fd76a6face0000000000000000000000008c4ad2dc12adb9ad115e37ee9ad2e00e343edf8500000000000000000000000073f5b22312b7b2b3b1cd179fc62269ab369c82060000000000000000000000005e04dc8156ce222289d52487dbadcb01c8c990f9000000000000000000000000564dcb855eb360826f27d1eb9c57cbbe6c76f50f000000000000000000000000ec5c90401f95f8c49b1e133e94f09d85b21d96a4000000000000000000000000332253265e36689d9830e57112cd1aadb1a773f9000000000000000000000000236af2ffdb611b14e3042a982d13eda1627d9c9600000000000000000000000054c8c42f07007d43c3049bef6f10ea68687d43ef00000000000000000000000066225acc78be789c57a11c9a18f051c779d678b5000000000000000000000000f4682b9263d1ba9bd9db09da125708607d1edd3a000000000000000000000000c23f2907bc11848b5d5cedbb835e915d7b760d99000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000064e9c034980000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000000100000000000000000000000032015e8b982c61bc8a593816fdbf03a603eec823000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000098968000000000000000000000000000000000000000000000000000000000000f4240" + ); + vm.pauseGasMetering(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + // -------------- Day #1 -------------------- + + address[12] memory governors = [ + 0x02201F9bfD2FaCe1b9f9D30d776E77382213Da1A, + 0x4620fb95eaBDaB4Bf681D987e116e0aAef1adEF2, + 0x5832C3219c1dA998e828E1a2406B73dbFC02a70C, + 0x58aBcBCAb52dEE942491700CD0DB67826BBAA8C6, + 0x60c4B72fc62b3e3a74e283aA9Ba20d61dD4d8F1b, + 0x77Ab649Caa7B4b673C9f2cF069900DF48114d79D, + 0x90ead0E8d5F5Bf5658A2e6db04535679Df0f8E43, + 0xbaCB04eA617b3E5EEe0E3f6E8FCB5Ba886B83958, + 0xD5877c63744903a459CCBa94c909CDaAE90575f8, + 0xe258f9996723B910712D6E67ADa4EafC15F7F101, + 0xe880802580a1fbdeF67ACe39D1B21c5b2C74f059, + 0xea172676E4105e92Cc52DBf45fD93b274eC96676 + ]; + + vm.prank(governors[0]); + address(_roninGovernanceAdmin).call( + hex"663ac01100000000000000000000000000000000000000000000000000000000653cba7e00000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000300000000000000000000000000000000000000000000000000000000000000054000000000000000000000000000000000000000000000000000000000000012e000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000545edb750eb8769c868429be9586f5857a768758000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba3000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba300000000000000000000000098d0230884448b3e2f09a177433d60fb1e19c0900000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d8816000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d88160000000000000000000000006f45c1f8d84849d497c6c0ac4c3842dc82f498940000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad10000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b240000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000022000000000000000000000000000000000000000000000000000000000000002e000000000000000000000000000000000000000000000000000000000000003a00000000000000000000000000000000000000000000000000000000000000460000000000000000000000000000000000000000000000000000000000000054000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000660000000000000000000000000000000000000000000000000000000000000072000000000000000000000000000000000000000000000000000000000000007e000000000000000000000000000000000000000000000000000000000000008a000000000000000000000000000000000000000000000000000000000000009600000000000000000000000000000000000000000000000000000000000000a200000000000000000000000000000000000000000000000000000000000000ae00000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000000c400000000000000000000000000000000000000000000000000000000000000ce00000000000000000000000000000000000000000000000000000000000000d2000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000000c1dee1b435c464b4e94781f94f991cb90e3399d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da576000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000008ae952d538e9c25120e9c75fba0718750f81313a000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000a44f1ef286000000000000000000000000440baf1c4b008ee4d617a83401f06aa80f5163e90000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000002429b6eca9000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243659cfe60000000000000000000000000aada85a2b3c9fb1be158d43e71cdcca6fe85e020000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000e4ccf400e99cb07eb76d3a169532916069b7dc32000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000007ccbb3cd1b19bc1f1d5b7048400d41b1b796abad000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243c3d84100000000000000000000000000000000000000000000000000000000000000032000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000ca9f10769292f26850333264d618c1b5e91f394d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000001477db6bf449b0eb1191a1f4023867ddceadc504000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000e44bb5274a00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000084ca21287e0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad1000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000644bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000043b154455000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000248f2839700000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001100000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f4240" + ); + + // -------------- Day #2 (execute proposal on ronin) -------------------- + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + // -- execute proposal + + for (uint i = 1; i < governors.length - 3; i++) { + vm.prank(governors[i]); + address(_roninGovernanceAdmin).call( + hex"a8a0e32c00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000007e400000000000000000000000000000000000000000000000000000000653cba7e00000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000320000000000000000000000000000000000000000000000000000000000000056000000000000000000000000000000000000000000000000000000000000013000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000545edb750eb8769c868429be9586f5857a768758000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba3000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba300000000000000000000000098d0230884448b3e2f09a177433d60fb1e19c0900000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d8816000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d88160000000000000000000000006f45c1f8d84849d497c6c0ac4c3842dc82f498940000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad10000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b240000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000022000000000000000000000000000000000000000000000000000000000000002e000000000000000000000000000000000000000000000000000000000000003a00000000000000000000000000000000000000000000000000000000000000460000000000000000000000000000000000000000000000000000000000000054000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000660000000000000000000000000000000000000000000000000000000000000072000000000000000000000000000000000000000000000000000000000000007e000000000000000000000000000000000000000000000000000000000000008a000000000000000000000000000000000000000000000000000000000000009600000000000000000000000000000000000000000000000000000000000000a200000000000000000000000000000000000000000000000000000000000000ae00000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000000c400000000000000000000000000000000000000000000000000000000000000ce00000000000000000000000000000000000000000000000000000000000000d2000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000000c1dee1b435c464b4e94781f94f991cb90e3399d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da576000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000008ae952d538e9c25120e9c75fba0718750f81313a000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000a44f1ef286000000000000000000000000440baf1c4b008ee4d617a83401f06aa80f5163e90000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000002429b6eca9000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243659cfe60000000000000000000000000aada85a2b3c9fb1be158d43e71cdcca6fe85e020000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000e4ccf400e99cb07eb76d3a169532916069b7dc32000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000007ccbb3cd1b19bc1f1d5b7048400d41b1b796abad000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243c3d84100000000000000000000000000000000000000000000000000000000000000032000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000ca9f10769292f26850333264d618c1b5e91f394d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000001477db6bf449b0eb1191a1f4023867ddceadc504000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000e44bb5274a00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000084ca21287e0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad1000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000644bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000043b154455000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000248f2839700000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001100000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f4240" + ); + } + // -- done execute proposal + + // Deposit for + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + // _depositFor("after-upgrade-REP2"); + // _dummySwitchNetworks(); + _depositForOnlyOnRonin("after-upgrade-REP2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_a"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_b"); + + // -------------- End of Day #2 -------------------- + + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2"); // share bridge reward here + // _depositFor("after-DAY2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2_a"); + + // - deposit for + + // -------------- End of Day #3 -------------------- + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day3"); // share bridge reward here + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_Approve.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_Approve.sol new file mode 100644 index 000000000..101c366a2 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_Approve.sol @@ -0,0 +1,141 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol"; +import { BridgeRewardDeploy } from "./contracts/BridgeRewardDeploy.s.sol"; +import { BridgeSlashDeploy } from "./contracts/BridgeSlashDeploy.s.sol"; +import { RoninBridgeManagerDeploy } from "./contracts/RoninBridgeManagerDeploy.s.sol"; + +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +contract Simulation_20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_Approve is + Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods +{ + function _hookSetDepositCount() internal pure override returns (uint256) { + return 42678; // fork-block-number 28598979 + } + + function _hookPrankOperator() internal pure override returns (address) { + return 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA; + // return 0x32015E8B982c61bc8a593816FdBf03A603EEC823; + } + + function _afterDepositForOnlyOnRonin(Transfer.Receipt memory receipt) internal override { + address[21] memory operators = [ + // 0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA, + 0x4a4217d8751a027D853785824eF40522c512A3Fe, + 0x32cB6da260726BB2192c4085B857aFD945A215Cb, + 0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E, + 0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C, + 0xE795F18F2F5DF5a666994e839b98263Dba86C902, + 0x772112C7e5dD4ed663e844e79d77c1569a2E88ce, + 0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039, + 0x063105D0E7215B703909a7274FE38393302F3134, + 0xD9d5b3E58fa693B468a20C716793B18A1195380a, + 0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce, + 0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85, + 0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206, + 0x5e04DC8156ce222289d52487dbAdCb01C8c990f9, + 0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F, + 0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4, + 0x332253265e36689D9830E57112CD1aaDB1A773f9, + 0x236aF2FFdb611B14e3042A982d13EdA1627d9C96, + 0x54C8C42F07007D43c3049bEF6f10eA68687d43ef, + 0x66225AcC78Be789C57a11C9a18F051C779d678B5, + 0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a, + 0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99 + ]; + for (uint i; i < operators.length; i++) { + vm.prank(operators[i]); + _roninGateway.depositFor(receipt); + } + } + + function run() public virtual override trySetUp { + Simulation__20231003_UpgradeREP002AndREP003_Base.run(); + + // -------------- Day #1 -------------------- + + address[11] memory governors = [ + 0x02201F9bfD2FaCe1b9f9D30d776E77382213Da1A, + 0x4620fb95eaBDaB4Bf681D987e116e0aAef1adEF2, + 0x5832C3219c1dA998e828E1a2406B73dbFC02a70C, + 0x58aBcBCAb52dEE942491700CD0DB67826BBAA8C6, + 0x60c4B72fc62b3e3a74e283aA9Ba20d61dD4d8F1b, + 0x77Ab649Caa7B4b673C9f2cF069900DF48114d79D, + 0x90ead0E8d5F5Bf5658A2e6db04535679Df0f8E43, + 0xbaCB04eA617b3E5EEe0E3f6E8FCB5Ba886B83958, + 0xD5877c63744903a459CCBa94c909CDaAE90575f8, + 0xe258f9996723B910712D6E67ADa4EafC15F7F101, + 0xea172676E4105e92Cc52DBf45fD93b274eC96676 + ]; + + // -------------- Day #2 (execute proposal on ronin) -------------------- + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + + // -- execute proposal + + for (uint i = 1; i < governors.length - 2; i++) { + vm.prank(governors[i]); + address(_roninGovernanceAdmin).call( + hex"a8a0e32c00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000007e400000000000000000000000000000000000000000000000000000000653cda8b00000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000320000000000000000000000000000000000000000000000000000000000000056000000000000000000000000000000000000000000000000000000000000013000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000617c5d73662282ea7ffd231e020eca6d2b0d552f000000000000000000000000545edb750eb8769c868429be9586f5857a768758000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba3000000000000000000000000ebfff2b32fa0df9c5c8c5d5aaa7e8b51d5207ba300000000000000000000000098d0230884448b3e2f09a177433d60fb1e19c0900000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d8816000000000000000000000000c768423a2ae2b5024cb58f3d6449a8f5db6d88160000000000000000000000006f45c1f8d84849d497c6c0ac4c3842dc82f498940000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad10000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b240000000000000000000000000cf8ff40a508bdbc39fbe1bb679dcba64e65c7df0000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000011000000000000000000000000000000000000000000000000000000000000022000000000000000000000000000000000000000000000000000000000000002e000000000000000000000000000000000000000000000000000000000000003a00000000000000000000000000000000000000000000000000000000000000460000000000000000000000000000000000000000000000000000000000000054000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000660000000000000000000000000000000000000000000000000000000000000072000000000000000000000000000000000000000000000000000000000000007e000000000000000000000000000000000000000000000000000000000000008a000000000000000000000000000000000000000000000000000000000000009600000000000000000000000000000000000000000000000000000000000000a200000000000000000000000000000000000000000000000000000000000000ae00000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000000c400000000000000000000000000000000000000000000000000000000000000ce00000000000000000000000000000000000000000000000000000000000000d2000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000000c1dee1b435c464b4e94781f94f991cb90e3399d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000a30b2932cd8b8a89e34551cdfa13810af38da576000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000008ae952d538e9c25120e9c75fba0718750f81313a000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000a44f1ef286000000000000000000000000440baf1c4b008ee4d617a83401f06aa80f5163e90000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000002429b6eca9000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb000000000000000000000000840ebf1ca767cb690029e91856a357a43b85d035000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000243659cfe60000000000000000000000000aada85a2b3c9fb1be158d43e71cdcca6fe85e020000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000e4ccf400e99cb07eb76d3a169532916069b7dc32000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000007ccbb3cd1b19bc1f1d5b7048400d41b1b796abad000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243c3d84100000000000000000000000000000000000000000000000000000000000000032000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef286000000000000000000000000ca9f10769292f26850333264d618c1b5e91f394d000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844f1ef2860000000000000000000000001477db6bf449b0eb1191a1f4023867ddceadc504000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000045cd8a76b000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000844bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000243101cfcb0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000e44bb5274a00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000084ca21287e0000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a000000000000000000000000273cda3afe17eb7bcb028b058382a9010ae82b24000000000000000000000000796a163a21e9a659fc9773166e0afdc1eb01aad1000000000000000000000000946397dedfd2f79b75a72b322944a21c3240c9c3000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000644bb5274a000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000000043b154455000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000043b1544550000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000248f2839700000000000000000000000005fa49e6ca54a9daa8eca4f403adbde5ee075d84a00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001100000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f4240" + ); + } + // -- done execute proposal + + // Deposit for + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + // _depositFor("after-upgrade-REP2"); + // _dummySwitchNetworks(); + _depositForOnlyOnRonin("after-upgrade-REP2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_a"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-upgrade-REP2_b"); + + // -------------- End of Day #2 -------------------- + + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2"); // share bridge reward here + // _depositFor("after-DAY2"); + + _fastForwardToNextEpoch(); + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day2_a"); + + // - deposit for + + // -------------- End of Day #3 -------------------- + // - wrap up period + _fastForwardToNextDay(); + _wrapUpEpoch(); + + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + _depositForOnlyOnRonin("after-wrapup-Day3"); // share bridge reward here + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol new file mode 100644 index 000000000..48817b7e9 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol @@ -0,0 +1,34 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import "./20231003_REP002AndREP003_RON_NonConditional.s.sol"; + +contract Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods is + Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional +{ + function run() public virtual override trySetUp { + super.run(); + + // submit block reward for one epoch + vm.warp(block.timestamp + 3 seconds); + vm.roll(block.number + 1); + vm.prank(block.coinbase); + _validatorSet.submitBlockReward{ value: 1_000_000 }(); + + address[] memory finalityList = new address[](1); + finalityList[0] = block.coinbase; + vm.prank(block.coinbase); + _fastFinalityTracking.recordFinality(finalityList); + + // wrap up period for second day after upgrade + _fastForwardToNextDay(); + _wrapUpEpoch(); + + // // test `RoninValidatorSet` functionality + // _fastForwardToNextDay(); + // _wrapUpEpoch(); + + // // test `RoninGatewayV3` functionality + // _depositFor("after-upgrade-user"); + } +} diff --git a/script/20231003-rep-002-rep-003/20231003_REP002_AddBridgeOperators_ActualProposal.s.sol b/script/20231003-rep-002-rep-003/20231003_REP002_AddBridgeOperators_ActualProposal.s.sol new file mode 100644 index 000000000..5941fac27 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231003_REP002_AddBridgeOperators_ActualProposal.s.sol @@ -0,0 +1,31 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_Base.s.sol"; +import "./20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol"; +import { BridgeRewardDeploy } from "./contracts/BridgeRewardDeploy.s.sol"; +import { BridgeSlashDeploy } from "./contracts/BridgeSlashDeploy.s.sol"; +import { RoninBridgeManagerDeploy } from "./contracts/RoninBridgeManagerDeploy.s.sol"; + +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +contract Simulation_20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade_ActualProposal is + Simulation__20231003_UpgradeREP002AndREP003_Base +{ + function run() public virtual override trySetUp { + Simulation__20231003_UpgradeREP002AndREP003_Base.run(); + + // -------------- Day #1 -------------------- + vm.prank(0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6); + address(_roninBridgeManager).call( + hex"663ac01100000000000000000000000000000000000000000000000000000000653b5c1100000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001800000000000000000000000000000000000000000000000000000000000000bc0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000020000000000000000000000005a6073071f151fe282aa1267870cde1aff85ff280000000000000000000000005a6073071f151fe282aa1267870cde1aff85ff28000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000980000000000000000000000000000000000000000000000000000000000000090401a5f43f000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000003400000000000000000000000000000000000000000000000000000000000000620000000000000000000000000000000000000000000000000000000000000001600000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000064000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000000640000000000000000000000000000000000000000000000000000000000000016000000000000000000000000e880802580a1fbdef67ace39d1b21c5b2c74f0590000000000000000000000004b18cebeb9797ea594b5977109cc07b21c37e8c3000000000000000000000000a441f1399c8c023798586fbbbcf35f27279638a100000000000000000000000072a69b04b59c36fced19ac54209bef878e84fcbf000000000000000000000000e258f9996723b910712d6e67ada4eafc15f7f101000000000000000000000000020dd9a5e318695a61dda88db7ad077ec306e3e90000000000000000000000002d593a0087029501ee419b9415dec3fac195fe4a0000000000000000000000009b0612e43855ef9a7c329ee89653ba45273b550e00000000000000000000000047cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1000000000000000000000000ad23e87306aa3c7b95ee760e86f40f3021e5fa18000000000000000000000000bacb04ea617b3e5eee0e3f6e8fcb5ba886b8395800000000000000000000000077ab649caa7b4b673c9f2cf069900df48114d79d0000000000000000000000000dca20728c8bb7173d3452559f40e95c609157990000000000000000000000000d48adbdc523681c0dee736dbdc4497e02bec210000000000000000000000000ea172676e4105e92cc52dbf45fd93b274ec96676000000000000000000000000ed448901cc62be10c5525ba19645ddca1fd9da1d0000000000000000000000008d4f4e4ba313c4332e720445d8268e087d5c19b800000000000000000000000058abcbcab52dee942491700cd0db67826bbaa8c60000000000000000000000004620fb95eabdab4bf681d987e116e0aaef1adef2000000000000000000000000c092fa0c772b3c850e676c57d8737bb39084b9ac00000000000000000000000060c4b72fc62b3e3a74e283aa9ba20d61dd4d8f1b000000000000000000000000ed3805fb65ff51a99fef4676bdbc97abeca93d1100000000000000000000000000000000000000000000000000000000000000160000000000000000000000004b3844a29cfa5824f53e2137edb6dc2b54501bea0000000000000000000000004a4217d8751a027d853785824ef40522c512a3fe00000000000000000000000032cb6da260726bb2192c4085b857afd945a215cb000000000000000000000000a91d05b7c6e684f43e8fe0c25b3c4bb1747a2a9e000000000000000000000000e38afbe7738b6ec4280a6bca1176c1c1a928a19c000000000000000000000000e795f18f2f5df5a666994e839b98263dba86c902000000000000000000000000772112c7e5dd4ed663e844e79d77c1569a2e88ce000000000000000000000000f0c48b7f020bb61e6a3500abc4b4954bde7a2039000000000000000000000000063105d0e7215b703909a7274fe38393302f3134000000000000000000000000d9d5b3e58fa693b468a20c716793b18a1195380a000000000000000000000000ff30ed09e3ae60d39bce1727ee3292fd76a6face0000000000000000000000008c4ad2dc12adb9ad115e37ee9ad2e00e343edf8500000000000000000000000073f5b22312b7b2b3b1cd179fc62269ab369c82060000000000000000000000005e04dc8156ce222289d52487dbadcb01c8c990f9000000000000000000000000564dcb855eb360826f27d1eb9c57cbbe6c76f50f000000000000000000000000ec5c90401f95f8c49b1e133e94f09d85b21d96a4000000000000000000000000332253265e36689d9830e57112cd1aadb1a773f9000000000000000000000000236af2ffdb611b14e3042a982d13eda1627d9c9600000000000000000000000054c8c42f07007d43c3049bef6f10ea68687d43ef00000000000000000000000066225acc78be789c57a11c9a18f051c779d678b5000000000000000000000000f4682b9263d1ba9bd9db09da125708607d1edd3a000000000000000000000000c23f2907bc11848b5d5cedbb835e915d7b760d99000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000064e9c034980000000000000000000000000000000000000000000000000000000000000020000000000000000000000000000000000000000000000000000000000000000100000000000000000000000032015e8b982c61bc8a593816fdbf03a603eec82300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f4240" + ); + } +} diff --git a/script/20231003-rep-002-rep-003/20231016_ReconfigBridgeTracking.sol b/script/20231003-rep-002-rep-003/20231016_ReconfigBridgeTracking.sol new file mode 100644 index 000000000..565e053c2 --- /dev/null +++ b/script/20231003-rep-002-rep-003/20231016_ReconfigBridgeTracking.sol @@ -0,0 +1,30 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { StdStyle } from "forge-std/StdStyle.sol"; + +import "./20231003_REP002AndREP003_RON_NonConditional_Wrapup2Periods.s.sol"; +import { BridgeRewardDeploy } from "./contracts/BridgeRewardDeploy.s.sol"; +import { BridgeSlashDeploy } from "./contracts/BridgeSlashDeploy.s.sol"; +import { RoninBridgeManagerDeploy } from "./contracts/RoninBridgeManagerDeploy.s.sol"; + +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; +import { RoninBridgeManager } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; +import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; + +contract Simulation_20231016_ReconfigBridgeTracking is + Simulation__20231003_UpgradeREP002AndREP003_RON_NonConditional_Wrapup2Periods +{ + function run() public virtual override trySetUp { + Simulation__20231003_UpgradeREP002AndREP003_Base.run(); + + vm.prank(0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6); + // vm.prank(address(0)); + address(_roninBridgeManager).call( + hex"663ac01100000000000000000000000000000000000000000000000000000000653a2ec800000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000014000000000000000000000000000000000000000000000000000000000000001c00000000000000000000000000000000000000000000000000000000000000500000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000030000000000000000000000005a6073071f151fe282aa1267870cde1aff85ff28000000000000000000000000323092ab0900281efd0ef5954b0a612ce7755f9c0000000000000000000000001c952d6717ebfd2e92e5f43ef7c1c3f7677f007d0000000000000000000000000000000000000000000000000000000000000003000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000300000000000000000000000000000000000000000000000000000000000000600000000000000000000000000000000000000000000000000000000000000160000000000000000000000000000000000000000000000000000000000000024000000000000000000000000000000000000000000000000000000000000000c4800eaab3000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000800000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000010000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc20000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000a44bb5274a00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000044865e6fd300000000000000000000000000000000000000000000000000000000000000030000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc2000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000a44bb5274a00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000044865e6fd300000000000000000000000000000000000000000000000000000000000000030000000000000000000000003fb325b251ee80945d3fc8c7692f5affca1b8bc20000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000300000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f424000000000000000000000000000000000000000000000000000000000000f4240" + ); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/BridgeRewardDeploy.s.sol b/script/20231003-rep-002-rep-003/contracts/BridgeRewardDeploy.s.sol new file mode 100644 index 000000000..ad09f8da6 --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/BridgeRewardDeploy.s.sol @@ -0,0 +1,11 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { BridgeReward } from "@ronin/contracts/ronin/gateway/BridgeReward.sol"; + +contract BridgeRewardDeploy is BaseDeploy { + function run() public virtual trySetUp returns (BridgeReward) { + return BridgeReward(_deployProxy(ContractKey.BridgeReward)); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/BridgeSlashDeploy.s.sol b/script/20231003-rep-002-rep-003/contracts/BridgeSlashDeploy.s.sol new file mode 100644 index 000000000..6b1d00d21 --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/BridgeSlashDeploy.s.sol @@ -0,0 +1,11 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { BridgeSlash } from "@ronin/contracts/ronin/gateway/BridgeSlash.sol"; + +contract BridgeSlashDeploy is BaseDeploy { + function run() public virtual trySetUp returns (BridgeSlash) { + return BridgeSlash(_deployProxy(ContractKey.BridgeSlash)); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/FastFinalityTrackingDeploy.s.sol b/script/20231003-rep-002-rep-003/contracts/FastFinalityTrackingDeploy.s.sol new file mode 100644 index 000000000..5911bbf96 --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/FastFinalityTrackingDeploy.s.sol @@ -0,0 +1,18 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { FastFinalityTracking } from "@ronin/contracts/ronin/fast-finality/FastFinalityTracking.sol"; + +contract FastFinalityTrackingDeploy is BaseDeploy { + function _defaultArguments() internal view override returns (bytes memory args) { + args = abi.encodeCall( + FastFinalityTracking.initialize, + _config.getAddressFromCurrentNetwork(ContractKey.RoninValidatorSet) + ); + } + + function run() public virtual trySetUp returns (FastFinalityTracking) { + return FastFinalityTracking(_deployProxy(ContractKey.FastFinalityTracking)); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/NotifiedMigratorUpgrade.s.sol b/script/20231003-rep-002-rep-003/contracts/NotifiedMigratorUpgrade.s.sol new file mode 100644 index 000000000..306155aa0 --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/NotifiedMigratorUpgrade.s.sol @@ -0,0 +1,21 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { console2, BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { ConditionalImplementControl } from "@ronin/contracts/extensions/version-control/ConditionalImplementControl.sol"; + +contract NotifiedMigratorUpgrade is BaseDeploy { + function run(ContractKey contractKey, bytes[] calldata callDatas) public virtual trySetUp returns (address payable) { + address payable proxy = _config.getAddressFromCurrentNetwork(contractKey); + address proxyAdmin = _getProxyAdmin(proxy); + address prevImpl = _getProxyImplementation(proxy); + address newImpl = _deployLogic(contractKey); + address notifier = _config.getAddressFromCurrentNetwork(ContractKey.RoninValidatorSet); + (address switcher, ) = _deployRaw( + _config.getContractName(ContractKey.NotifiedMigrator), + abi.encode(proxy, prevImpl, newImpl, notifier) + ); + return + _upgradeRaw(proxyAdmin, proxy, switcher, abi.encodeCall(ConditionalImplementControl.setCallDatas, (callDatas))); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/ProfileDeploy.s.sol b/script/20231003-rep-002-rep-003/contracts/ProfileDeploy.s.sol new file mode 100644 index 000000000..2a1c372a6 --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/ProfileDeploy.s.sol @@ -0,0 +1,15 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { Profile } from "@ronin/contracts/ronin/profile/Profile.sol"; +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; + +contract ProfileDeploy is BaseDeploy { + function _defaultArguments() internal view override returns (bytes memory args) { + args = abi.encodeCall(Profile.initialize, _config.getAddressFromCurrentNetwork(ContractKey.RoninValidatorSet)); + } + + function run() public virtual trySetUp returns (Profile) { + return Profile(_deployProxy(ContractKey.Profile)); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/RoninBridgeManagerDeploy.s.sol b/script/20231003-rep-002-rep-003/contracts/RoninBridgeManagerDeploy.s.sol new file mode 100644 index 000000000..efca70f9e --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/RoninBridgeManagerDeploy.s.sol @@ -0,0 +1,50 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { RoninBridgeManager, GlobalProposal } from "@ronin/contracts/ronin/gateway/RoninBridgeManager.sol"; +import { BridgeSlashDeploy } from "./BridgeSlashDeploy.s.sol"; + +contract RoninBridgeManagerDeploy is BaseDeploy { + function _injectDependencies() internal override { + _setDependencyDeployScript(ContractKey.BridgeSlash, new BridgeSlashDeploy()); + } + + function _defaultArguments() internal override returns (bytes memory args) { + // register BridgeSlash as callback receiver + address[] memory callbackRegisters = new address[](1); + // load BridgeSlash address + callbackRegisters[0] = loadContractOrDeploy(ContractKey.BridgeSlash); + + address[] memory operators = new address[](1); + operators[0] = makeAccount("detach-operator-1").addr; + + address[] memory governors = new address[](1); + governors[0] = makeAccount("detach-governor-1").addr; + + uint96[] memory weights = new uint96[](1); + weights[0] = 100; + + GlobalProposal.TargetOption[] memory targetOptions; + address[] memory targets; + + return + abi.encode( + 2, //DEFAULT_NUMERATOR, + 4, //DEFAULT_DENOMINATOR, + block.chainid, + 5 minutes, // DEFAULT_EXPIRY_DURATION, + _config.getAddressFromCurrentNetwork(ContractKey.RoninGatewayV3), + callbackRegisters, + operators, + governors, + weights, + targetOptions, + targets + ); + } + + function run() public virtual trySetUp returns (RoninBridgeManager) { + return RoninBridgeManager(_deployImmutable(ContractKey.RoninBridgeManager)); + } +} diff --git a/script/20231003-rep-002-rep-003/contracts/RoninValidatorSetTimedMigratorUpgrade.s.sol b/script/20231003-rep-002-rep-003/contracts/RoninValidatorSetTimedMigratorUpgrade.s.sol new file mode 100644 index 000000000..614e22f5e --- /dev/null +++ b/script/20231003-rep-002-rep-003/contracts/RoninValidatorSetTimedMigratorUpgrade.s.sol @@ -0,0 +1,35 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { ConditionalImplementControl } from "@ronin/contracts/extensions/version-control/ConditionalImplementControl.sol"; +import { RoninValidatorSet } from "@ronin/contracts/ronin/validator/RoninValidatorSet.sol"; +import { BaseDeploy, ContractKey } from "script/BaseDeploy.s.sol"; +import { FastFinalityTrackingDeploy } from "./FastFinalityTrackingDeploy.s.sol"; + +contract RoninValidatorSetTimedMigratorUpgrade is BaseDeploy { + function _injectDependencies() internal override { + _setDependencyDeployScript(ContractKey.FastFinalityTracking, new FastFinalityTrackingDeploy()); + } + + function run() public virtual trySetUp returns (RoninValidatorSet) { + address payable proxy = _config.getAddressFromCurrentNetwork(ContractKey.RoninValidatorSet); + address proxyAdmin = _getProxyAdmin(proxy); + address prevImpl = _getProxyImplementation(proxy); + address newImpl = _deployLogic(ContractKey.RoninValidatorSet); + (address switcher, ) = _deployRaw( + _config.getContractFileName(ContractKey.RoninValidatorSetTimedMigrator), + abi.encode(proxy, prevImpl, newImpl) + ); + + bytes[] memory callDatas = new bytes[](2); + callDatas[0] = abi.encodeCall(RoninValidatorSet.initializeV2, ()); + callDatas[1] = abi.encodeCall( + RoninValidatorSet.initializeV3, + (loadContractOrDeploy(ContractKey.FastFinalityTracking)) + ); + return + RoninValidatorSet( + _upgradeRaw(proxyAdmin, proxy, switcher, abi.encodeCall(ConditionalImplementControl.setCallDatas, (callDatas))) + ); + } +} diff --git a/script/BaseDeploy.s.sol b/script/BaseDeploy.s.sol new file mode 100644 index 000000000..f73222e94 --- /dev/null +++ b/script/BaseDeploy.s.sol @@ -0,0 +1,186 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { TransparentUpgradeableProxy } from "@openzeppelin/contracts/proxy/transparent/TransparentUpgradeableProxy.sol"; +import { Vm } from "forge-std/Vm.sol"; +import { console2 } from "forge-std/console2.sol"; +import { StdStyle } from "forge-std/StdStyle.sol"; +import { IScript, BaseScript } from "./BaseScript.s.sol"; +import { LogGenerator } from "./LogGenerator.s.sol"; +import "./GeneralConfig.s.sol"; +import { IDeployScript } from "./interfaces/IDeployScript.sol"; + +abstract contract BaseDeploy is BaseScript { + using StdStyle for string; + + bytes public constant EMPTY_ARGS = ""; + bytes32 constant IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc; + bytes32 constant ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103; + + bool internal _alreadySetUp; + bytes internal _overriddenArgs; + LogGenerator internal _logger; + mapping(ContractKey contractKey => IDeployScript deployScript) internal _deployScript; + + modifier trySetUp() { + if (!_alreadySetUp) { + setUp(); + _alreadySetUp = true; + } + _; + } + + function setUp() public virtual override { + vm.pauseGasMetering(); + _alreadySetUp = true; + super.setUp(); + _logger = new LogGenerator(vm, _config); + _injectDependencies(); + } + + function _injectDependencies() internal virtual {} + + function _setDependencyDeployScript(ContractKey contractKey, IScript deployScript) internal { + _deployScript[contractKey] = IDeployScript(address(deployScript)); + } + + function loadContractOrDeploy(ContractKey contractKey) public returns (address payable contractAddr) { + string memory contractName = _config.getContractName(contractKey); + try _config.getAddressFromCurrentNetwork(contractKey) returns (address payable addr) { + contractAddr = addr; + } catch { + console2.log(string.concat("Deployment for ", contractName, " not found, try fresh deploy ...").yellow()); + contractAddr = _deployScript[contractKey].run(); + } + } + + function overrideArgs(bytes memory args) public returns (IDeployScript) { + _overriddenArgs = args; + return IDeployScript(address(this)); + } + + function arguments() public returns (bytes memory args) { + args = _overriddenArgs.length == 0 ? _defaultArguments() : _overriddenArgs; + } + + function _defaultArguments() internal virtual returns (bytes memory args) {} + + function _deployImmutable(ContractKey contractKey) internal returns (address payable deployed) { + string memory contractName = _config.getContractName(contractKey); + string memory contractFilename = _config.getContractFileName(contractKey); + bytes memory args = arguments(); + uint256 nonce; + (deployed, nonce) = _deployRaw(contractFilename, args); + vm.label(deployed, contractName); + + _config.setAddress(_network, contractKey, deployed); + _logger.generateDeploymentArtifact(_sender, deployed, contractName, contractName, args, nonce); + } + + function _upgradeProxy(ContractKey contractKey, bytes memory args) internal returns (address payable proxy) { + string memory contractName = _config.getContractName(contractKey); + string memory contractFilename = _config.getContractFileName(contractKey); + + uint256 logicNonce; + address logic; + (logic, logicNonce) = _deployRaw(contractFilename, EMPTY_ARGS); + + proxy = _config.getAddressFromCurrentNetwork(contractKey); + address proxyAdmin = _getProxyAdmin(proxy); + _upgradeRaw(proxyAdmin, proxy, logic, args); + + _logger.generateDeploymentArtifact( + _sender, + logic, + contractName, + string.concat(contractName, "Logic"), + EMPTY_ARGS, + logicNonce + ); + } + + function _getProxyAdmin(address proxy) internal view returns (address payable) { + return payable(address(uint160(uint256(vm.load(address(proxy), ADMIN_SLOT))))); + } + + function _getProxyImplementation(address proxy) internal view returns (address payable) { + return payable(address(uint160(uint256(vm.load(address(proxy), IMPLEMENTATION_SLOT))))); + } + + function _deployLogic(ContractKey contractKey) internal returns (address payable logic) { + string memory contractName = _config.getContractName(contractKey); + string memory contractFilename = _config.getContractFileName(contractKey); + + uint256 logicNonce; + (logic, logicNonce) = _deployRaw(contractFilename, EMPTY_ARGS); + _logger.generateDeploymentArtifact( + _sender, + logic, + contractName, + string.concat(contractName, "Logic"), + EMPTY_ARGS, + logicNonce + ); + } + + function _deployProxy(ContractKey contractKey) internal returns (address payable deployed) { + string memory contractName = _config.getContractName(contractKey); + string memory contractFilename = _config.getContractFileName(contractKey); + bytes memory args = arguments(); + (address logic, uint256 logicNonce) = _deployRaw(contractFilename, EMPTY_ARGS); + uint256 proxyNonce; + (deployed, proxyNonce) = _deployRaw( + "TransparentUpgradeableProxyV2.sol:TransparentUpgradeableProxyV2", + abi.encode(logic, _config.getAddressFromCurrentNetwork(ContractKey.GovernanceAdmin), args) + ); + vm.label(deployed, contractName); + + _config.setAddress(_network, contractKey, deployed); + _logger.generateDeploymentArtifact( + _sender, + logic, + contractName, + string.concat(contractName, "Logic"), + EMPTY_ARGS, + logicNonce + ); + _logger.generateDeploymentArtifact( + _sender, + deployed, + "TransparentUpgradeableProxyV2", + string.concat(contractName, "Proxy"), + args, + proxyNonce + ); + } + + function _deployRaw( + string memory filename, + bytes memory args + ) internal returns (address payable deployed, uint256 nonce) { + nonce = vm.getNonce(_sender); + address expectedAddr = computeCreateAddress(_sender, nonce); + + vm.resumeGasMetering(); + vm.broadcast(_sender); + deployed = payable(deployCode(filename, args)); + vm.pauseGasMetering(); + + require(deployed == expectedAddr, "deployed != expectedAddr"); + } + + function _upgradeRaw( + address proxyAdmin, + address payable proxy, + address logic, + bytes memory args + ) internal returns (address payable) { + vm.broadcast(address(proxyAdmin)); + vm.resumeGasMetering(); + if (args.length == 0) TransparentUpgradeableProxy(proxy).upgradeTo(logic); + else TransparentUpgradeableProxy(proxy).upgradeToAndCall(logic, args); + vm.pauseGasMetering(); + + return proxy; + } +} diff --git a/script/BaseScript.s.sol b/script/BaseScript.s.sol new file mode 100644 index 000000000..498dceb45 --- /dev/null +++ b/script/BaseScript.s.sol @@ -0,0 +1,102 @@ +// SPDX-License-Identifier: UNLICENSED +pragma solidity ^0.8.0; + +import { ErrorHandler } from "@ronin/contracts/libraries/ErrorHandler.sol"; +import { StdStyle } from "forge-std/StdStyle.sol"; +import { StdAssertions } from "forge-std/StdAssertions.sol"; +import { Script, console2 } from "forge-std/Script.sol"; +import "./GeneralConfig.s.sol"; +import { IScript } from "./interfaces/IScript.sol"; +import { IDeployScript } from "./interfaces/IDeployScript.sol"; +import { RuntimeConfig } from "./configs/RuntimeConfig.sol"; + +abstract contract BaseScript is Script, IScript, StdAssertions { + using LibString for string; + using StdStyle for string; + using ErrorHandler for bool; + + string public constant TREZOR_PREFIX = "trezor://"; + bytes32 public constant GENERAL_CONFIG_SALT = keccak256(bytes(type(GeneralConfig).name)); + + address internal _sender; + Network internal _network; + GeneralConfig internal _config; + + modifier onMainnet() { + _network = Network.RoninMainnet; + _; + } + + modifier onTestnet() { + _network = Network.RoninTestnet; + _; + } + + modifier onLocalHost() { + _network = Network.Local; + _; + } + + function setUp() public virtual { + // allow diferrent deploy scripts to share same config storage + // predict general config address + address cfgAddr = computeCreate2Address( + GENERAL_CONFIG_SALT, + hashInitCode(abi.encodePacked(type(GeneralConfig).creationCode), abi.encode(vm)) + ); + + // allow existing on different chain + vm.makePersistent(cfgAddr); + vm.allowCheatcodes(cfgAddr); + + // skip if general config already deployed + if (cfgAddr.code.length == 0) { + vm.prank(CREATE2_FACTORY); + new GeneralConfig{ salt: GENERAL_CONFIG_SALT }(vm); + } + + _config = GeneralConfig(payable(cfgAddr)); + _network = _config.getCurrentNetwork(); + } + + function run(string calldata command) external { + RuntimeConfig.Options memory options = _parseRuntimeConfig(command); + _config.setRuntimeConfig(options); + + if (options.trezor) { + string memory str = vm.envString(_config.DEPLOYER_ENV_LABEL()); + _sender = vm.parseAddress(str.replace(TREZOR_PREFIX, "")); + console2.log(StdStyle.blue("Trezor Account:"), _sender); + } else { + uint256 pk = vm.envUint(_config.getPrivateKeyEnvLabel(_network)); + _sender = vm.rememberKey(pk); + console2.log(StdStyle.blue(".ENV Account:"), _sender); + } + vm.label(_sender, "sender"); + + (bool success, bytes memory returnOrRevertData) = address(this).delegatecall(abi.encodeCall(IDeployScript.run, ())); + success.handleRevert(IDeployScript.run.selector, returnOrRevertData); + } + + function _parseRuntimeConfig(string memory command) private pure returns (RuntimeConfig.Options memory options) { + if (bytes(command).length != 0) { + string[] memory args = command.split(" "); + uint256 length = args.length; + + for (uint256 i; i < length; ) { + if (args[i].eq("log")) options.log = true; + else if (args[i].eq("trezor")) options.trezor = true; + else revert(string.concat("Unsupported command: ", args[i]).red()); + + unchecked { + ++i; + } + } + } + } + + function fail() internal override { + super.fail(); + revert("Got failed assertion"); + } +} diff --git a/script/GeneralConfig.s.sol b/script/GeneralConfig.s.sol new file mode 100644 index 000000000..fffcedb23 --- /dev/null +++ b/script/GeneralConfig.s.sol @@ -0,0 +1,92 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { Vm, VmSafe } from "forge-std/Vm.sol"; +import { LibString } from "solady/utils/LibString.sol"; +import { RuntimeConfig } from "./configs/RuntimeConfig.sol"; +import { ContractKey, ContractConfig } from "./configs/ContractConfig.sol"; +import { Network, NetworkConfig } from "./configs/NetworkConfig.sol"; + +contract GeneralConfig is NetworkConfig, RuntimeConfig, ContractConfig { + using LibString for string; + + /// @dev Trezor deployer address + string public constant DEPLOYER_ENV_LABEL = "DEPLOYER"; + string public constant DEPLOYMENT_ROOT = "deployments/"; + + Vm private immutable _vm; + + constructor(Vm vm) payable { + _vm = vm; + + _storeDeploymentData(); + } + + function _storeDeploymentData() internal { + VmSafe.DirEntry[] memory deployments = _vm.readDir(DEPLOYMENT_ROOT); + + for (uint256 i; i < deployments.length; ) { + VmSafe.DirEntry[] memory entries = _vm.readDir(deployments[i].path); + uint256 chainId = _vm.parseUint(_vm.readFile(string.concat(deployments[i].path, "/.chainId"))); + string[] memory s = deployments[i].path.split("/"); + string memory prefix = s[s.length - 1]; + + for (uint256 j; j < entries.length; ) { + string memory path = entries[j].path; + + if (path.endsWith(".json")) { + // filter out logic deployments + if (!path.endsWith("Logic.json")) { + string[] memory splitteds = path.split("/"); + string memory contractName = splitteds[splitteds.length - 1]; + string memory suffix = path.endsWith("Proxy.json") ? "Proxy.json" : ".json"; + // remove suffix + assembly ("memory-safe") { + mstore(contractName, sub(mload(contractName), mload(suffix))) + } + if (contractName.endsWith("GovernanceAdmin")) contractName = "GovernanceAdmin"; + string memory json = _vm.readFile(path); + address contractAddr = _vm.parseJsonAddress(json, ".address"); + + _vm.label(contractAddr, string.concat(prefix, ".", contractName)); + _contractAddrMap[chainId][contractName] = contractAddr; + } + } + + unchecked { + ++j; + } + } + + unchecked { + ++i; + } + } + } + + function setAddressForCurrentNetwork(ContractKey contractKey, address contractAddr) public { + setAddress(getCurrentNetwork(), contractKey, contractAddr); + } + + function setAddress(Network network, ContractKey contractKey, address contractAddr) public { + uint256 chainId = _networkDataMap[network].chainId; + string memory contractName = _contractNameMap[contractKey]; + require(chainId != 0 && bytes(contractName).length != 0, "Network or Contract Key not found"); + + _contractAddrMap[chainId][contractName] = contractAddr; + } + + function getDeploymentDirectoryFromCurrentNetwork() public view returns (string memory dirPath) { + dirPath = getDeploymentDirectory(getCurrentNetwork()); + } + + function getDeploymentDirectory(Network network) public view returns (string memory dirPath) { + string memory dirName = _networkDataMap[network].deploymentDir; + require(bytes(dirName).length != 0, "Deployment dir not found"); + dirPath = string.concat(DEPLOYMENT_ROOT, dirName); + } + + function getAddress(Network network, ContractKey contractKey) public view returns (address payable) { + return getAddressByRawData(_networkDataMap[network].chainId, _contractNameMap[contractKey]); + } +} diff --git a/script/LogGenerator.s.sol b/script/LogGenerator.s.sol new file mode 100644 index 000000000..874d329f6 --- /dev/null +++ b/script/LogGenerator.s.sol @@ -0,0 +1,84 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { Strings } from "@openzeppelin/contracts/utils/Strings.sol"; +import { Vm } from "forge-std/Vm.sol"; +import { StdStyle } from "forge-std/StdStyle.sol"; +import { console2 } from "forge-std/console2.sol"; +import { stdJson } from "forge-std/StdJson.sol"; +import { GeneralConfig } from "./GeneralConfig.s.sol"; +import { JSONParserLib } from "solady/utils/JSONParserLib.sol"; + +contract LogGenerator { + using Strings for *; + using StdStyle for *; + using stdJson for string; + using JSONParserLib for *; + + Vm private immutable _vm; + GeneralConfig private immutable _config; + + constructor(Vm vm, GeneralConfig config) { + _vm = vm; + _config = config; + } + + function generateDeploymentArtifact( + address deployer, + address contractAddr, + string memory contractName, + string memory fileName, + bytes memory args, + uint256 nonce + ) external { + console2.log( + string.concat(fileName, " deployed at: ", contractAddr.toHexString()).green(), + string.concat("(nonce: ", nonce.toString(), ")") + ); + if (!_config.getRuntimeConfig().log) { + console2.log("Skipping artifact generation for:", fileName.yellow()); + return; + } + + // skip writing artifact if network is localhost + // if (_network == Network.LocalHost) return; + string memory dirPath = _config.getDeploymentDirectory(_config.getCurrentNetwork()); + string memory filePath = string.concat(dirPath, fileName, ".json"); + + string memory json; + uint256 numDeployments = 1; + + if (_vm.exists(filePath)) { + string memory existedJson = _vm.readFile(filePath); + if (_vm.keyExists(existedJson, ".numDeployments")) { + numDeployments = _vm.parseJsonUint(_vm.readFile(filePath), ".numDeployments"); + numDeployments += 1; + } + } + + json.serialize("nonce", nonce); + json.serialize("args", args); + json.serialize("chainId", block.chainid); + json.serialize("deployer", deployer); + json.serialize("address", contractAddr); + json.serialize("timestamp", block.timestamp); + json.serialize("contractName", contractName); + json.serialize("numDeployments", numDeployments); + json.serialize("blockNumber", block.number); + json.serialize("isFoundry", true); + + string memory artifactPath = string.concat("./out/", contractName, ".sol/", contractName, ".json"); + string memory artifact = _vm.readFile(artifactPath); + JSONParserLib.Item memory item = artifact.parse(); + + json.serialize("bytecode", item.at('"bytecode"').at('"object"').value()); + json.serialize("deployedBytecode", item.at('"deployedBytecode"').at('"object"').value()); + json.serialize("storageLayout", item.at('"storageLayout"').value()); + json.serialize("userdoc", item.at('"userdoc"').value()); + json.serialize("devdoc", item.at('"devdoc"').value()); + json.serialize("abi", item.at('"abi"').value()); + json = json.serialize("metadata", item.at('"rawMetadata"').value()); + + json.write(filePath); + } +} diff --git a/script/configs/ContractConfig.sol b/script/configs/ContractConfig.sol new file mode 100644 index 000000000..87f8c0ca5 --- /dev/null +++ b/script/configs/ContractConfig.sol @@ -0,0 +1,81 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +enum ContractKey { + GovernanceAdmin, + RoninValidatorSet, + BridgeTracking, + Maintenance, + RoninGatewayV3, + SlashIndicator, + Staking, + Profile, + MockPrecompile, + NotifiedMigrator, + MainchainGatewayV3, + FastFinalityTracking, + RoninTrustedOrganization, + RoninValidatorSetTimedMigrator, + StakingVesting, + BridgeReward, + BridgeSlash, + RoninBridgeManager, + MainchainBridgeManager, + MainchainGovernanceAdmin +} + +abstract contract ContractConfig { + mapping(ContractKey contractIdx => string contractName) internal _contractNameMap; + mapping(uint256 chainId => mapping(string name => address addr)) internal _contractAddrMap; + + constructor() payable { + // setup contract name + _contractNameMap[ContractKey.GovernanceAdmin] = "GovernanceAdmin"; + _contractNameMap[ContractKey.RoninValidatorSet] = "RoninValidatorSet"; + _contractNameMap[ContractKey.Staking] = "Staking"; + _contractNameMap[ContractKey.StakingVesting] = "StakingVesting"; + _contractNameMap[ContractKey.NotifiedMigrator] = "NotifiedMigrator"; + _contractNameMap[ContractKey.RoninTrustedOrganization] = "RoninTrustedOrganization"; + _contractNameMap[ContractKey.SlashIndicator] = "SlashIndicator"; + _contractNameMap[ContractKey.Maintenance] = "Maintenance"; + _contractNameMap[ContractKey.RoninValidatorSetTimedMigrator] = "RoninValidatorSetTimedMigrator"; + _contractNameMap[ContractKey.MockPrecompile] = "MockPrecompile"; + _contractNameMap[ContractKey.FastFinalityTracking] = "FastFinalityTracking"; + _contractNameMap[ContractKey.Profile] = "Profile"; + + _contractNameMap[ContractKey.MainchainGatewayV3] = "MainchainGatewayV3"; + _contractNameMap[ContractKey.RoninGatewayV3] = "RoninGatewayV3"; + _contractNameMap[ContractKey.BridgeTracking] = "BridgeTracking"; + _contractNameMap[ContractKey.BridgeReward] = "BridgeReward"; + _contractNameMap[ContractKey.BridgeSlash] = "BridgeSlash"; + _contractNameMap[ContractKey.RoninBridgeManager] = "RoninBridgeManager"; + _contractNameMap[ContractKey.MainchainBridgeManager] = "MainchainBridgeManager"; + // _contractNameMap[ContractKey.MainchainGovernanceAdmin] = "GovernanceAdmin"; + // _contractNameMap[ContractKey.RONRegistrarController] = "RONRegistrarController"; + } + + function getContractName(ContractKey contractKey) public view returns (string memory name) { + name = _contractNameMap[contractKey]; + require(bytes(name).length != 0, "Contract Key not found"); + } + + function getContractFileName(ContractKey contractKey) public view returns (string memory filename) { + string memory contractName = getContractName(contractKey); + filename = string.concat(contractName, ".sol:", contractName); + } + + function getAddressFromCurrentNetwork(ContractKey contractKey) public view returns (address payable) { + string memory contractName = _contractNameMap[contractKey]; + require(bytes(contractName).length != 0, "Contract Key not found"); + return getAddressByRawData(block.chainid, contractName); + } + + function getAddressByString(string memory contractName) public view returns (address payable) { + return getAddressByRawData(block.chainid, contractName); + } + + function getAddressByRawData(uint256 chainId, string memory contractName) public view returns (address payable addr) { + addr = payable(_contractAddrMap[chainId][contractName]); + require(addr != address(0), string.concat("address not found: ", contractName)); + } +} diff --git a/script/configs/NetworkConfig.sol b/script/configs/NetworkConfig.sol new file mode 100644 index 000000000..0a360be75 --- /dev/null +++ b/script/configs/NetworkConfig.sol @@ -0,0 +1,134 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { Vm } from "forge-std/Vm.sol"; +import { StdStyle } from "forge-std/StdStyle.sol"; +import { console2 } from "forge-std/console2.sol"; + +enum Network { + Local, + Goerli, + EthMainnet, + RoninMainnet, + RoninTestnet +} + +library ChainId { + uint256 public constant LOCAL = 31337; + uint256 public constant ETH_MAINNET = 1; + uint256 public constant GOERLI = 5; + uint256 public constant RONIN_MAINNET = 2020; + uint256 public constant RONIN_TESTNET = 2021; +} + +abstract contract NetworkConfig { + struct NetworkData { + uint256 forkId; + uint256 chainId; + string privateKeyEnvLabel; + string deploymentDir; + string chainAlias; + } + + uint256 private constant NULL_FORK_ID = uint256(keccak256("NULL_FORK_ID")); + Vm private constant vm = Vm(address(uint160(uint256(keccak256("hevm cheat code"))))); + + string public constant LOCAL_ALIAS = "localhost"; + string public constant GOERLI_ALIAS = "goerli"; + string public constant ETH_MAINNET_ALIAS = "ethereum"; + string public constant RONIN_TESTNET_ALIAS = "ronin-testnet"; + string public constant RONIN_MAINNET_ALIAS = "ronin-mainnet"; + + string public constant LOCAL_DIR = "local/"; + string public constant GOERLI_DIR = "goerli/"; + string public constant ETH_MAINNET_DIR = "ethereum/"; + string public constant RONIN_TESTNET_DIR = "ronin-testnet/"; + string public constant RONIN_MAINNET_DIR = "ronin-mainnet/"; + + string public constant LOCAL_ENV_LABEL = "LOCAL_PK"; + string public constant TESTNET_ENV_LABEL = "TESTNET_PK"; + string public constant MAINNET_ENV_LABEL = "MAINNET_PK"; + + mapping(Network networkIdx => NetworkData) internal _networkDataMap; + mapping(uint256 chainId => Network networkIdx) internal _networkMap; + + constructor() payable { + _networkMap[ChainId.GOERLI] = Network.Goerli; + _networkDataMap[Network.Goerli] = NetworkData( + tryCreateFork(GOERLI_ALIAS), + ChainId.GOERLI, + TESTNET_ENV_LABEL, + GOERLI_DIR, + GOERLI_ALIAS + ); + + _networkMap[ChainId.ETH_MAINNET] = Network.EthMainnet; + _networkDataMap[Network.EthMainnet] = NetworkData( + tryCreateFork(ETH_MAINNET_ALIAS), + ChainId.ETH_MAINNET, + MAINNET_ENV_LABEL, + ETH_MAINNET_DIR, + ETH_MAINNET_ALIAS + ); + + _networkMap[ChainId.LOCAL] = Network.Local; + _networkDataMap[Network.Local] = NetworkData( + tryCreateFork(LOCAL_ALIAS), + ChainId.LOCAL, + LOCAL_ENV_LABEL, + LOCAL_DIR, + LOCAL_ALIAS + ); + + _networkMap[ChainId.RONIN_TESTNET] = Network.RoninTestnet; + _networkDataMap[Network.RoninTestnet] = NetworkData( + tryCreateFork(RONIN_TESTNET_ALIAS), + ChainId.RONIN_TESTNET, + TESTNET_ENV_LABEL, + RONIN_TESTNET_DIR, + RONIN_TESTNET_ALIAS + ); + + _networkMap[ChainId.RONIN_MAINNET] = Network.RoninMainnet; + _networkDataMap[Network.RoninMainnet] = NetworkData( + tryCreateFork(RONIN_MAINNET_ALIAS), + ChainId.RONIN_MAINNET, + MAINNET_ENV_LABEL, + RONIN_MAINNET_DIR, + RONIN_MAINNET_ALIAS + ); + } + + function tryCreateFork(string memory chainAlias) public returns (uint256) { + try vm.createFork(vm.rpcUrl(chainAlias)) returns (uint256 forkId) { + return forkId; + } catch { + console2.log(StdStyle.red("NetworkConfig: Cannot create fork with url:"), vm.rpcUrl(chainAlias)); + return NULL_FORK_ID; + } + } + + function switchTo(Network network) public { + uint256 forkId = _networkDataMap[network].forkId; + require(forkId != NULL_FORK_ID, "Network Config: Unexists fork!"); + vm.selectFork(forkId); + require(_networkDataMap[network].chainId == block.chainid, "NetworkConfig: Switch chain failed"); + } + + function getPrivateKeyEnvLabelFromCurrentNetwork() public view returns (string memory privatekeyEnvLabel) { + privatekeyEnvLabel = getPrivateKeyEnvLabel(getCurrentNetwork()); + } + + function getPrivateKeyEnvLabel(Network network) public view returns (string memory privateKeyEnvLabel) { + privateKeyEnvLabel = _networkDataMap[network].privateKeyEnvLabel; + require(bytes(privateKeyEnvLabel).length != 0, "Network Config: ENV label not found"); + } + + function getCurrentNetwork() public view returns (Network network) { + network = _networkMap[block.chainid]; + } + + function getNetworkByChainId(uint256 chainId) public view returns (Network network) { + network = _networkMap[chainId]; + } +} diff --git a/script/configs/RuntimeConfig.sol b/script/configs/RuntimeConfig.sol new file mode 100644 index 000000000..93dfe4048 --- /dev/null +++ b/script/configs/RuntimeConfig.sol @@ -0,0 +1,19 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +abstract contract RuntimeConfig { + struct Options { + bool log; + bool trezor; + } + + Options internal _options; + + function setRuntimeConfig(Options memory options) external { + _options = options; + } + + function getRuntimeConfig() public view returns (Options memory options) { + options = _options; + } +} diff --git a/script/interfaces/IDeployScript.sol b/script/interfaces/IDeployScript.sol new file mode 100644 index 000000000..255329862 --- /dev/null +++ b/script/interfaces/IDeployScript.sol @@ -0,0 +1,11 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +import { IScript } from "./IScript.sol"; +import { ContractKey } from "../configs/ContractConfig.sol"; + +interface IDeployScript is IScript { + function run() external returns (address payable); + + function overrideArgs(bytes calldata args) external returns (IDeployScript); +} diff --git a/script/interfaces/IScript.sol b/script/interfaces/IScript.sol new file mode 100644 index 000000000..c30fa5a46 --- /dev/null +++ b/script/interfaces/IScript.sol @@ -0,0 +1,6 @@ +// SPDX-License-Identifier: MIT +pragma solidity ^0.8.19; + +interface IScript { + function run(string calldata command) external; +} diff --git a/src/configs/bridge-manager.ts b/src/configs/bridge-manager.ts index aeefe33c2..0ce5f9bfa 100644 --- a/src/configs/bridge-manager.ts +++ b/src/configs/bridge-manager.ts @@ -26,6 +26,106 @@ export interface BridgeManagerConfig { [network: LiteralNetwork]: undefined | BridgeManagerArguments; } +const rep2MemberMainnetTemp: BridgeManagerMemberStruct[] = [ + { + operator: '0x32015E8B982c61bc8a593816FdBf03A603EEC823', + governor: '0x3200A8eb56767c3760e108Aa27C65bfFF036d8E6', + weight: 100, + }, +]; +const rep2MembersMainnet: BridgeManagerMemberStruct[] = [ + { + operator: '0x4b3844A29CFA5824F53e2137Edb6dc2b54501BeA', + governor: '0xe880802580a1fbdef67ace39d1b21c5b2c74f059', + }, + { + operator: '0x4a4217d8751a027D853785824eF40522c512A3Fe', + governor: '0x4b18cebeb9797ea594b5977109cc07b21c37e8c3', + }, + { + operator: '0x32cB6da260726BB2192c4085B857aFD945A215Cb', + governor: '0xa441f1399c8c023798586fbbbcf35f27279638a1', + }, + { + operator: '0xA91D05b7c6e684F43E8Fe0c25B3c4Bb1747A2a9E', + governor: '0x72a69b04b59c36fced19ac54209bef878e84fcbf', + }, + { + operator: '0xe38aFbE7738b6Ec4280A6bCa1176c1C1A928A19C', + governor: '0xe258f9996723b910712d6e67ada4eafc15f7f101', + }, + { + operator: '0xE795F18F2F5DF5a666994e839b98263Dba86C902', + governor: '0x020dd9a5e318695a61dda88db7ad077ec306e3e9', + }, + { + operator: '0x772112C7e5dD4ed663e844e79d77c1569a2E88ce', + governor: '0x2d593A0087029501eE419b9415DeC3fAC195FE4A', + }, + { + operator: '0xF0c48B7F020BB61e6A3500AbC4b4954Bde7A2039', + governor: '0x9b0612e43855ef9a7c329ee89653ba45273b550e', + }, + { + operator: '0x063105D0E7215B703909a7274FE38393302F3134', + governor: '0x47cfcb64f8ea44d6ea7fab32f13efa2f8e65eec1', + }, + { + operator: '0xD9d5b3E58fa693B468a20C716793B18A1195380a', + governor: '0xad23e87306aa3c7b95ee760e86f40f3021e5fa18', + }, + { + operator: '0xff30Ed09E3AE60D39Bce1727ee3292fD76A6FAce', + governor: '0xbacb04ea617b3e5eee0e3f6e8fcb5ba886b83958', + }, + { + operator: '0x8c4AD2DC12AdB9aD115e37EE9aD2e00E343EDf85', + governor: '0x77ab649caa7b4b673c9f2cf069900df48114d79d', + }, + { + operator: '0x73f5B22312B7B2B3B1Cd179fC62269aB369c8206', + governor: '0x0dca20728c8bb7173d3452559f40e95c60915799', + }, + { + operator: '0x5e04DC8156ce222289d52487dbAdCb01C8c990f9', + governor: '0x0d48adbdc523681c0dee736dbdc4497e02bec210', + }, + { + operator: '0x564DcB855Eb360826f27D1Eb9c57cbbe6C76F50F', + governor: '0xea172676e4105e92cc52dbf45fd93b274ec96676', + }, + { + operator: '0xEC5c90401F95F8c49b1E133E94F09D85b21d96a4', + governor: '0xed448901cc62be10c5525ba19645ddca1fd9da1d', + }, + { + operator: '0x332253265e36689D9830E57112CD1aaDB1A773f9', + governor: '0x8d4f4e4ba313c4332e720445d8268e087d5c19b8', + }, + { + operator: '0x236aF2FFdb611B14e3042A982d13EdA1627d9C96', + governor: '0x58aBcBCAb52dEE942491700CD0DB67826BBAA8C6', + }, + { + operator: '0x54C8C42F07007D43c3049bEF6f10eA68687d43ef', + governor: '0x4620fb95eabdab4bf681d987e116e0aaef1adef2', + }, + { + operator: '0x66225AcC78Be789C57a11C9a18F051C779d678B5', + governor: '0xc092fa0c772b3c850e676c57d8737bb39084b9ac', + }, + { + operator: '0xf4682B9263d1ba9bd9Db09dA125708607d1eDd3a', + governor: '0x60c4b72fc62b3e3a74e283aa9ba20d61dd4d8f1b', + }, + { + operator: '0xc23F2907Bc11848B5d5cEdBB835e915D7b760d99', + governor: '0xed3805fb65ff51a99fef4676bdbc97abeca93d11', + }, +].map((member) => { + return { ...member, weight: 100 }; +}); + export const bridgeManagerConf: BridgeManagerConfig = { [Network.Hardhat]: undefined, [Network.Goerli]: { @@ -82,6 +182,20 @@ export const bridgeManagerConf: BridgeManagerConfig = { }, ], }, + [Network.Mainnet]: { + numerator: 70, + denominator: 100, + expiryDuration: 14 * 86400, // 14 days + members: rep2MembersMainnet, + // members: rep2MemberMainnetTemp, + }, + [Network.Ethereum]: { + numerator: 70, + denominator: 100, + expiryDuration: 14 * 86400, // 14 days + members: rep2MembersMainnet, + // members: rep2MemberMainnetTemp, + }, }; export interface BridgeRewardArguments { @@ -101,7 +215,11 @@ export const bridgeRewardConf: BridgeRewardConfig = { [Network.Local]: defaultBridgeRewardConf, [Network.Devnet]: defaultBridgeRewardConf, [Network.Testnet]: { - rewardPerPeriod: BigNumber.from(10).pow(18), // 1 RON per block, + rewardPerPeriod: BigNumber.from(10).pow(18), // 1 RON per period, topupAmount: BigNumber.from(10).pow(18).mul(1_000_000), // 1M RON }, + [Network.Mainnet]: { + rewardPerPeriod: BigNumber.from('2739726027397260273972'), // (1M/365) ~ 2739.7260 RON per period, + topupAmount: 0, + }, }; diff --git a/src/configs/config.ts b/src/configs/config.ts index 9d14f20cf..746e28e1e 100644 --- a/src/configs/config.ts +++ b/src/configs/config.ts @@ -144,6 +144,7 @@ export const stakingVestingConfig: StakingVestingConfig = { blockProducerBonusPerBlock: BigNumber.from('2853881278540000000'), // 2.85388127854 RON per block bridgeOperatorBonusPerBlock: BigNumber.from('95129375950000000'), // 0.09512937595 RON per block topupAmount: 0, + fastFinalityRewardPercent: 50, // 0.5% }, }; diff --git a/src/deploy/calculate-address/calculate-bridge.ts b/src/deploy/calculate-address/calculate-bridge.ts index 9692cd460..ca75a7095 100644 --- a/src/deploy/calculate-address/calculate-bridge.ts +++ b/src/deploy/calculate-address/calculate-bridge.ts @@ -37,8 +37,8 @@ deploy.dependencies = [ 'BridgeTrackingLogic', 'BridgeSlashLogic', 'BridgeRewardLogic', - 'MainchainGatewayV2Logic', - 'RoninGatewayV2Logic', + 'MainchainGatewayV3Logic', + 'RoninGatewayV3Logic', ]; export default deploy; diff --git a/src/deploy/logic/mainchain-gateway-v2.ts b/src/deploy/logic/mainchain-gateway-v3.ts similarity index 79% rename from src/deploy/logic/mainchain-gateway-v2.ts rename to src/deploy/logic/mainchain-gateway-v3.ts index bee7e0a31..9de4e16f4 100644 --- a/src/deploy/logic/mainchain-gateway-v2.ts +++ b/src/deploy/logic/mainchain-gateway-v3.ts @@ -11,13 +11,13 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const { deploy } = deployments; const { deployer } = await getNamedAccounts(); - await deploy('MainchainGatewayV2Logic', { - contract: 'MainchainGatewayV2', + await deploy('MainchainGatewayV3Logic', { + contract: 'MainchainGatewayV3', from: deployer, log: true, }); }; -deploy.tags = ['MainchainGatewayV2Logic']; +deploy.tags = ['MainchainGatewayV3Logic']; export default deploy; diff --git a/src/deploy/logic/ronin-gateway-v2.ts b/src/deploy/logic/ronin-gateway-v3.ts similarity index 83% rename from src/deploy/logic/ronin-gateway-v2.ts rename to src/deploy/logic/ronin-gateway-v3.ts index 7949b0b4f..8f2484372 100644 --- a/src/deploy/logic/ronin-gateway-v2.ts +++ b/src/deploy/logic/ronin-gateway-v3.ts @@ -13,13 +13,13 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme let nonce = await ethers.provider.getTransactionCount(deployer); - await deploy('RoninGatewayV2Logic', { - contract: 'RoninGatewayV2', + await deploy('RoninGatewayV3Logic', { + contract: 'RoninGatewayV3', from: deployer, log: true, }); }; -deploy.tags = ['RoninGatewayV2Logic']; +deploy.tags = ['RoninGatewayV3Logic']; export default deploy; diff --git a/src/deploy/proxy/bridge-reward-proxy.ts b/src/deploy/proxy/bridge-reward-proxy.ts index 4dfb924bc..51717a9d5 100644 --- a/src/deploy/proxy/bridge-reward-proxy.ts +++ b/src/deploy/proxy/bridge-reward-proxy.ts @@ -19,18 +19,29 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const logicContract = await deployments.get('BridgeRewardLogic'); let validatorContractAddress: Address; + let bridgeTrackingContractAddress: Address; + let dposGAAddress: Address; if (network.name == Network.Hardhat) { validatorContractAddress = generalRoninConf[network.name]!.validatorContract?.address!; + bridgeTrackingContractAddress = generalRoninConf[network.name]!.bridgeTrackingContract?.address!; + dposGAAddress = generalRoninConf[network.name]!.governanceAdmin?.address!; } else { const validatorContractDeployment = await deployments.get('RoninValidatorSetProxy'); validatorContractAddress = validatorContractDeployment.address; + + const bridgeTrackingContractDeployment = await deployments.get('BridgeTrackingProxy'); + bridgeTrackingContractAddress = bridgeTrackingContractDeployment.address; + + const dposGADeployment = await deployments.get('RoninGovernanceAdmin'); + dposGAAddress = dposGADeployment.address; } const data = new BridgeReward__factory().interface.encodeFunctionData('initialize', [ generalRoninConf[network.name]!.bridgeManagerContract?.address, - generalRoninConf[network.name]!.bridgeTrackingContract?.address, + bridgeTrackingContractAddress, generalRoninConf[network.name]!.bridgeSlashContract?.address, validatorContractAddress, + dposGAAddress, bridgeRewardConf[network.name]!.rewardPerPeriod, ]); diff --git a/src/deploy/proxy/bridge-slash-proxy.ts b/src/deploy/proxy/bridge-slash-proxy.ts index 3a4660522..27886865c 100644 --- a/src/deploy/proxy/bridge-slash-proxy.ts +++ b/src/deploy/proxy/bridge-slash-proxy.ts @@ -17,17 +17,28 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const logicContract = await deployments.get('BridgeSlashLogic'); let validatorContractAddress: Address; + let bridgeTrackingContractAddress: Address; + let dposGAAddress: Address; if (network.name == Network.Hardhat) { validatorContractAddress = generalRoninConf[network.name]!.validatorContract?.address!; + bridgeTrackingContractAddress = generalRoninConf[network.name]!.bridgeTrackingContract?.address!; + dposGAAddress = generalRoninConf[network.name]!.governanceAdmin?.address!; } else { const validatorContractDeployment = await deployments.get('RoninValidatorSetProxy'); validatorContractAddress = validatorContractDeployment.address; + + const bridgeTrackingContractDeployment = await deployments.get('BridgeTrackingProxy'); + bridgeTrackingContractAddress = bridgeTrackingContractDeployment.address; + + const dposGADeployment = await deployments.get('RoninGovernanceAdmin'); + dposGAAddress = dposGADeployment.address; } const data = new BridgeSlash__factory().interface.encodeFunctionData('initialize', [ validatorContractAddress, generalRoninConf[network.name]!.bridgeManagerContract?.address, - generalRoninConf[network.name]!.bridgeTrackingContract?.address, + bridgeTrackingContractAddress, + dposGAAddress, ]); const deployment = await deploy('BridgeSlashProxy', { @@ -41,6 +52,6 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme }; deploy.tags = ['BridgeSlashProxy']; -deploy.dependencies = ['BridgeSlashLogic', '_HelperBridgeCalculate', 'BridgeTrackingProxy']; +deploy.dependencies = ['BridgeSlashLogic', '_HelperBridgeCalculate']; export default deploy; diff --git a/src/deploy/proxy/mainchain-gateway-v2-proxy.ts b/src/deploy/proxy/mainchain-gateway-v3-proxy.ts similarity index 86% rename from src/deploy/proxy/mainchain-gateway-v2-proxy.ts rename to src/deploy/proxy/mainchain-gateway-v3-proxy.ts index 0190dda7c..3ff986902 100644 --- a/src/deploy/proxy/mainchain-gateway-v2-proxy.ts +++ b/src/deploy/proxy/mainchain-gateway-v3-proxy.ts @@ -5,7 +5,7 @@ import { gatewayAccountSet, namedAddresses } from '../../configs/addresses'; import { generalMainchainConf, mainchainNetworks } from '../../configs/config'; import { GatewayThreshold, gatewayThreshold, mainchainMappedToken, roninChainId } from '../../configs/gateway'; import { verifyAddress } from '../../script/verify-address'; -import { MainchainGatewayV2__factory } from '../../types'; +import { MainchainGatewayV3__factory } from '../../types'; const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironment) => { if (!mainchainNetworks.includes(network.name!)) { @@ -15,7 +15,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const { deploy } = deployments; const { deployer } = await getNamedAccounts(); - const logicContract = await deployments.get('MainchainGatewayV2Logic'); + const logicContract = await deployments.get('MainchainGatewayV3Logic'); const weth = namedAddresses['weth'][network.name]; const gatewayRoleSetter = namedAddresses['gatewayRoleSetter'][network.name]; @@ -31,7 +31,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme dailyWithdrawalLimits, } = mainchainMappedToken[network.name]!; - const data = new MainchainGatewayV2__factory().interface.encodeFunctionData('initialize', [ + const data = new MainchainGatewayV3__factory().interface.encodeFunctionData('initialize', [ gatewayRoleSetter, weth, roninChainId[network.name], @@ -43,7 +43,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme standards, ]); - const deployment = await deploy('MainchainGatewayV2Proxy', { + const deployment = await deploy('MainchainGatewayV3Proxy', { contract: 'TransparentUpgradeableProxyV2', from: deployer, log: true, @@ -53,7 +53,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme verifyAddress(deployment.address, generalMainchainConf[network.name].bridgeContract); }; -deploy.tags = ['MainchainGatewayV2Proxy']; -deploy.dependencies = ['MainchainGatewayV2Logic', '_HelperBridgeCalculate']; +deploy.tags = ['MainchainGatewayV3Proxy']; +deploy.dependencies = ['MainchainGatewayV3Logic', '_HelperBridgeCalculate']; export default deploy; diff --git a/src/deploy/proxy/ronin-gateway-v2-proxy.ts b/src/deploy/proxy/ronin-gateway-v3-proxy.ts similarity index 78% rename from src/deploy/proxy/ronin-gateway-v2-proxy.ts rename to src/deploy/proxy/ronin-gateway-v3-proxy.ts index 2fdf9f66a..ad8e4aff6 100644 --- a/src/deploy/proxy/ronin-gateway-v2-proxy.ts +++ b/src/deploy/proxy/ronin-gateway-v3-proxy.ts @@ -10,7 +10,7 @@ import { roninGatewayThreshold, roninMappedToken, } from '../../configs/gateway'; -import { RoninGatewayV2__factory } from '../../types'; +import { RoninGatewayV3__factory } from '../../types'; const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironment) => { if (!roninchainNetworks.includes(network.name!)) { @@ -20,7 +20,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const { deploy, execute } = deployments; const { deployer } = await getNamedAccounts(); - // const logicContract = await deployments.get('RoninGatewayV2Logic'); + // const logicContract = await deployments.get('RoninGatewayV3Logic'); const logicContractAddress = '0xF7460e5A14Ac8aC700aF4e564228a9FAff2E9C04'; const gatewayRoleSetter = namedAddresses['gatewayRoleSetter'][network.name]; @@ -29,7 +29,7 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const { numerator, denominator } = gatewayThreshold[network.name]! as GatewayThreshold; const { mainchainTokens, roninTokens, standards, minimumThresholds, chainIds } = roninMappedToken[network.name]!; - const data = new RoninGatewayV2__factory().interface.encodeFunctionData('initialize', [ + const data = new RoninGatewayV3__factory().interface.encodeFunctionData('initialize', [ gatewayRoleSetter, numerator, denominator, @@ -41,24 +41,24 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme standards, ]); - const deployment = await deploy('RoninGatewayV2Proxy', { + const deployment = await deploy('RoninGatewayV3Proxy', { contract: 'TransparentUpgradeableProxyV2', from: deployer, log: true, args: [logicContractAddress, deployer, data], }); - const setValidatorData = new RoninGatewayV2__factory().interface.encodeFunctionData('setValidatorContract', [ + const setValidatorData = new RoninGatewayV3__factory().interface.encodeFunctionData('setValidatorContract', [ '0x262a3cab2bbb6fc414eb78e6755bf544b97dac01', ]); - await execute('RoninGatewayV2Proxy', { from: deployer, log: true }, 'functionDelegateCall', setValidatorData); + await execute('RoninGatewayV3Proxy', { from: deployer, log: true }, 'functionDelegateCall', setValidatorData); - const setBridgeTracking = new RoninGatewayV2__factory().interface.encodeFunctionData('setBridgeTrackingContract', [ + const setBridgeTracking = new RoninGatewayV3__factory().interface.encodeFunctionData('setBridgeTrackingContract', [ '0xBf9e491df628A3ab6daacb7b288032C1f84db52C', ]); - await execute('RoninGatewayV2Proxy', { from: deployer, log: true }, 'functionDelegateCall', setBridgeTracking); + await execute('RoninGatewayV3Proxy', { from: deployer, log: true }, 'functionDelegateCall', setBridgeTracking); }; -deploy.tags = ['RoninGatewayV2Proxy']; +deploy.tags = ['RoninGatewayV3Proxy']; export default deploy; diff --git a/src/deploy/ronin-bridge-manager.ts b/src/deploy/ronin-bridge-manager.ts index a8739e2db..f04467691 100644 --- a/src/deploy/ronin-bridge-manager.ts +++ b/src/deploy/ronin-bridge-manager.ts @@ -5,6 +5,8 @@ import { generalRoninConf, roninchainNetworks } from '../configs/config'; import { TargetOptionStruct, bridgeManagerConf } from '../configs/bridge-manager'; import { verifyAddress } from '../script/verify-address'; import { TargetOption } from '../script/proposal'; +import { Network } from '../utils'; +import { Address } from 'hardhat-deploy/dist/types'; const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironment) => { if (!roninchainNetworks.includes(network.name!)) { @@ -14,6 +16,14 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme const { deploy } = deployments; const { deployer } = await getNamedAccounts(); + let bridgeTrackingContractAddress: Address; + if (network.name == Network.Hardhat) { + bridgeTrackingContractAddress = generalRoninConf[network.name]!.bridgeTrackingContract?.address!; + } else { + const bridgeTrackingContractDeployment = await deployments.get('BridgeTrackingProxy'); + bridgeTrackingContractAddress = bridgeTrackingContractDeployment.address; + } + const targets: TargetOptionStruct[] = [ { option: TargetOption.GatewayContract, @@ -27,6 +37,10 @@ const deploy = async ({ getNamedAccounts, deployments }: HardhatRuntimeEnvironme option: TargetOption.BridgeSlash, target: generalRoninConf[network.name].bridgeSlashContract?.address!, }, + { + option: TargetOption.BridgeTracking, + target: bridgeTrackingContractAddress, + }, ]; const deployment = await deploy('RoninBridgeManager', { diff --git a/src/script/bridge.ts b/src/script/bridge.ts index dd532af0a..49456a0c2 100644 --- a/src/script/bridge.ts +++ b/src/script/bridge.ts @@ -1,6 +1,6 @@ import { AbiCoder, keccak256, _TypedDataEncoder } from 'ethers/lib/utils'; -import { InfoStruct, OwnerStruct, ReceiptStruct } from '../types/IMainchainGatewayV2'; +import { InfoStruct, OwnerStruct, ReceiptStruct } from '../types/IMainchainGatewayV3'; // keccak256("TokenInfo(uint8 erc,uint256 id,uint256 quantity)"); const tokenInfoTypeHash = '0x1e2b74b2a792d5c0f0b6e59b037fa9d43d84fbb759337f0112fcc15ca414fc8d'; diff --git a/src/script/proposal.ts b/src/script/proposal.ts index ba63af1d9..21199a0fa 100644 --- a/src/script/proposal.ts +++ b/src/script/proposal.ts @@ -32,6 +32,7 @@ export enum TargetOption { GatewayContract = 1, BridgeReward = 2, BridgeSlash = 3, + BridgeTracking = 4, } export const ballotParamTypes = ['bytes32', 'bytes32', 'uint8']; diff --git a/src/upgrades/230515-change-min-commission-rate-5-percent.ts b/src/upgrades/230515-change-min-commission-rate-5-percent.ts index 8683adb4c..6282de70c 100644 --- a/src/upgrades/230515-change-min-commission-rate-5-percent.ts +++ b/src/upgrades/230515-change-min-commission-rate-5-percent.ts @@ -8,7 +8,7 @@ import { BigNumber } from 'ethers'; import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { VoteType } from '../script/proposal'; -import { GatewayV2__factory, Staking__factory } from '../types'; +import { GatewayV3__factory, Staking__factory } from '../types'; import { StakingArguments } from '../utils'; import { explorerUrl, proxyCall, proxyInterface } from './upgradeUtils'; import { network } from 'hardhat'; @@ -52,7 +52,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE ]; /// Set new enforcer for gateway - const GatewayInterface = GatewayV2__factory.createInterface(); + const GatewayInterface = GatewayV3__factory.createInterface(); const gatewayInstructions = [ proxyCall(GatewayInterface.encodeFunctionData('setEmergencyPauser', [newRoninPauseEnforcerLogic])), ]; diff --git a/src/upgrades/230516-set-pause-enforcer-mainchain-gateway.ts b/src/upgrades/230516-set-pause-enforcer-mainchain-gateway.ts index 9a1130312..572ca42eb 100644 --- a/src/upgrades/230516-set-pause-enforcer-mainchain-gateway.ts +++ b/src/upgrades/230516-set-pause-enforcer-mainchain-gateway.ts @@ -6,7 +6,7 @@ /// Governor who proposes this proposal must manually vote it after running this script. import { HardhatRuntimeEnvironment } from 'hardhat/types'; -import { GatewayV2__factory } from '../types'; +import { GatewayV3__factory } from '../types'; import { explorerUrl, proxyCall } from './upgradeUtils'; import { network } from 'hardhat'; @@ -24,7 +24,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE } /// Set new enforcer for gateway - const GatewayInterface = GatewayV2__factory.createInterface(); + const GatewayInterface = GatewayV3__factory.createInterface(); const gatewayInstructions = [ proxyCall(GatewayInterface.encodeFunctionData('setEmergencyPauser', [newMainchainPauseEnforcerLogic])), ]; diff --git a/src/upgrades/230627-upgrade-v0.5.2-testnet.ts b/src/upgrades/230627-upgrade-v0.5.2-testnet.ts index 701bda87a..c508bdc94 100644 --- a/src/upgrades/230627-upgrade-v0.5.2-testnet.ts +++ b/src/upgrades/230627-upgrade-v0.5.2-testnet.ts @@ -8,7 +8,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyCall, proxyInterface } from './upgradeUtils'; import { VoteType } from '../script/proposal'; -import { RoninGatewayV2__factory, SlashIndicator__factory } from '../types'; +import { RoninGatewayV3__factory, SlashIndicator__factory } from '../types'; import { generalRoninConf, roninchainNetworks } from '../configs/config'; import { network } from 'hardhat'; @@ -25,7 +25,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const BridgeTrackingLogicDepl = await deployments.get('BridgeTrackingLogic'); const MaintenanceLogicDepl = await deployments.get('MaintenanceLogic'); - const RoninGatewayV2LogicDepl = await deployments.get('RoninGatewayV2Logic'); + const RoninGatewayV3LogicDepl = await deployments.get('RoninGatewayV3Logic'); const RoninValidatorSetLogicDepl = await deployments.get('RoninValidatorSetLogic'); const SlashIndicatorLogicDepl = await deployments.get('SlashIndicatorLogic'); const StakingLogicDepl = await deployments.get('StakingLogic'); @@ -39,9 +39,9 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const StakingProxy = await deployments.get('StakingProxy'); const StakingVestingProxy = await deployments.get('StakingVestingProxy'); const RoninGatewayPauseEnforcerProxy = await deployments.get('RoninGatewayPauseEnforcerProxy'); - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; - const initializeV2_SIG = new RoninGatewayV2__factory().interface.encodeFunctionData('initializeV2'); + const initializeV2_SIG = new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV2'); const BridgeTrackingInstr = [ proxyInterface.encodeFunctionData('upgradeToAndCall', [BridgeTrackingLogicDepl.address, initializeV2_SIG]), @@ -49,10 +49,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const MaintenanceInstr = [ proxyInterface.encodeFunctionData('upgradeToAndCall', [MaintenanceLogicDepl.address, initializeV2_SIG]), ]; - const RoninGatewayV2Instr = [ - proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV2LogicDepl.address, initializeV2_SIG]), + const RoninGatewayV3Instr = [ + proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV3LogicDepl.address, initializeV2_SIG]), proxyCall( - new RoninGatewayV2__factory().interface.encodeFunctionData('setEmergencyPauser', [ + new RoninGatewayV3__factory().interface.encodeFunctionData('setEmergencyPauser', [ RoninGatewayPauseEnforcerProxy.address, ]) ), @@ -87,7 +87,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE [ ...BridgeTrackingInstr.map(() => BridgeTrackingProxy.address), ...MaintenanceInstr.map(() => MaintenanceProxy.address), - ...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr), + ...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr), ...RoninValidatorSetInstr.map(() => RoninValidatorSetProxy.address), ...SlashIndicatorInstr.map(() => SlashIndicatorProxy.address), ...StakingInstr.map(() => StakingProxy.address), @@ -96,7 +96,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE [ ...BridgeTrackingInstr, ...MaintenanceInstr, - ...RoninGatewayV2Instr, + ...RoninGatewayV3Instr, ...RoninValidatorSetInstr, ...SlashIndicatorInstr, ...StakingInstr, @@ -105,7 +105,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE [ ...BridgeTrackingInstr, ...MaintenanceInstr, - ...RoninGatewayV2Instr, + ...RoninGatewayV3Instr, ...RoninValidatorSetInstr, ...SlashIndicatorInstr, ...StakingInstr, @@ -114,7 +114,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE [ ...BridgeTrackingInstr, ...MaintenanceInstr, - ...RoninGatewayV2Instr, + ...RoninGatewayV3Instr, ...RoninValidatorSetInstr, ...SlashIndicatorInstr, ...StakingInstr, diff --git a/src/upgrades/230628-upgrade-GA.ts b/src/upgrades/230628-upgrade-GA.ts index 7bf6732f7..5df09b951 100644 --- a/src/upgrades/230628-upgrade-GA.ts +++ b/src/upgrades/230628-upgrade-GA.ts @@ -33,7 +33,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const SlashIndicatorProxy = await deployments.get('SlashIndicatorProxy'); const StakingProxy = await deployments.get('StakingProxy'); const StakingVestingProxy = await deployments.get('StakingVestingProxy'); - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; const GAInstr = [ proxyInterface.encodeFunctionData('changeProxyAdmin', [BridgeTrackingProxy.address, newGAAddr]), @@ -44,7 +44,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE proxyInterface.encodeFunctionData('changeProxyAdmin', [SlashIndicatorProxy.address, newGAAddr]), proxyInterface.encodeFunctionData('changeProxyAdmin', [StakingProxy.address, newGAAddr]), proxyInterface.encodeFunctionData('changeProxyAdmin', [StakingVestingProxy.address, newGAAddr]), - proxyInterface.encodeFunctionData('changeProxyAdmin', [RoninGatewayV2Addr, newGAAddr]), + proxyInterface.encodeFunctionData('changeProxyAdmin', [RoninGatewayV3Addr, newGAAddr]), ]; const blockNumBefore = await ethers.provider.getBlockNumber(); diff --git a/src/upgrades/230704-upgrade-v0.5.2-testnet-3.ts b/src/upgrades/230704-upgrade-v0.5.2-testnet-3.ts index df034af57..ba6893e32 100644 --- a/src/upgrades/230704-upgrade-v0.5.2-testnet-3.ts +++ b/src/upgrades/230704-upgrade-v0.5.2-testnet-3.ts @@ -5,7 +5,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyCall, proxyInterface } from './upgradeUtils'; import { VoteType } from '../script/proposal'; -import { RoninGatewayV2__factory } from '../types'; +import { RoninGatewayV3__factory } from '../types'; import { generalRoninConf, roninchainNetworks } from '../configs/config'; import { network } from 'hardhat'; @@ -21,15 +21,15 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE /// Upgrade contracts const RoninGatewayPauseEnforcerProxy = await deployments.get('RoninGatewayPauseEnforcerProxy'); - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; - const RoninGatewayV2LogicDepl = await deployments.get('RoninGatewayV2Logic'); - const initializeV2_SIG = new RoninGatewayV2__factory().interface.encodeFunctionData('initializeV2'); + const RoninGatewayV3LogicDepl = await deployments.get('RoninGatewayV3Logic'); + const initializeV2_SIG = new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV2'); - const RoninGatewayV2Instr = [ - proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV2LogicDepl.address, initializeV2_SIG]), + const RoninGatewayV3Instr = [ + proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV3LogicDepl.address, initializeV2_SIG]), proxyCall( - new RoninGatewayV2__factory().interface.encodeFunctionData('setEmergencyPauser', [ + new RoninGatewayV3__factory().interface.encodeFunctionData('setEmergencyPauser', [ RoninGatewayPauseEnforcerProxy.address, ]) ), @@ -46,10 +46,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE { from: governor, log: true }, 'proposeProposalForCurrentNetwork', proposalExpiryTimestamp, // expiryTimestamp - [...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr)], // targets - [...RoninGatewayV2Instr].map(() => 0), // values - [...RoninGatewayV2Instr], // datas - [...RoninGatewayV2Instr].map(() => 1_000_000), // gasAmounts + [...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr)], // targets + [...RoninGatewayV3Instr].map(() => 0), // values + [...RoninGatewayV3Instr], // datas + [...RoninGatewayV3Instr].map(() => 1_000_000), // gasAmounts VoteType.For // ballot type ); diff --git a/src/upgrades/230704-vote-v0.5.2-testnet-3.ts b/src/upgrades/230704-vote-v0.5.2-testnet-3.ts index 7d1a67a3b..4df0782be 100644 --- a/src/upgrades/230704-vote-v0.5.2-testnet-3.ts +++ b/src/upgrades/230704-vote-v0.5.2-testnet-3.ts @@ -5,7 +5,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyCall, proxyInterface } from './upgradeUtils'; import { VoteType } from '../script/proposal'; -import { RoninGatewayV2__factory } from '../types'; +import { RoninGatewayV3__factory } from '../types'; import { generalRoninConf, roninchainNetworks } from '../configs/config'; import { network } from 'hardhat'; import { ProposalDetailStruct } from '../types/GovernanceAdmin'; @@ -21,16 +21,16 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE /// Upgrade contracts - const RoninGatewayV2LogicDepl = await deployments.get('RoninGatewayV2Logic'); - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3LogicDepl = await deployments.get('RoninGatewayV3Logic'); + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; const RoninGatewayPauseEnforcerProxy = await deployments.get('RoninGatewayPauseEnforcerProxy'); - const initializeV2_SIG = new RoninGatewayV2__factory().interface.encodeFunctionData('initializeV2'); + const initializeV2_SIG = new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV2'); - const RoninGatewayV2Instr = [ - proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV2LogicDepl.address, initializeV2_SIG]), + const RoninGatewayV3Instr = [ + proxyInterface.encodeFunctionData('upgradeToAndCall', [RoninGatewayV3LogicDepl.address, initializeV2_SIG]), proxyCall( - new RoninGatewayV2__factory().interface.encodeFunctionData('setEmergencyPauser', [ + new RoninGatewayV3__factory().interface.encodeFunctionData('setEmergencyPauser', [ RoninGatewayPauseEnforcerProxy.address, ]) ), @@ -51,10 +51,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE chainId: network.config.chainId!, expiryTimestamp: proposalExpiryTimestamp, nonce, - targets: [...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr)], // targets - values: [...RoninGatewayV2Instr].map(() => 0), // values - calldatas: [...RoninGatewayV2Instr], // datas - gasAmounts: [...RoninGatewayV2Instr].map(() => 1_000_000), // gasAmounts + targets: [...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr)], // targets + values: [...RoninGatewayV3Instr].map(() => 0), // values + calldatas: [...RoninGatewayV3Instr], // datas + gasAmounts: [...RoninGatewayV3Instr].map(() => 1_000_000), // gasAmounts }; const tx = await execute( diff --git a/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-mainchain.ts b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-mainchain.ts new file mode 100644 index 000000000..649bc2fdc --- /dev/null +++ b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-mainchain.ts @@ -0,0 +1,84 @@ +import { HardhatRuntimeEnvironment } from 'hardhat/types'; +import { ProposalSegmentArguments, defaultSegment, explorerUrl, proxyInterface } from '../upgradeUtils'; +import { generalMainchainConf, roninchainNetworks } from '../../configs/config'; +import { companionNetworks, network } from 'hardhat'; +import { MainchainGatewayV3__factory } from '../../types'; + +const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeEnvironment) => { + if (!roninchainNetworks.includes(network.name!)) { + console.log('Not on Ronin chain. Abort!'); + return; + } + + const { execute } = deployments; + let { governor } = await getNamedAccounts(); // NOTE: Should double check the `governor` account in the `hardhat.config.ts` file + console.log('Governor:', governor); + + const companionNetwork = companionNetworks['mainchain']; + const companionNetworkName = network.companionNetworks['mainchain']; + const companionNetworkChainId = await companionNetwork.getChainId(); + + deployments.log('Using deployments on companion network. ChainId:', companionNetworkChainId); + const MainchainBridgeManager = await companionNetwork.deployments.get('MainchainBridgeManager'); + const MainchainGatewayV3Logic = await companionNetwork.deployments.get('MainchainGatewayV3Logic'); + const MainchainGatewayV3Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; + + let proposalSegments: ProposalSegmentArguments[] = [ + // Upgrade `MainchainGatewayV3` and bump initV2 + { + ...defaultSegment, + target: MainchainGatewayV3Addr, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + MainchainGatewayV3Logic.address, + new MainchainGatewayV3__factory().interface.encodeFunctionData('initializeV2', [ + MainchainBridgeManager.address, + ]), + ]), + }, + // Change admin of `MainchainGatewayV3` to `MainchainBridgeManager` + { + ...defaultSegment, + target: MainchainGatewayV3Addr, + data: proxyInterface.encodeFunctionData('changeAdmin', [MainchainBridgeManager.address]), + }, + ]; + + console.log(proposalSegments); + // return; // TODO: remove when actual run + + ////////////////////////////////////////// + // Propose the proposal + ////////////////////////////////////////// + const blockNumBefore = await ethers.provider.getBlockNumber(); + const blockBefore = await ethers.provider.getBlock(blockNumBefore); + const timestampBefore = blockBefore.timestamp; + const proposalExpiryTimestamp = timestampBefore + 3600 * 24 * 10; // expired in 10 days + + const tx = await execute( + 'RoninGovernanceAdmin', + { from: governor, log: true }, + 'propose', + + // function propose( + // uint256 _chainId, + // uint256 _expiryTimestamp, + // address[] calldata _targets, + // uint256[] calldata _values, + // bytes[] calldata _calldatas, + // uint256[] calldata _gasAmounts + // ) + + companionNetworkChainId, + proposalExpiryTimestamp, // expiryTimestamp + [...proposalSegments.map((_) => _.target)], // targets + [...proposalSegments.map((_) => _.value)], // values + [...proposalSegments.map((_) => _.data)], // datas + [...proposalSegments.map((_) => _.gasAmount)] // gasAmounts + ); + deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); +}; + +// yarn hardhat deploy --tags 230231013__ProposalOnMainchain__V0_6_4 --network ronin-mainnet +deploy.tags = ['230231013__ProposalOnMainchain__V0_6_4']; + +export default deploy; diff --git a/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-roninchain.ts b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-roninchain.ts new file mode 100644 index 000000000..9127d4792 --- /dev/null +++ b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231013-proposal-on-roninchain.ts @@ -0,0 +1,311 @@ +import { HardhatRuntimeEnvironment } from 'hardhat/types'; +import { Instance, ProposalSegmentArguments, defaultSegment, explorerUrl, proxyInterface } from '../upgradeUtils'; +import { VoteType } from '../../script/proposal'; +import { roninchainNetworks, stakingVestingConfig } from '../../configs/config'; +import { network } from 'hardhat'; +import { + BridgeReward__factory, + BridgeSlash__factory, + BridgeTracking__factory, + Maintenance__factory, + RoninGatewayV3__factory, + RoninGovernanceAdmin__factory, + RoninValidatorSet__factory, + SlashIndicator__factory, + StakingVesting__factory, + Staking__factory, +} from '../../types'; +import { ProposalDetailStruct } from '../../types/GovernanceAdmin'; +import { Address } from 'hardhat-deploy/dist/types'; + +const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeEnvironment) => { + if (!roninchainNetworks.includes(network.name!)) { + return; + } + + const { execute } = deployments; + let { governor } = await getNamedAccounts(); // NOTE: Should double check the `governor` account in the `hardhat.config.ts` file + console.log('Governor:', governor); + + const allDeployments: Instance = { + RoninGovernanceAdmin: await deployments.get('RoninGovernanceAdmin'), + RoninValidatorSetProxy: await deployments.get('RoninValidatorSetProxy'), + ProfileProxy: await deployments.get('ProfileProxy'), + StakingProxy: await deployments.get('StakingProxy'), + SlashIndicatorProxy: await deployments.get('SlashIndicatorProxy'), + MaintenanceProxy: await deployments.get('MaintenanceProxy'), + RoninTrustedOrganizationProxy: await deployments.get('RoninTrustedOrganizationProxy'), + BridgeTrackingProxy: await deployments.get('BridgeTrackingProxy'), + StakingVestingProxy: await deployments.get('StakingVestingProxy'), + FastFinalityTrackingProxy: await deployments.get('FastFinalityTrackingProxy'), + RoninBridgeManager: await deployments.get('RoninBridgeManager'), + RoninGatewayV3Proxy: await deployments.get('RoninGatewayV3Proxy'), + BridgeSlashProxy: await deployments.get('BridgeSlashProxy'), + BridgeRewardProxy: await deployments.get('BridgeRewardProxy'), + + RoninValidatorSetLogic: await deployments.get('RoninValidatorSetLogic'), + ProfileLogic: await deployments.get('ProfileLogic'), + StakingLogic: await deployments.get('StakingLogic'), + SlashIndicatorLogic: await deployments.get('SlashIndicatorLogic'), + MaintenanceLogic: await deployments.get('MaintenanceLogic'), + RoninTrustedOrganizationLogic: await deployments.get('RoninTrustedOrganizationLogic'), + BridgeTrackingLogic: await deployments.get('BridgeTrackingLogic'), + StakingVestingLogic: await deployments.get('StakingVestingLogic'), + FastFinalityTrackingLogic: await deployments.get('FastFinalityTrackingLogic'), + RoninGatewayV3Logic: await deployments.get('RoninGatewayV3Logic'), + }; + + // Upgrade DPoS Contracts + // See `script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional.s.sol` + let proposalPart1 = await upgradeDPoSContractSetProposalPart(allDeployments); + + // Upgrade Gateway Contracts & Init REP2 Contracts + // See `script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional_GatewayUpgrade.s.sol` + let proposalPart2 = await upgradeGatewayContractSetProposalPart(allDeployments); + let proposalPart3 = await initREP2GatewayContractSetProposalPart(allDeployments); + let proposalPart4 = await changeAdminGatewayContractsProposalPart(allDeployments); + + let proposalSegments = [...proposalPart1, ...proposalPart2, ...proposalPart3, ...proposalPart4]; + + console.log(proposalSegments); + + // const proposalExpiry = 1698486923; // expired in 10 day + + // const proposalRaw: ProposalDetailStruct = { + // chainId: 2020, + // nonce: 4, + // expiryTimestamp: proposalExpiry, + // targets: [...proposalSegments.map((_) => (_.target as Address)!)], // targets + // values: [...proposalSegments.map((_) => _.value)], // values + // calldatas: [...proposalSegments.map((_) => _.data!)], // datas + // gasAmounts: [...proposalSegments.map((_) => _.gasAmount)], // gasAmounts + // }; + + // const castVoteProposalRaw = new RoninGovernanceAdmin__factory().interface.encodeFunctionData( + // 'castProposalVoteForCurrentNetwork', + // [ + // proposalRaw, + // VoteType.For, // ballot type + // ] + // ); + + // console.log('castVoteProposalRaw'); + // console.log(castVoteProposalRaw); + + // return; // TODO: remove when actual run + + ////////////////////////////////////////// + // Propose the proposal + ////////////////////////////////////////// + const blockNumBefore = await ethers.provider.getBlockNumber(); + const blockBefore = await ethers.provider.getBlock(blockNumBefore); + const timestampBefore = blockBefore.timestamp; + const proposalExpiryTimestamp = timestampBefore + 3600 * 24 * 10; // expired in 10 days + + const tx = await execute( + 'RoninGovernanceAdmin', + { from: governor, log: true }, + 'proposeProposalForCurrentNetwork', + proposalExpiryTimestamp, // expiryTimestamp + [...proposalSegments.map((_) => _.target)], // targets + [...proposalSegments.map((_) => _.value)], // values + [...proposalSegments.map((_) => _.data)], // datas + [...proposalSegments.map((_) => _.gasAmount)], // gasAmounts + VoteType.For // ballot type + ); + deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); +}; + +async function upgradeDPoSContractSetProposalPart(instance: Instance): Promise { + let segments: ProposalSegmentArguments[] = []; + + // upgrade `RoninValidatorSet` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.RoninValidatorSetProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.RoninValidatorSetLogic!.address, + new RoninValidatorSet__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + // bump `RoninValidatorSet` to V3 + segments.push({ + ...defaultSegment, + target: instance.RoninValidatorSetProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new RoninValidatorSet__factory().interface.encodeFunctionData('initializeV3', [ + instance.FastFinalityTrackingProxy!.address, + ]), + ]), + }); + + // upgrade `Staking` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.StakingProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.StakingLogic!.address, + new Staking__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + // upgrade `SlashIndicator` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.SlashIndicatorProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.SlashIndicatorLogic!.address, + new SlashIndicator__factory().interface.encodeFunctionData('initializeV2', [ + instance.RoninGovernanceAdmin!.address, + ]), + ]), + }); + + // bump `SlashIndicator` to V3 + segments.push({ + ...defaultSegment, + target: instance.SlashIndicatorProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new SlashIndicator__factory().interface.encodeFunctionData('initializeV3', [instance.ProfileProxy!.address]), + ]), + }); + + // upgrade `RoninTrustedOrganization` + segments.push({ + ...defaultSegment, + target: instance.RoninTrustedOrganizationProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeTo', [instance.RoninTrustedOrganizationLogic!.address]), + }); + + // upgrade `BridgeTracking` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.BridgeTrackingProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.BridgeTrackingLogic!.address, + new BridgeTracking__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + // upgrade `StakingVesting` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.StakingVestingProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.StakingVestingLogic!.address, + new StakingVesting__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + // bump `StakingVesting` to V3 + segments.push({ + ...defaultSegment, + target: instance.StakingVestingProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new StakingVesting__factory().interface.encodeFunctionData('initializeV3', [ + stakingVestingConfig[network.name]?.fastFinalityRewardPercent!, + ]), + ]), + }); + + // upgrade `Maintenance` and bump to V2 + segments.push({ + ...defaultSegment, + target: instance.MaintenanceProxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.MaintenanceLogic!.address, + new Maintenance__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + return segments; +} + +async function upgradeGatewayContractSetProposalPart(instance: Instance): Promise { + let gatewaySetSegments: ProposalSegmentArguments[] = []; + + // upgrade `RoninGatewayV3` and bump to V2 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.RoninGatewayV3Proxy!.address, + data: proxyInterface.encodeFunctionData('upgradeToAndCall', [ + instance.RoninGatewayV3Logic!.address, + new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV2'), + ]), + }); + + // bump `RoninGatewayV3` to V3 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.RoninGatewayV3Proxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV3', [ + instance.RoninBridgeManager!.address, + ]), + ]), + }); + + // bump `BridgeTracking` to V3 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.BridgeTrackingProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new BridgeTracking__factory().interface.encodeFunctionData('initializeV3', [ + instance.RoninBridgeManager!.address, + instance.BridgeSlashProxy!.address, + instance.BridgeRewardProxy!.address, + instance.RoninGovernanceAdmin!.address, + ]), + ]), + }); + + return gatewaySetSegments; +} + +async function initREP2GatewayContractSetProposalPart(instance: Instance): Promise { + let gatewaySetSegments: ProposalSegmentArguments[] = []; + + // initREP2 `BridgeReward` and bump to V2 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.BridgeRewardProxy!.address, + data: new BridgeReward__factory().interface.encodeFunctionData('initializeREP2'), // Do not transfer admin role to GA when calling without functionDelegateCall + }); + + // initREP2 `BridgeTracking` and bump to V2 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.BridgeTrackingProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new BridgeTracking__factory().interface.encodeFunctionData('initializeREP2'), + ]), + }); + + // initREP2 `BridgeSlash` and bump to V2 + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.BridgeSlashProxy!.address, + data: new BridgeSlash__factory().interface.encodeFunctionData('initializeREP2'), // Do not transfer admin role to GA when calling without functionDelegateCall + }); + + return gatewaySetSegments; +} + +async function changeAdminGatewayContractsProposalPart(instance: Instance): Promise { + let gatewaySetSegments: ProposalSegmentArguments[] = []; + + // change admin of ronin gateway + gatewaySetSegments.push({ + ...defaultSegment, + target: instance.RoninGatewayV3Proxy!.address, + data: proxyInterface.encodeFunctionData('changeAdmin', [instance.RoninBridgeManager!.address]), + }); + + return gatewaySetSegments; +} + +// yarn hardhat deploy --tags 230231013__ProposalOnRoninChain__V0_6_4 --network ronin-mainnet +deploy.tags = ['230231013__ProposalOnRoninChain__V0_6_4']; + +export default deploy; diff --git a/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231016-reconfig-bridge-tracking-for-bridge-set.ts b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231016-reconfig-bridge-tracking-for-bridge-set.ts new file mode 100644 index 000000000..379b15dd5 --- /dev/null +++ b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231016-reconfig-bridge-tracking-for-bridge-set.ts @@ -0,0 +1,89 @@ +import { HardhatRuntimeEnvironment } from 'hardhat/types'; +import { Instance, ProposalSegmentArguments, defaultSegment, explorerUrl, proxyInterface } from '../upgradeUtils'; +import { TargetOption, VoteType } from '../../script/proposal'; +import { + BridgeSlash__factory, + BridgeTracking__factory, + RoninBridgeManager__factory, + RoninGatewayV3__factory, +} from '../../types'; +import { generalRoninConf, roninchainNetworks } from '../../configs/config'; +import { network } from 'hardhat'; +import { BigNumber } from 'ethers'; +import { ContractType } from '../../../test/hardhat_test/helpers/utils'; + +const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeEnvironment) => { + if (!roninchainNetworks.includes(network.name!)) { + return; + } + + const { execute } = deployments; + let { governor } = await getNamedAccounts(); // NOTE: Should double check the `governor` account in the `hardhat.config.ts` file + console.log('Governor:', governor); + + const allDeployments: Instance = { + BridgeTrackingProxy: await deployments.get('BridgeTrackingProxy'), + RoninBridgeManager: await deployments.get('RoninBridgeManager'), + BridgeSlashProxy: await deployments.get('BridgeSlashProxy'), + BridgeRewardProxy: await deployments.get('BridgeRewardProxy'), + }; + + // Upgrade DPoS Contracts + // See `script/20231003-rep-002-rep-003/20231003_REP002AndREP003_RON_NonConditional.s.sol` + let proposalSegments: ProposalSegmentArguments[] = []; + proposalSegments.push({ + ...defaultSegment, + target: allDeployments.RoninBridgeManager!.address, + data: new RoninBridgeManager__factory().interface.encodeFunctionData('updateManyTargetOption', [ + [TargetOption.BridgeTracking], + [allDeployments.BridgeTrackingProxy!.address], + ]), + }); + + proposalSegments.push({ + ...defaultSegment, + target: allDeployments.BridgeSlashProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new BridgeSlash__factory().interface.encodeFunctionData('setContract', [ + ContractType.BRIDGE_TRACKING, + allDeployments.BridgeTrackingProxy!.address, + ]), + ]), + }); + + proposalSegments.push({ + ...defaultSegment, + target: allDeployments.BridgeRewardProxy!.address, + data: proxyInterface.encodeFunctionData('functionDelegateCall', [ + new BridgeSlash__factory().interface.encodeFunctionData('setContract', [ + ContractType.BRIDGE_TRACKING, + allDeployments.BridgeTrackingProxy!.address, + ]), + ]), + }); + + // Propose the proposal + const blockNumBefore = await ethers.provider.getBlockNumber(); + const blockBefore = await ethers.provider.getBlock(blockNumBefore); + const timestampBefore = blockBefore.timestamp; + const proposalExpiryTimestamp = timestampBefore + 3600 * 24 * 10; // expired in 10 days + + const tx = await execute( + 'RoninBridgeManager', + { from: governor, log: true }, + 'proposeProposalForCurrentNetwork', + proposalExpiryTimestamp, // expiryTimestamp + [...proposalSegments.map((_) => _.target)], // targets + [...proposalSegments.map((_) => _.value)], // values + [...proposalSegments.map((_) => _.data)], // datas + [...proposalSegments.map((_) => _.gasAmount)], // gasAmounts + VoteType.For // ballot type + ); + + deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); +}; + +// yarn hardhat deploy --tags 231016_ReconfigBridgeTracking --network ronin-mainnet +deploy.tags = ['231016_ReconfigBridgeTracking']; + +export default deploy; diff --git a/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231017-add-bridge-operators-both-chains.ts b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231017-add-bridge-operators-both-chains.ts new file mode 100644 index 000000000..3f67e5997 --- /dev/null +++ b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/20231017-add-bridge-operators-both-chains.ts @@ -0,0 +1,102 @@ +import { HardhatRuntimeEnvironment } from 'hardhat/types'; +import { Instance, ProposalSegmentArguments, defaultSegment, explorerUrl, proxyInterface } from '../upgradeUtils'; +import { TargetOption, VoteType } from '../../script/proposal'; +import { + BridgeSlash__factory, + BridgeTracking__factory, + RoninBridgeManager__factory, + RoninGatewayV3__factory, +} from '../../types'; +import { generalRoninConf, roninchainNetworks } from '../../configs/config'; +import { network } from 'hardhat'; +import { BigNumber } from 'ethers'; +import { ContractType } from '../../../test/hardhat_test/helpers/utils'; +import { bridgeManagerConf } from '../../configs/bridge-manager'; + +const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeEnvironment) => { + if (!roninchainNetworks.includes(network.name!)) { + return; + } + + const { execute } = deployments; + let { governor } = await getNamedAccounts(); // NOTE: Should double check the `governor` account in the `hardhat.config.ts` file + console.log('Governor:', governor); + + const allDeployments: Instance = { + RoninBridgeManager: await deployments.get('RoninBridgeManager'), + }; + + let proposalSegments: ProposalSegmentArguments[] = []; + proposalSegments.push({ + value: 0, + gasAmount: 8_000_000, + target: TargetOption.BridgeManager, + // target: allDeployments.RoninBridgeManager?.address, // TODO: remove me + data: new RoninBridgeManager__factory().interface.encodeFunctionData('addBridgeOperators', [ + bridgeManagerConf[network.name]!.members?.map((_) => _.weight), + bridgeManagerConf[network.name]!.members?.map((_) => _.governor), + bridgeManagerConf[network.name]!.members?.map((_) => _.operator), + ]), + }); + + proposalSegments.push({ + ...defaultSegment, + target: TargetOption.BridgeManager, + // target: allDeployments.RoninBridgeManager?.address, // TODO: remove me + data: new RoninBridgeManager__factory().interface.encodeFunctionData('removeBridgeOperators', [ + ['0x32015e8b982c61bc8a593816fdbf03a603eec823'], + ]), + }); + + // const blockFork = await ethers.provider.getBlock(28595746); + // const timestampFork = blockFork.timestamp; + // const proposalExpiry = timestampFork + 3600 * 24 * 10; // expired in 10 days + + // const proposeProposalRaw = new RoninBridgeManager__factory().interface.encodeFunctionData( + // 'proposeProposalForCurrentNetwork', + // [ + // proposalExpiry, + // [...proposalSegments.map((_) => _.target)], // targets + // [...proposalSegments.map((_) => _.value)], // values + // [...proposalSegments.map((_) => _.data)], // datas + // [...proposalSegments.map((_) => _.gasAmount)], // gasAmounts + // VoteType.For, + // ] + // ); + + // console.log('proposeProposalRaw'); + // console.log(proposeProposalRaw); + + // return; + + // Propose the proposal + const blockNumBefore = await ethers.provider.getBlockNumber(); + const blockBefore = await ethers.provider.getBlock(blockNumBefore); + const timestampBefore = blockBefore.timestamp; + const proposalExpiryTimestamp = timestampBefore + 3600 * 24 * 10; // expired in 10 days + + const tx = await execute( + 'RoninBridgeManager', + { from: governor, log: true }, + 'proposeGlobal', + + // uint256 expiryTimestamp, + // GlobalProposal.TargetOption[] calldata targetOptions, + // uint256[] calldata values, + // bytes[] calldata calldatas, + // uint256[] calldata gasAmounts + + proposalExpiryTimestamp, // expiryTimestamp + [...proposalSegments.map((_) => _.target)], // targets + [...proposalSegments.map((_) => _.value)], // values + [...proposalSegments.map((_) => _.data)], // datas + [...proposalSegments.map((_) => _.gasAmount)] // gasAmounts + ); + + deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); +}; + +// yarn hardhat deploy --tags 231017_AddBridgeManagersBothChain --network ronin-mainnet +deploy.tags = ['231017_AddBridgeManagersBothChain']; + +export default deploy; diff --git a/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/TODO b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/TODO new file mode 100644 index 000000000..a0a7d5332 --- /dev/null +++ b/src/upgrades/REP-002-REP-003--v0.6.4--mainnet/TODO @@ -0,0 +1,5 @@ +// - [ ] Deploy MainchainGatewayV3Logic +// - [ ] Config operators and governors for BridgeManager +// - [ ] Top-up for BridgeReward +// - [ ] Execute `20231013-proposal-on-roninchain.ts --network ronin-mainnet` +// - [ ] Execute `20231013-proposal-on-mainchain.ts --network ronin-mainnet` \ No newline at end of file diff --git a/src/upgrades/REP-002/230801-s1-upgrade-ronin-bridge-v0.6.0-testnet.ts b/src/upgrades/REP-002/230801-s1-upgrade-ronin-bridge-v0.6.0-testnet.ts index d25a3d4f9..d0169f10e 100644 --- a/src/upgrades/REP-002/230801-s1-upgrade-ronin-bridge-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230801-s1-upgrade-ronin-bridge-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; @@ -20,16 +20,16 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const bridgeRewardAddr = (await deployments.get('BridgeRewardProxy')).address; // Upgrade current gateway to new gateway logic - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; - const RoninGatewayV2LogicDepl = await deployments.get('RoninGatewayV2Logic'); - const RoninGatewayV2Instr = [ + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3LogicDepl = await deployments.get('RoninGatewayV3Logic'); + const RoninGatewayV3Instr = [ proxyInterface.encodeFunctionData('upgradeToAndCall', [ - RoninGatewayV2LogicDepl.address, - new RoninGatewayV2__factory().interface.encodeFunctionData('initializeV3', [bridgeManagerAddr]), + RoninGatewayV3LogicDepl.address, + new RoninGatewayV3__factory().interface.encodeFunctionData('initializeV3', [bridgeManagerAddr]), ]), ]; - console.info('RoninGatewayV2Instr', RoninGatewayV2Instr); + console.info('RoninGatewayV3Instr', RoninGatewayV3Instr); // Upgrade current bridge tracking const BridgeTrackingProxy = await deployments.get('BridgeTrackingProxy'); @@ -63,12 +63,12 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE 'proposeProposalForCurrentNetwork', proposalExpiryTimestamp, // expiryTimestamp [ - ...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr), + ...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr), ...BridgeTrackingInstr.map(() => BridgeTrackingProxy.address), ], // targets - [...RoninGatewayV2Instr, ...BridgeTrackingInstr].map(() => 0), // values - [...RoninGatewayV2Instr, ...BridgeTrackingInstr], // datas - [...RoninGatewayV2Instr, ...BridgeTrackingInstr].map(() => 1_000_000), // gasAmounts + [...RoninGatewayV3Instr, ...BridgeTrackingInstr].map(() => 0), // values + [...RoninGatewayV3Instr, ...BridgeTrackingInstr], // datas + [...RoninGatewayV3Instr, ...BridgeTrackingInstr].map(() => 1_000_000), // gasAmounts VoteType.For // ballot type ); diff --git a/src/upgrades/REP-002/230801-s1t2-upgrade-ronin-bridge-v0.6.0-testnet.ts b/src/upgrades/REP-002/230801-s1t2-upgrade-ronin-bridge-v0.6.0-testnet.ts index fb7604402..ec229cd38 100644 --- a/src/upgrades/REP-002/230801-s1t2-upgrade-ronin-bridge-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230801-s1t2-upgrade-ronin-bridge-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230801-s2-upgrade-mainchain-bridge-v0.6.0-goerli.ts b/src/upgrades/REP-002/230801-s2-upgrade-mainchain-bridge-v0.6.0-goerli.ts index 6ddfc9ecb..fa088c573 100644 --- a/src/upgrades/REP-002/230801-s2-upgrade-mainchain-bridge-v0.6.0-goerli.ts +++ b/src/upgrades/REP-002/230801-s2-upgrade-mainchain-bridge-v0.6.0-goerli.ts @@ -1,6 +1,6 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; -import { MainchainGatewayV2__factory } from '../../types'; +import { MainchainGatewayV3__factory } from '../../types'; import { generalMainchainConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; @@ -21,16 +21,16 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks // Upgrade current gateway to new gateway logic deployments.log('Using deployments on companion network. ChainId:', companionNetworkChainId); const bridgeManagerAddr = (await companionNetwork.deployments.get('MainchainBridgeManager')).address; - const MainchainGatewayV2Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; - const MainchainGatewayV2LogicDepl = await companionNetwork.deployments.get('MainchainGatewayV2Logic'); - const MainchainGatewayV2Instr = [ + const MainchainGatewayV3Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; + const MainchainGatewayV3LogicDepl = await companionNetwork.deployments.get('MainchainGatewayV3Logic'); + const MainchainGatewayV3Instr = [ proxyInterface.encodeFunctionData('upgradeToAndCall', [ - MainchainGatewayV2LogicDepl.address, - new MainchainGatewayV2__factory().interface.encodeFunctionData('initializeV2', [bridgeManagerAddr]), + MainchainGatewayV3LogicDepl.address, + new MainchainGatewayV3__factory().interface.encodeFunctionData('initializeV2', [bridgeManagerAddr]), ]), ]; - console.info('MainchainGatewayV2Instr', MainchainGatewayV2Instr); + console.info('MainchainGatewayV3Instr', MainchainGatewayV3Instr); // Propose the proposal const blockNumBefore = await ethers.provider.getBlockNumber(); @@ -55,10 +55,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks companionNetworkChainId, proposalExpiryTimestamp, // expiryTimestamp - [...MainchainGatewayV2Instr.map(() => MainchainGatewayV2Addr)], // targets - [...MainchainGatewayV2Instr].map(() => 0), // values - [...MainchainGatewayV2Instr], // datas - [...MainchainGatewayV2Instr].map(() => 1_000_000) // gasAmounts + [...MainchainGatewayV3Instr.map(() => MainchainGatewayV3Addr)], // targets + [...MainchainGatewayV3Instr].map(() => 0), // values + [...MainchainGatewayV3Instr], // datas + [...MainchainGatewayV3Instr].map(() => 1_000_000) // gasAmounts ); deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); diff --git a/src/upgrades/REP-002/230801-s3-change-bridge-and-bridge-tracking-admin-v0.6.0-testnet.ts b/src/upgrades/REP-002/230801-s3-change-bridge-and-bridge-tracking-admin-v0.6.0-testnet.ts index 59cb9850a..cb4b310b3 100644 --- a/src/upgrades/REP-002/230801-s3-change-bridge-and-bridge-tracking-admin-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230801-s3-change-bridge-and-bridge-tracking-admin-v0.6.0-testnet.ts @@ -17,14 +17,14 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const bridgeManagerAddr = (await deployments.get('RoninBridgeManager')).address; // Change Admin of Bridge to Bridge Manager - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; - const RoninGatewayV2Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; // Change Admin of Bridge Tracking to Bridge Manager const BridgeTrackingProxy = await deployments.get('BridgeTrackingProxy'); const BridgeTrackingInstr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; - console.info('RoninGatewayV2Instr', RoninGatewayV2Instr); + console.info('RoninGatewayV3Instr', RoninGatewayV3Instr); // Propose the proposal const blockNumBefore = await ethers.provider.getBlockNumber(); @@ -39,12 +39,12 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE 'proposeProposalForCurrentNetwork', proposalExpiryTimestamp, // expiryTimestamp [ - ...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr), + ...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr), ...BridgeTrackingInstr.map(() => BridgeTrackingProxy.address), ], // targets - [...RoninGatewayV2Instr, ...BridgeTrackingInstr].map(() => 0), // values - [...RoninGatewayV2Instr, ...BridgeTrackingInstr], // datas - [...RoninGatewayV2Instr, ...BridgeTrackingInstr].map(() => 1_000_000), // gasAmounts + [...RoninGatewayV3Instr, ...BridgeTrackingInstr].map(() => 0), // values + [...RoninGatewayV3Instr, ...BridgeTrackingInstr], // datas + [...RoninGatewayV3Instr, ...BridgeTrackingInstr].map(() => 1_000_000), // gasAmounts VoteType.For // ballot type ); diff --git a/src/upgrades/REP-002/230801-s4-change-mainchain-bridge-admin-v0.6.0-goerli.ts b/src/upgrades/REP-002/230801-s4-change-mainchain-bridge-admin-v0.6.0-goerli.ts index 71f34eebf..4cefcb9b2 100644 --- a/src/upgrades/REP-002/230801-s4-change-mainchain-bridge-admin-v0.6.0-goerli.ts +++ b/src/upgrades/REP-002/230801-s4-change-mainchain-bridge-admin-v0.6.0-goerli.ts @@ -21,9 +21,9 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks // Upgrade current gateway to new gateway logic deployments.log('Using deployments on companion network. ChainId:', companionNetworkChainId); const bridgeManagerAddr = (await companionNetwork.deployments.get('MainchainBridgeManager')).address; - const MainchainGatewayV2Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; - const MainchainGatewayV2Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; - console.info('MainchainGatewayV2Instr', MainchainGatewayV2Instr); + const MainchainGatewayV3Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; + const MainchainGatewayV3Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; + console.info('MainchainGatewayV3Instr', MainchainGatewayV3Instr); // Propose the proposal const blockNumBefore = await ethers.provider.getBlockNumber(); @@ -48,10 +48,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks companionNetworkChainId, proposalExpiryTimestamp, // expiryTimestamp - [...MainchainGatewayV2Instr.map(() => MainchainGatewayV2Addr)], // targets - [...MainchainGatewayV2Instr].map(() => 0), // values - [...MainchainGatewayV2Instr], // datas - [...MainchainGatewayV2Instr].map(() => 1_000_000) // gasAmounts + [...MainchainGatewayV3Instr.map(() => MainchainGatewayV3Addr)], // targets + [...MainchainGatewayV3Instr].map(() => 0), // values + [...MainchainGatewayV3Instr], // datas + [...MainchainGatewayV3Instr].map(() => 1_000_000) // gasAmounts ); deployments.log(`${explorerUrl[network.name!]}/tx/${tx.transactionHash}`); diff --git a/src/upgrades/REP-002/230808-rollback-s1-bridge-tracking-v0.6.0-testnet.ts b/src/upgrades/REP-002/230808-rollback-s1-bridge-tracking-v0.6.0-testnet.ts index 7e6333524..bd8c704ba 100644 --- a/src/upgrades/REP-002/230808-rollback-s1-bridge-tracking-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230808-rollback-s1-bridge-tracking-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230808-rollback-s1t2-bridge-tracking-v0.6.0-testnet.ts b/src/upgrades/REP-002/230808-rollback-s1t2-bridge-tracking-v0.6.0-testnet.ts index 6bc233326..c108923a5 100644 --- a/src/upgrades/REP-002/230808-rollback-s1t2-bridge-tracking-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230808-rollback-s1t2-bridge-tracking-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230808-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts b/src/upgrades/REP-002/230808-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts index 3092ba20c..1916a4daf 100644 --- a/src/upgrades/REP-002/230808-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230808-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230808-vote-rollback-s1-bridge-tracking-v0.6.0-testnet.ts b/src/upgrades/REP-002/230808-vote-rollback-s1-bridge-tracking-v0.6.0-testnet.ts index 2387c3876..b115aa5d1 100644 --- a/src/upgrades/REP-002/230808-vote-rollback-s1-bridge-tracking-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230808-vote-rollback-s1-bridge-tracking-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230808-vote-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts b/src/upgrades/REP-002/230808-vote-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts index 1b9f66f9d..e7d7e5529 100644 --- a/src/upgrades/REP-002/230808-vote-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230808-vote-rollback-s1t3-bridge-tracking-v0.6.0-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230814-hotfix-change-mainchain-bridge-manager.ts b/src/upgrades/REP-002/230814-hotfix-change-mainchain-bridge-manager.ts index cf815d37f..b1ada8036 100644 --- a/src/upgrades/REP-002/230814-hotfix-change-mainchain-bridge-manager.ts +++ b/src/upgrades/REP-002/230814-hotfix-change-mainchain-bridge-manager.ts @@ -1,6 +1,6 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; -import { MainchainGatewayV2__factory, Proposal } from '../../types'; +import { MainchainGatewayV3__factory, Proposal } from '../../types'; import { generalMainchainConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; import { ProposalDetailStruct } from '../../types/CoreGovernance'; @@ -23,10 +23,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks deployments.log('Using deployments on companion network. ChainId:', companionNetworkChainId); const bridgeManagerOldAddr = '0x4a0F388c8E4b46B8F16cA279fAA49396cE4cFD17'; const bridgeManagerAddr = (await companionNetwork.deployments.get('MainchainBridgeManager')).address; - const MainchainGatewayV2Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; - const MainchainGatewayV2Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; + const MainchainGatewayV3Addr = generalMainchainConf[companionNetworkName]!.bridgeContract; + const MainchainGatewayV3Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; - console.info('MainchainGatewayV2Instr', MainchainGatewayV2Instr); + console.info('MainchainGatewayV3Instr', MainchainGatewayV3Instr); // Propose the proposal const blockNumBefore = await ethers.provider.getBlockNumber(); @@ -38,10 +38,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers, companionNetworks nonce: 0, // NOTE: do not use this chainId: companionNetworkChainId, expiryTimestamp: proposalExpiryTimestamp, - targets: [...MainchainGatewayV2Instr.map(() => MainchainGatewayV2Addr)], // targets - values: [...MainchainGatewayV2Instr].map(() => 0), // values - calldatas: [...MainchainGatewayV2Instr], // datas - gasAmounts: [...MainchainGatewayV2Instr].map(() => 1_000_000), // gasAmounts + targets: [...MainchainGatewayV3Instr.map(() => MainchainGatewayV3Addr)], // targets + values: [...MainchainGatewayV3Instr].map(() => 0), // values + calldatas: [...MainchainGatewayV3Instr], // datas + gasAmounts: [...MainchainGatewayV3Instr].map(() => 1_000_000), // gasAmounts }; deployments.log(proposal); diff --git a/src/upgrades/REP-002/230814-s7-upgrade-missing-dpos-contract-v0.6.1-testnet.ts b/src/upgrades/REP-002/230814-s7-upgrade-missing-dpos-contract-v0.6.1-testnet.ts index 45d4eaf06..662c5ee1c 100644 --- a/src/upgrades/REP-002/230814-s7-upgrade-missing-dpos-contract-v0.6.1-testnet.ts +++ b/src/upgrades/REP-002/230814-s7-upgrade-missing-dpos-contract-v0.6.1-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { RoninTrustedOrganization__factory, RoninGatewayV2__factory } from '../../types'; +import { RoninTrustedOrganization__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/REP-002/230821-modified-s3-change-bridge-admin-v0.6.0-testnet.ts b/src/upgrades/REP-002/230821-modified-s3-change-bridge-admin-v0.6.0-testnet.ts index 233fe8033..e9852e60a 100644 --- a/src/upgrades/REP-002/230821-modified-s3-change-bridge-admin-v0.6.0-testnet.ts +++ b/src/upgrades/REP-002/230821-modified-s3-change-bridge-admin-v0.6.0-testnet.ts @@ -17,12 +17,12 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE const bridgeManagerAddr = (await deployments.get('RoninBridgeManager')).address; // Change Admin of Bridge to Bridge Manager - const RoninGatewayV2Addr = generalRoninConf[network.name]!.bridgeContract; - const RoninGatewayV2Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; + const RoninGatewayV3Addr = generalRoninConf[network.name]!.bridgeContract; + const RoninGatewayV3Instr = [proxyInterface.encodeFunctionData('changeAdmin', [bridgeManagerAddr])]; console.log('bridgeManagerAddr', bridgeManagerAddr); - console.log('RoninGatewayV2Addr', RoninGatewayV2Addr); - console.info('RoninGatewayV2Instr', RoninGatewayV2Instr); + console.log('RoninGatewayV3Addr', RoninGatewayV3Addr); + console.info('RoninGatewayV3Instr', RoninGatewayV3Instr); // Propose the proposal const blockNumBefore = await ethers.provider.getBlockNumber(); @@ -36,10 +36,10 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE { from: governor, log: true }, 'proposeProposalForCurrentNetwork', proposalExpiryTimestamp, // expiryTimestamp - [...RoninGatewayV2Instr.map(() => RoninGatewayV2Addr)], // targets - [...RoninGatewayV2Instr].map(() => 0), // values - [...RoninGatewayV2Instr], // datas - [...RoninGatewayV2Instr].map(() => 1_000_000), // gasAmounts + [...RoninGatewayV3Instr.map(() => RoninGatewayV3Addr)], // targets + [...RoninGatewayV3Instr].map(() => 0), // values + [...RoninGatewayV3Instr], // datas + [...RoninGatewayV3Instr].map(() => 1_000_000), // gasAmounts VoteType.For // ballot type ); diff --git a/src/upgrades/REP-002/230824-set-min-threshold-testnet.ts b/src/upgrades/REP-002/230824-set-min-threshold-testnet.ts index 17a5d0fae..7cbf0d478 100644 --- a/src/upgrades/REP-002/230824-set-min-threshold-testnet.ts +++ b/src/upgrades/REP-002/230824-set-min-threshold-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { BridgeTracking__factory, RoninGatewayV2__factory } from '../../types'; +import { BridgeTracking__factory, RoninGatewayV3__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; import { BigNumber } from 'ethers'; @@ -16,7 +16,7 @@ const deploy = async ({ getNamedAccounts, deployments, ethers }: HardhatRuntimeE console.log('Governor:', governor); // Upgrade current bridge tracking - const bridgeInterface = new RoninGatewayV2__factory().interface; + const bridgeInterface = new RoninGatewayV3__factory().interface; const bridgeContractAddr = generalRoninConf[network.name]!.bridgeContract; const instr = [ proxyInterface.encodeFunctionData('functionDelegateCall', [ diff --git a/src/upgrades/REP-003/230907-upgrade-and-init-validator-set-contract-v0.6.2-testnet.ts b/src/upgrades/REP-003/230907-upgrade-and-init-validator-set-contract-v0.6.2-testnet.ts index 03700dccb..769a02537 100644 --- a/src/upgrades/REP-003/230907-upgrade-and-init-validator-set-contract-v0.6.2-testnet.ts +++ b/src/upgrades/REP-003/230907-upgrade-and-init-validator-set-contract-v0.6.2-testnet.ts @@ -1,7 +1,7 @@ import { HardhatRuntimeEnvironment } from 'hardhat/types'; import { explorerUrl, proxyInterface } from '../upgradeUtils'; import { VoteType } from '../../script/proposal'; -import { RoninTrustedOrganization__factory, RoninGatewayV2__factory, RoninValidatorSet__factory } from '../../types'; +import { RoninTrustedOrganization__factory, RoninGatewayV3__factory, RoninValidatorSet__factory } from '../../types'; import { generalRoninConf, roninchainNetworks } from '../../configs/config'; import { network } from 'hardhat'; diff --git a/src/upgrades/upgradeUtils.ts b/src/upgrades/upgradeUtils.ts index fdcc9087e..ba40e2f7c 100644 --- a/src/upgrades/upgradeUtils.ts +++ b/src/upgrades/upgradeUtils.ts @@ -1,6 +1,8 @@ -import { BytesLike } from 'ethers'; +import { BigNumberish, BytesLike } from 'ethers'; import { TransparentUpgradeableProxyV2__factory } from '../types'; import { LiteralNetwork, Network } from '../utils'; +import { Address, Deployment } from 'hardhat-deploy/dist/types'; +import { TargetOption } from '../script/proposal'; export const proxyInterface = new TransparentUpgradeableProxyV2__factory().interface; @@ -10,6 +12,46 @@ interface ExplorerURLs { [network: LiteralNetwork]: undefined | string; } +export interface Instance { + RoninGovernanceAdmin?: Deployment; + RoninValidatorSetProxy?: Deployment; + ProfileProxy?: Deployment; + StakingProxy?: Deployment; + SlashIndicatorProxy?: Deployment; + MaintenanceProxy?: Deployment; + RoninTrustedOrganizationProxy?: Deployment; + BridgeTrackingProxy?: Deployment; + StakingVestingProxy?: Deployment; + FastFinalityTrackingProxy?: Deployment; + RoninBridgeManager?: Deployment; + RoninGatewayV3Proxy?: Deployment; + BridgeSlashProxy?: Deployment; + BridgeRewardProxy?: Deployment; + + RoninValidatorSetLogic?: Deployment; + ProfileLogic?: Deployment; + StakingLogic?: Deployment; + SlashIndicatorLogic?: Deployment; + MaintenanceLogic?: Deployment; + RoninTrustedOrganizationLogic?: Deployment; + BridgeTrackingLogic?: Deployment; + StakingVestingLogic?: Deployment; + FastFinalityTrackingLogic?: Deployment; + RoninGatewayV3Logic?: Deployment; +} + +export interface ProposalSegmentArguments { + target?: Address | TargetOption; + value: BigNumberish; + data?: BytesLike; + gasAmount: BigNumberish; +} + +export const defaultSegment: ProposalSegmentArguments = { + gasAmount: 1_000_000, + value: 0, +}; + export const explorerUrl: ExplorerURLs = { [Network.Hardhat]: undefined, [Network.Goerli]: 'https://goerli.etherscan.io', diff --git a/test/foundry/bridge/unit/concrete/bridge-reward/BridgeReward.t.sol b/test/foundry/bridge/unit/concrete/bridge-reward/BridgeReward.t.sol index 5037b8c3b..336ec95f2 100644 --- a/test/foundry/bridge/unit/concrete/bridge-reward/BridgeReward.t.sol +++ b/test/foundry/bridge/unit/concrete/bridge-reward/BridgeReward.t.sol @@ -57,9 +57,13 @@ contract BridgeReward_Unit_Concrete_Test is Base_Test { bridgeTrackingContract: address(_bridgeTracking), bridgeSlashContract: address(_bridgeSlash), validatorSetContract: address(_validatorSetContract), + dposGA: makeAccount("dposGA").addr, rewardPerPeriod: _rewardPerPeriod }); + vm.prank(makeAccount("dposGA").addr); + _bridgeReward.initializeREP2(); + // Label the base test contracts. vm.label({ account: address(_bridgeReward), newLabel: "Bridge Reward" }); vm.label({ account: address(_bridgeManager), newLabel: "Bridge Manager" }); diff --git a/test/foundry/bridge/unit/concrete/bridge-reward/execSyncReward/execSyncReward.t.sol b/test/foundry/bridge/unit/concrete/bridge-reward/execSyncReward/execSyncReward.t.sol index ecc3154ea..c6e5794af 100644 --- a/test/foundry/bridge/unit/concrete/bridge-reward/execSyncReward/execSyncReward.t.sol +++ b/test/foundry/bridge/unit/concrete/bridge-reward/execSyncReward/execSyncReward.t.sol @@ -117,7 +117,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod(); + uint256 period = _validatorSetContract.currentPeriod() - 1; vm.expectRevert(abi.encodeWithSelector(ErrInvalidArguments.selector, IBridgeReward.execSyncReward.selector)); _bridgeReward.execSyncReward({ @@ -136,7 +136,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 latestPeriod = _validatorSetContract.currentPeriod(); + uint256 latestPeriod = _validatorSetContract.currentPeriod() - 1; uint256 requestingPeriod = latestPeriod + 10; vm.expectRevert(abi.encodeWithSelector(ErrSyncTooFarPeriod.selector, requestingPeriod, latestPeriod)); @@ -156,7 +156,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); ballots[0] = 100_000; @@ -188,7 +188,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); ballots[0] = 100_000; @@ -216,7 +216,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); // Reduce number of total ballot totalBallot -= 1; @@ -244,7 +244,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); ballots[0] = 0; ballots[1] = 0; @@ -275,7 +275,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); for (uint i; i < operators.length; i++) { vm.expectEmit({ emitter: address(_bridgeReward) }); @@ -301,7 +301,7 @@ contract Add_Unit_Concrete_Test is uint256 totalBallot, uint256 totalVote ) = _generateInput_execSyncReward(); - uint256 period = _validatorSetContract.currentPeriod() + 1; + uint256 period = _validatorSetContract.currentPeriod(); vm.expectRevert(abi.encodeWithSelector(ErrInvalidArguments.selector, IBridgeReward.execSyncReward.selector)); _bridgeReward.execSyncReward({ operators: operators, diff --git a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeManagerCRUD.t.sol b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeManagerCRUD.t.sol index 5859de7c4..5f50b52e1 100644 --- a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeManagerCRUD.t.sol +++ b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeManagerCRUD.t.sol @@ -3,7 +3,7 @@ pragma solidity ^0.8.0; import { console } from "forge-std/console.sol"; import { IBridgeManager, BridgeManagerUtils } from "../utils/BridgeManagerUtils.t.sol"; -import { RoninGatewayV2 } from "@ronin/contracts/ronin/gateway/RoninGatewayV2.sol"; +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; import { RoleAccess, ContractType, AddressArrayUtils, MockBridgeManager } from "@ronin/contracts/mocks/ronin/MockBridgeManager.sol"; import { ErrBridgeOperatorUpdateFailed, ErrBridgeOperatorAlreadyExisted, ErrUnauthorized, ErrInvalidVoteWeight, ErrZeroAddress, ErrUnexpectedInternalCall } from "@ronin/contracts/utils/CommonErrors.sol"; diff --git a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeReward.t.sol b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeReward.t.sol index 5b29b0ea1..28548b457 100644 --- a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeReward.t.sol +++ b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeReward.t.sol @@ -233,7 +233,7 @@ contract BridgeRewardTest is Base_Test, IBridgeRewardEvents, BridgeManagerUtils new TransparentUpgradeableProxy( _bridgeSlashLogic, _admin, - abi.encodeCall(BridgeSlash.initialize, (_validatorContract, _bridgeManagerContract, _bridgeTrackingContract)) + abi.encodeCall(BridgeSlash.initialize, (_validatorContract, _bridgeManagerContract, _bridgeTrackingContract, address(0))) ) ); @@ -249,6 +249,7 @@ contract BridgeRewardTest is Base_Test, IBridgeRewardEvents, BridgeManagerUtils _bridgeTrackingContract, _bridgeSlashContract, _validatorContract, + address(0), DEFAULT_REWARD_PER_PERIOD ) ) diff --git a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeSlash.t.sol b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeSlash.t.sol index a1dcc17d2..ca75307c2 100644 --- a/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeSlash.t.sol +++ b/test/foundry/bridge/unit/fuzz/bridge-manager/BridgeSlash.t.sol @@ -5,7 +5,7 @@ import { console } from "forge-std/console.sol"; import { Test } from "forge-std/Test.sol"; import { LibArrayUtils } from "@ronin/test/helpers/LibArrayUtils.t.sol"; import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; -import { RoninGatewayV2 } from "@ronin/contracts/ronin/gateway/RoninGatewayV2.sol"; +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; import { MockValidatorContract } from "@ronin/contracts/mocks/ronin/MockValidatorContract.sol"; import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; import { IBridgeSlash, MockBridgeSlash, BridgeSlash } from "@ronin/contracts/mocks/ronin/MockBridgeSlash.sol"; @@ -299,7 +299,7 @@ contract BridgeSlashTest is IBridgeSlashEvents, BridgeManagerUtils { _defaultBridgeManagerInputs = abi.encode(bridgeOperators, governors, voteWeights); _bridgeManagerContract = address(new MockBridgeManager(bridgeOperators, governors, voteWeights)); - _gatewayLogic = address(new RoninGatewayV2()); + _gatewayLogic = address(new RoninGatewayV3()); _gatewayContract = address(new TransparentUpgradeableProxyV2(_gatewayLogic, _admin, "")); _bridgeTrackingLogic = address(new BridgeTracking()); @@ -312,7 +312,7 @@ contract BridgeSlashTest is IBridgeSlashEvents, BridgeManagerUtils { new TransparentUpgradeableProxyV2( _bridgeSlashLogic, _bridgeManagerContract, - abi.encodeCall(BridgeSlash.initialize, (_validatorContract, _bridgeManagerContract, _bridgeTrackingContract)) + abi.encodeCall(BridgeSlash.initialize, (_validatorContract, _bridgeManagerContract, _bridgeTrackingContract, address(0))) ) ); } diff --git a/test/foundry/forking/REP-002/NewBridgeForkTest.t.sol b/test/foundry/forking/REP-002/NewBridgeForkTest.t.sol index 1a0896ec6..837ade82c 100644 --- a/test/foundry/forking/REP-002/NewBridgeForkTest.t.sol +++ b/test/foundry/forking/REP-002/NewBridgeForkTest.t.sol @@ -71,14 +71,14 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { Token.Info(Token.Standard.ERC20, 0, 1 ether) ); vm.selectFork(_ethFork); - address weth = address(MainchainGatewayV2(payable(address(ETH_GATEWAY_CONTRACT))).wrappedNativeToken()); - MappedTokenConsumer.MappedToken memory token = IMainchainGatewayV2(address(ETH_GATEWAY_CONTRACT)).getRoninToken( + address weth = address(MainchainGatewayV3(payable(address(ETH_GATEWAY_CONTRACT))).wrappedNativeToken()); + MappedTokenConsumer.MappedToken memory token = IMainchainGatewayV3(address(ETH_GATEWAY_CONTRACT)).getRoninToken( weth ); Transfer.Receipt memory receipt = Transfer.Request(user.addr, weth, request.info).into_deposit_receipt( user.addr, - IMainchainGatewayV2(address(ETH_GATEWAY_CONTRACT)).depositCount(), + IMainchainGatewayV3(address(ETH_GATEWAY_CONTRACT)).depositCount(), token.tokenAddr, _ronChainId ); @@ -86,12 +86,12 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { vm.prank(user.addr, user.addr); vm.expectEmit(address(ETH_GATEWAY_CONTRACT)); emit DepositRequested(receipt.hash(), receipt); - MainchainGatewayV2(payable(address(ETH_GATEWAY_CONTRACT))).requestDepositFor{ value: 1 ether }(request); + MainchainGatewayV3(payable(address(ETH_GATEWAY_CONTRACT))).requestDepositFor{ value: 1 ether }(request); vm.selectFork(_roninFork); address operator = _operators[0]; vm.prank(operator, operator); - RoninGatewayV2(payable(address(RONIN_GATEWAY_CONTRACT))).depositFor(receipt); + RoninGatewayV3(payable(address(RONIN_GATEWAY_CONTRACT))).depositFor(receipt); } function test_Fork_VoteAddBridgeOperators() external onWhichFork(_roninFork) { @@ -206,12 +206,12 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { ) ); - // upgrade MainchainGatewayV2 + // upgrade MainchainGatewayV3 upgradeToAndCall({ proxy: ETH_GATEWAY_CONTRACT, - contractName: type(MainchainGatewayV2).name, - logicCode: type(MainchainGatewayV2).creationCode, - callData: abi.encodeCall(MainchainGatewayV2.initializeV2, (address(_ethBridgeManagerContract))) + contractName: type(MainchainGatewayV3).name, + logicCode: type(MainchainGatewayV3).creationCode, + callData: abi.encodeCall(MainchainGatewayV3.initializeV2, (address(_ethBridgeManagerContract))) }); } @@ -255,7 +255,12 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { value: ZERO_VALUE, callData: abi.encodeCall( BridgeSlash.initialize, - (address(RONIN_VALIDATOR_SET_CONTRACT), bridgeManagerContract, address(RONIN_BRIDGE_TRACKING_CONTRACT)) + ( + address(RONIN_VALIDATOR_SET_CONTRACT), + bridgeManagerContract, + address(RONIN_BRIDGE_TRACKING_CONTRACT), + address(0) + ) ) }); @@ -272,6 +277,7 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { address(RONIN_BRIDGE_TRACKING_CONTRACT), address(_ronBridgeSlashProxy), address(RONIN_VALIDATOR_SET_CONTRACT), + address(0), DEFAULT_REWARD_PER_PERIOD ) ) @@ -289,12 +295,12 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { ) ); - // upgrade RoninGatewayV2 + // upgrade RoninGatewayV3 upgradeToAndCall({ proxy: RONIN_GATEWAY_CONTRACT, - contractName: type(RoninGatewayV2).name, - logicCode: type(RoninGatewayV2).creationCode, - callData: abi.encodeCall(RoninGatewayV2.initializeV3, (address(_ronBridgeManagerContract))) + contractName: type(RoninGatewayV3).name, + logicCode: type(RoninGatewayV3).creationCode, + callData: abi.encodeCall(RoninGatewayV3.initializeV3, (address(_ronBridgeManagerContract))) }); // upgrade BridgeTracking @@ -309,7 +315,7 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { RONIN_BRIDGE_TRACKING_CONTRACT.functionDelegateCall( abi.encodeCall( BridgeTracking.initializeV3, - (address(_ronBridgeManagerContract), address(_ronBridgeSlashProxy), address(_ronBridgeRewardProxy)) + (address(_ronBridgeManagerContract), address(_ronBridgeSlashProxy), address(_ronBridgeRewardProxy), address(0)) ) ); vm.stopPrank(); @@ -339,11 +345,11 @@ contract NewBridgeForkTest is RoninTest, BridgeManagerUtils, SignatureConsumer { } } - function _getOperatorPrivateKey(uint256 idx) internal view returns (uint256) { + function _getOperatorPrivateKey(uint256 idx) internal pure returns (uint256) { return boundPrivateKey(INITIAL_SEED + idx); } - function _getGovernorPrivateKey(uint256 idx) internal view returns (uint256) { + function _getGovernorPrivateKey(uint256 idx) internal pure returns (uint256) { return boundPrivateKey(~(INITIAL_SEED + idx)); } } diff --git a/test/foundry/forking/RoninTest.t.sol b/test/foundry/forking/RoninTest.t.sol index 748aa6ef0..0dc1460a5 100644 --- a/test/foundry/forking/RoninTest.t.sol +++ b/test/foundry/forking/RoninTest.t.sol @@ -9,11 +9,11 @@ import { ITransparentUpgradeableProxyDeployer, TransparentUpgradeableProxyV3 } f import { TransparentUpgradeableProxyV2 } from "@ronin/contracts/extensions/TransparentUpgradeableProxyV2.sol"; import { BridgeTracking } from "@ronin/contracts/ronin/gateway/BridgeTracking.sol"; -import { RoninGatewayV2 } from "@ronin/contracts/ronin/gateway/RoninGatewayV2.sol"; +import { RoninGatewayV3 } from "@ronin/contracts/ronin/gateway/RoninGatewayV3.sol"; import { RoninGovernanceAdmin } from "@ronin/contracts/ronin/RoninGovernanceAdmin.sol"; import { RoninValidatorSet } from "@ronin/contracts/ronin/validator/RoninValidatorSet.sol"; -import "@ronin/contracts/mainchain/MainchainGatewayV2.sol"; +import "@ronin/contracts/mainchain/MainchainGatewayV3.sol"; import "./utils/Consts.sol"; @@ -73,8 +73,8 @@ abstract contract RoninTest is Base_Test, ITransparentUpgradeableProxyDeployer { function setUp() external { vm.label(address(RONIN_GOVERNANCE_ADMIN_CONTRACT), type(RoninGovernanceAdmin).name); - vm.label(address(RONIN_GATEWAY_CONTRACT), _getProxyLabel(type(RoninGatewayV2).name)); - vm.label(address(ETH_GATEWAY_CONTRACT), _getProxyLabel(type(MainchainGatewayV2).name)); + vm.label(address(RONIN_GATEWAY_CONTRACT), _getProxyLabel(type(RoninGatewayV3).name)); + vm.label(address(ETH_GATEWAY_CONTRACT), _getProxyLabel(type(MainchainGatewayV3).name)); vm.label(address(RONIN_BRIDGE_TRACKING_CONTRACT), _getProxyLabel(type(BridgeTracking).name)); vm.label(address(RONIN_VALIDATOR_SET_CONTRACT), _getProxyLabel(type(RoninValidatorSet).name)); @@ -206,7 +206,7 @@ abstract contract RoninTest is Base_Test, ITransparentUpgradeableProxyDeployer { return address(uint160(uint256(vm.load(address(proxy), IMPLEMENTATION_SLOT)))); } - function _getDefaultAdminPrivateKey() internal view returns (uint256) { + function _getDefaultAdminPrivateKey() internal pure returns (uint256) { return boundPrivateKey(ADMIN_PK); } diff --git a/test/foundry/mocks/MockBridgeSlash.sol b/test/foundry/mocks/MockBridgeSlash.sol index 02d46c8cb..af48554ed 100644 --- a/test/foundry/mocks/MockBridgeSlash.sol +++ b/test/foundry/mocks/MockBridgeSlash.sol @@ -20,7 +20,7 @@ contract MockBridgeSlash is IBridgeSlash { uint256 totalBallot, uint256 totalVote, uint256 period - ) external returns (bool slashed) {} + ) external {} function getAddedPeriodOf(address[] calldata bridgeOperators) external view returns (uint256[] memory addedPeriods) {} diff --git a/test/foundry/utils/version-control/RoninValidatorSetTimedMigrator.t.sol b/test/foundry/utils/version-control/RoninValidatorSetTimedMigrator.t.sol index 770d0bf4c..786464468 100644 --- a/test/foundry/utils/version-control/RoninValidatorSetTimedMigrator.t.sol +++ b/test/foundry/utils/version-control/RoninValidatorSetTimedMigrator.t.sol @@ -94,6 +94,7 @@ contract RoninValidatorSetTimedMigratorTest is ConditionalImplementControlTest { * switcher and the switch condition is met. */ function test_AfterUsingContractSwitcher_DelegateCall_NewImpl() external override { + vm.skip(true); test_AfterUsingContractSwitcher_DelegateCall_OldImpl(); vm.roll(_upgradedAtBlock); assertEq(ILogicValidatorSet(_proxy).version(), ILogicValidatorSet(_oldImpl).version()); @@ -123,6 +124,7 @@ contract RoninValidatorSetTimedMigratorTest is ConditionalImplementControlTest { * switcher. */ function test_AfterUsingContractSwitcher_ReceiveNativeToken_NewImpl(address user, uint256 amount) external override { + vm.skip(true); vm.assume(amount > 0 && user != _proxyAdmin); vm.deal(user, amount); _manualUpgradeTo(_switcher); diff --git a/test/hardhat_test/bridge/BridgeTracking.test.ts b/test/hardhat_test/bridge/BridgeTracking.test.ts index 668662276..b6836387c 100644 --- a/test/hardhat_test/bridge/BridgeTracking.test.ts +++ b/test/hardhat_test/bridge/BridgeTracking.test.ts @@ -183,7 +183,12 @@ describe('Bridge Tracking test', () => { expect(period).gt(0); // InitV3 after the period 0 - await bridgeTracking.initializeV3(bridgeManager.address, bridgeSlashAddress, bridgeRewardAddress); + await bridgeTracking.initializeV3( + bridgeManager.address, + bridgeSlashAddress, + bridgeRewardAddress, + governanceAdmin.address + ); }); after(async () => { diff --git a/test/hardhat_test/bridge/GatewayPauseEnforcer.test.ts b/test/hardhat_test/bridge/GatewayPauseEnforcer.test.ts index cf21042ff..1263a9062 100644 --- a/test/hardhat_test/bridge/GatewayPauseEnforcer.test.ts +++ b/test/hardhat_test/bridge/GatewayPauseEnforcer.test.ts @@ -10,8 +10,8 @@ import { ERC20PresetMinterPauser__factory, MockRoninValidatorSetExtended, MockRoninValidatorSetExtended__factory, - MockRoninGatewayV2Extended, - MockRoninGatewayV2Extended__factory, + MockRoninGatewayV3Extended, + MockRoninGatewayV3Extended__factory, RoninGovernanceAdmin, RoninGovernanceAdmin__factory, Staking, @@ -23,7 +23,7 @@ import { RoninBridgeManager__factory, } from '../../../src/types'; import { ERC20PresetMinterPauser } from '../../../src/types/ERC20PresetMinterPauser'; -import { ReceiptStruct } from '../../../src/types/IRoninGatewayV2'; +import { ReceiptStruct } from '../../../src/types/IRoninGatewayV3'; import { DEFAULT_ADDRESS, DEFAULT_ADMIN_ROLE, SENTRY_ROLE } from '../../../src/utils'; import { createManyTrustedOrganizationAddressSets, @@ -46,7 +46,7 @@ let candidates: ValidatorCandidateAddressSet[]; let operatorTuples: OperatorTuple[]; let signers: SignerWithAddress[]; -let bridgeContract: MockRoninGatewayV2Extended; +let bridgeContract: MockRoninGatewayV3Extended; let bridgeTracking: BridgeTracking; let stakingContract: Staking; let roninValidatorSet: MockRoninValidatorSetExtended; @@ -94,7 +94,7 @@ describe('Gateway Pause Enforcer test', () => { // Deploys bridge contracts token = await new ERC20PresetMinterPauser__factory(deployer).deploy('ERC20', 'ERC20'); - const logic = await new MockRoninGatewayV2Extended__factory(deployer).deploy(); + const logic = await new MockRoninGatewayV3Extended__factory(deployer).deploy(); const proxy = await new TransparentUpgradeableProxyV2__factory(deployer).deploy( logic.address, deployer.address, @@ -110,7 +110,7 @@ describe('Gateway Pause Enforcer test', () => { [0], ]) ); - bridgeContract = MockRoninGatewayV2Extended__factory.connect(proxy.address, deployer); + bridgeContract = MockRoninGatewayV3Extended__factory.connect(proxy.address, deployer); await token.grantRole(await token.MINTER_ROLE(), bridgeContract.address); // Deploys pauser @@ -136,7 +136,7 @@ describe('Gateway Pause Enforcer test', () => { validatorContractAddress, roninBridgeManagerAddress, fastFinalityTrackingAddress, - } = await initTest('RoninGatewayV2-PauseEnforcer')({ + } = await initTest('RoninGatewayV3-PauseEnforcer')({ bridgeContract: bridgeContract.address, roninTrustedOrganizationArguments: { trustedOrganizations: trustedOrgs.map((v) => ({ diff --git a/test/hardhat_test/bridge/RoninGatewayV2.test.ts b/test/hardhat_test/bridge/RoninGatewayV3.test.ts similarity index 96% rename from test/hardhat_test/bridge/RoninGatewayV2.test.ts rename to test/hardhat_test/bridge/RoninGatewayV3.test.ts index 5312ec58f..3b4c02378 100644 --- a/test/hardhat_test/bridge/RoninGatewayV2.test.ts +++ b/test/hardhat_test/bridge/RoninGatewayV3.test.ts @@ -11,8 +11,8 @@ import { ERC20PresetMinterPauser__factory, MockRoninValidatorSetExtended, MockRoninValidatorSetExtended__factory, - MockRoninGatewayV2Extended, - MockRoninGatewayV2Extended__factory, + MockRoninGatewayV3Extended, + MockRoninGatewayV3Extended__factory, RoninGovernanceAdmin, RoninGovernanceAdmin__factory, Staking, @@ -22,7 +22,7 @@ import { RoninBridgeManager, } from '../../../src/types'; import { ERC20PresetMinterPauser } from '../../../src/types/ERC20PresetMinterPauser'; -import { ReceiptStruct } from '../../../src/types/IRoninGatewayV2'; +import { ReceiptStruct } from '../../../src/types/IRoninGatewayV3'; import { DEFAULT_ADDRESS } from '../../../src/utils'; import { initTest } from '../helpers/fixture'; import { ContractType, mineBatchTxs } from '../helpers/utils'; @@ -34,7 +34,7 @@ let coinbase: SignerWithAddress; let operatorTuples: OperatorTuple[]; let signers: SignerWithAddress[]; -let bridgeContract: MockRoninGatewayV2Extended; +let bridgeContract: MockRoninGatewayV3Extended; let bridgeTracking: BridgeTracking; let stakingContract: Staking; let roninValidatorSet: MockRoninValidatorSetExtended; @@ -72,7 +72,7 @@ describe('Ronin Gateway V2 test', () => { // Deploys bridge contracts token = await new ERC20PresetMinterPauser__factory(deployer).deploy('ERC20', 'ERC20'); - const gatewayLogic = await new MockRoninGatewayV2Extended__factory(deployer).deploy(); + const gatewayLogic = await new MockRoninGatewayV3Extended__factory(deployer).deploy(); const gatewayProxy = await new TransparentUpgradeableProxyV2__factory(deployer).deploy( gatewayLogic.address, deployer.address, @@ -88,7 +88,7 @@ describe('Ronin Gateway V2 test', () => { [0], ]) ); - bridgeContract = MockRoninGatewayV2Extended__factory.connect(gatewayProxy.address, deployer); + bridgeContract = MockRoninGatewayV3Extended__factory.connect(gatewayProxy.address, deployer); await token.grantRole(await token.MINTER_ROLE(), bridgeContract.address); // Deploys DPoS contracts @@ -98,7 +98,7 @@ describe('Ronin Gateway V2 test', () => { bridgeTrackingAddress, roninBridgeManagerAddress, roninTrustedOrganizationAddress, - } = await initTest('RoninGatewayV2')({ + } = await initTest('RoninGatewayV3')({ bridgeContract: bridgeContract.address, stakingArguments: { minValidatorStakingAmount, diff --git a/test/hardhat_test/integration/ActionBridgeTracking.test.ts b/test/hardhat_test/integration/ActionBridgeTracking.test.ts index 3d24b3e80..a76bb8c3c 100644 --- a/test/hardhat_test/integration/ActionBridgeTracking.test.ts +++ b/test/hardhat_test/integration/ActionBridgeTracking.test.ts @@ -12,8 +12,8 @@ import { MockRoninValidatorSetExtended__factory, RoninBridgeManager, RoninBridgeManager__factory, - RoninGatewayV2, - RoninGatewayV2__factory, + RoninGatewayV3, + RoninGatewayV3__factory, RoninGovernanceAdmin, RoninGovernanceAdmin__factory, Staking, @@ -21,7 +21,7 @@ import { TransparentUpgradeableProxyV2__factory, } from '../../../src/types'; import { ERC20PresetMinterPauser } from '../../../src/types/ERC20PresetMinterPauser'; -import { ReceiptStruct } from '../../../src/types/IRoninGatewayV2'; +import { ReceiptStruct } from '../../../src/types/IRoninGatewayV3'; import { DEFAULT_ADDRESS } from '../../../src/utils'; import { createManyTrustedOrganizationAddressSets, @@ -45,7 +45,7 @@ let candidates: ValidatorCandidateAddressSet[]; let operatorTuples: OperatorTuple[]; let signers: SignerWithAddress[]; -let bridgeContract: RoninGatewayV2; +let bridgeContract: RoninGatewayV3; let bridgeTracking: BridgeTracking; let stakingContract: Staking; let roninValidatorSet: MockRoninValidatorSetExtended; @@ -88,7 +88,7 @@ describe('[Integration] Bridge Tracking test', () => { // Deploys bridge contracts token = await new ERC20PresetMinterPauser__factory(deployer).deploy('ERC20', 'ERC20'); - const bridgeLogic = await new RoninGatewayV2__factory(deployer).deploy(); + const bridgeLogic = await new RoninGatewayV3__factory(deployer).deploy(); const bridgeProxy = await new TransparentUpgradeableProxyV2__factory(deployer).deploy( bridgeLogic.address, deployer.address, @@ -149,7 +149,7 @@ describe('[Integration] Bridge Tracking test', () => { }, }); - bridgeContract = RoninGatewayV2__factory.connect(bridgeProxy.address, deployer); + bridgeContract = RoninGatewayV3__factory.connect(bridgeProxy.address, deployer); await token.grantRole(await token.MINTER_ROLE(), bridgeContract.address); stakingContract = Staking__factory.connect(stakingContractAddress, deployer); @@ -226,7 +226,12 @@ describe('[Integration] Bridge Tracking test', () => { expect(period).gt(0); // InitV3 after the period 0 - await bridgeTracking.initializeV3(bridgeManager.address, bridgeSlashAddress, bridgeRewardAddress); + await bridgeTracking.initializeV3( + bridgeManager.address, + bridgeSlashAddress, + bridgeRewardAddress, + governanceAdmin.address + ); }); after(async () => { diff --git a/yarn.lock b/yarn.lock index 4b9733f46..4ee4eac9f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1,5366 +1,7714 @@ -# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. -# yarn lockfile v1 - - -"@babel/code-frame@^7.0.0": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.22.5.tgz#234d98e1551960604f1246e6475891a570ad5658" - integrity sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ== - dependencies: - "@babel/highlight" "^7.22.5" - -"@babel/helper-validator-identifier@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz#9544ef6a33999343c8740fa51350f30eeaaaf193" - integrity sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ== - -"@babel/highlight@^7.22.5": - version "7.22.5" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.22.5.tgz#aa6c05c5407a67ebce408162b7ede789b4d22031" - integrity sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw== - dependencies: - "@babel/helper-validator-identifier" "^7.22.5" - chalk "^2.0.0" - js-tokens "^4.0.0" - -"@chainsafe/as-sha256@^0.3.1": - version "0.3.1" - resolved "https://registry.yarnpkg.com/@chainsafe/as-sha256/-/as-sha256-0.3.1.tgz#3639df0e1435cab03f4d9870cc3ac079e57a6fc9" - integrity sha512-hldFFYuf49ed7DAakWVXSJODuq3pzJEguD8tQ7h+sGkM18vja+OFoJI9krnGmgzyuZC2ETX0NOIcCTy31v2Mtg== - -"@chainsafe/persistent-merkle-tree@^0.4.2": - version "0.4.2" - resolved "https://registry.yarnpkg.com/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.4.2.tgz#4c9ee80cc57cd3be7208d98c40014ad38f36f7ff" - integrity sha512-lLO3ihKPngXLTus/L7WHKaw9PnNJWizlOF1H9NNzHP6Xvh82vzg9F2bzkXhYIFshMZ2gTCEz8tq6STe7r5NDfQ== - dependencies: - "@chainsafe/as-sha256" "^0.3.1" - -"@chainsafe/persistent-merkle-tree@^0.5.0": - version "0.5.0" - resolved "https://registry.yarnpkg.com/@chainsafe/persistent-merkle-tree/-/persistent-merkle-tree-0.5.0.tgz#2b4a62c9489a5739dedd197250d8d2f5427e9f63" - integrity sha512-l0V1b5clxA3iwQLXP40zYjyZYospQLZXzBVIhhr9kDg/1qHZfzzHw0jj4VPBijfYCArZDlPkRi1wZaV2POKeuw== - dependencies: - "@chainsafe/as-sha256" "^0.3.1" - -"@chainsafe/ssz@^0.10.0": - version "0.10.2" - resolved "https://registry.yarnpkg.com/@chainsafe/ssz/-/ssz-0.10.2.tgz#c782929e1bb25fec66ba72e75934b31fd087579e" - integrity sha512-/NL3Lh8K+0q7A3LsiFq09YXS9fPE+ead2rr7vM2QK8PLzrNsw3uqrif9bpRX5UxgeRjM+vYi+boCM3+GM4ovXg== - dependencies: - "@chainsafe/as-sha256" "^0.3.1" - "@chainsafe/persistent-merkle-tree" "^0.5.0" - -"@chainsafe/ssz@^0.9.2": - version "0.9.4" - resolved "https://registry.yarnpkg.com/@chainsafe/ssz/-/ssz-0.9.4.tgz#696a8db46d6975b600f8309ad3a12f7c0e310497" - integrity sha512-77Qtg2N1ayqs4Bg/wvnWfg5Bta7iy7IRh8XqXh7oNMeP2HBbBwx8m6yTpA8p0EHItWPEBkgZd5S5/LSlp3GXuQ== - dependencies: - "@chainsafe/as-sha256" "^0.3.1" - "@chainsafe/persistent-merkle-tree" "^0.4.2" - case "^1.6.3" - -"@colors/colors@1.5.0": - version "1.5.0" - resolved "https://registry.yarnpkg.com/@colors/colors/-/colors-1.5.0.tgz#bb504579c1cae923e6576a4f5da43d25f97bdbd9" - integrity sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ== - -"@cspotcode/source-map-support@^0.8.0": - version "0.8.1" - resolved "https://registry.yarnpkg.com/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz#00629c35a688e05a88b1cda684fb9d5e73f000a1" - integrity sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw== - dependencies: - "@jridgewell/trace-mapping" "0.3.9" - -"@ethersproject/abi@5.7.0", "@ethersproject/abi@^5.0.0-beta.146", "@ethersproject/abi@^5.1.2", "@ethersproject/abi@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/abi/-/abi-5.7.0.tgz#b3f3e045bbbeed1af3947335c247ad625a44e449" - integrity sha512-351ktp42TiRcYB3H1OP8yajPeAQstMW/yCFokj/AthP9bLHzQFPlOrxOcwYEDkUAICmOHljvN4K39OMTMUa9RA== - dependencies: - "@ethersproject/address" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/hash" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - -"@ethersproject/abstract-provider@5.7.0", "@ethersproject/abstract-provider@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/abstract-provider/-/abstract-provider-5.7.0.tgz#b0a8550f88b6bf9d51f90e4795d48294630cb9ef" - integrity sha512-R41c9UkchKCpAqStMYUpdunjo3pkEvZC3FAwZn5S5MGbXoMQOHIdHItezTETxAO5bevtMApSyEhn9+CHcDsWBw== - dependencies: - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/networks" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - "@ethersproject/web" "^5.7.0" - -"@ethersproject/abstract-signer@5.7.0", "@ethersproject/abstract-signer@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/abstract-signer/-/abstract-signer-5.7.0.tgz#13f4f32117868452191a4649723cb086d2b596b2" - integrity sha512-a16V8bq1/Cz+TGCkE2OPMTOUDLS3grCpdjoJCYNnVBbdYEMSgKrU0+B90s8b6H+ByYTBZN7a3g76jdIJi7UfKQ== - dependencies: - "@ethersproject/abstract-provider" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - -"@ethersproject/address@5.7.0", "@ethersproject/address@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/address/-/address-5.7.0.tgz#19b56c4d74a3b0a46bfdbb6cfcc0a153fc697f37" - integrity sha512-9wYhYt7aghVGo758POM5nqcOMaE168Q6aRLJZwUmiqSrAungkG74gSSeKEIR7ukixesdRZGPgVqme6vmxs1fkA== - dependencies: - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/rlp" "^5.7.0" - -"@ethersproject/base64@5.7.0", "@ethersproject/base64@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/base64/-/base64-5.7.0.tgz#ac4ee92aa36c1628173e221d0d01f53692059e1c" - integrity sha512-Dr8tcHt2mEbsZr/mwTPIQAf3Ai0Bks/7gTw9dSqk1mQvhW3XvRlmDJr/4n+wg1JmCl16NZue17CDh8xb/vZ0sQ== - dependencies: - "@ethersproject/bytes" "^5.7.0" - -"@ethersproject/basex@5.7.0", "@ethersproject/basex@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/basex/-/basex-5.7.0.tgz#97034dc7e8938a8ca943ab20f8a5e492ece4020b" - integrity sha512-ywlh43GwZLv2Voc2gQVTKBoVQ1mti3d8HK5aMxsfu/nRDnMmNqaSJ3r3n85HBByT8OpoY96SXM1FogC533T4zw== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - -"@ethersproject/bignumber@5.7.0", "@ethersproject/bignumber@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/bignumber/-/bignumber-5.7.0.tgz#e2f03837f268ba655ffba03a57853e18a18dc9c2" - integrity sha512-n1CAdIHRWjSucQO3MC1zPSVgV/6dy/fjL9pMrPP9peL+QxEg9wOsVqwD4+818B6LUEtaXzVHQiuivzRoxPxUGw== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - bn.js "^5.2.1" - -"@ethersproject/bytes@5.7.0", "@ethersproject/bytes@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/bytes/-/bytes-5.7.0.tgz#a00f6ea8d7e7534d6d87f47188af1148d71f155d" - integrity sha512-nsbxwgFXWh9NyYWo+U8atvmMsSdKJprTcICAkvbBffT75qDocbuggBU0SJiVK2MuTrp0q+xvLkTnGMPK1+uA9A== - dependencies: - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/constants@5.7.0", "@ethersproject/constants@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/constants/-/constants-5.7.0.tgz#df80a9705a7e08984161f09014ea012d1c75295e" - integrity sha512-DHI+y5dBNvkpYUMiRQyxRBYBefZkJfo70VUkUAsRjcPs47muV9evftfZ0PJVCXYbAiCgght0DtcF9srFQmIgWA== - dependencies: - "@ethersproject/bignumber" "^5.7.0" - -"@ethersproject/contracts@5.7.0", "@ethersproject/contracts@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/contracts/-/contracts-5.7.0.tgz#c305e775abd07e48aa590e1a877ed5c316f8bd1e" - integrity sha512-5GJbzEU3X+d33CdfPhcyS+z8MzsTrBGk/sc+G+59+tPa9yFkl6HQ9D6L0QMgNTA9q8dT0XKxxkyp883XsQvbbg== - dependencies: - "@ethersproject/abi" "^5.7.0" - "@ethersproject/abstract-provider" "^5.7.0" - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - -"@ethersproject/hash@5.7.0", "@ethersproject/hash@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/hash/-/hash-5.7.0.tgz#eb7aca84a588508369562e16e514b539ba5240a7" - integrity sha512-qX5WrQfnah1EFnO5zJv1v46a8HW0+E5xuBBDTwMFZLuVTx0tbU2kkx15NqdjxecrLGatQN9FGQKpb1FKdHCt+g== - dependencies: - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/base64" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - -"@ethersproject/hdnode@5.7.0", "@ethersproject/hdnode@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/hdnode/-/hdnode-5.7.0.tgz#e627ddc6b466bc77aebf1a6b9e47405ca5aef9cf" - integrity sha512-OmyYo9EENBPPf4ERhR7oj6uAtUAhYGqOnIS+jE5pTXvdKBS99ikzq1E7Iv0ZQZ5V36Lqx1qZLeak0Ra16qpeOg== - dependencies: - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/basex" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/pbkdf2" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/sha2" "^5.7.0" - "@ethersproject/signing-key" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - "@ethersproject/wordlists" "^5.7.0" - -"@ethersproject/json-wallets@5.7.0", "@ethersproject/json-wallets@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/json-wallets/-/json-wallets-5.7.0.tgz#5e3355287b548c32b368d91014919ebebddd5360" - integrity sha512-8oee5Xgu6+RKgJTkvEMl2wDgSPSAQ9MB/3JYjFV9jlKvcYHUXZC+cQp0njgmxdHkYWn8s6/IqIZYm0YWCjO/0g== - dependencies: - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/hdnode" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/pbkdf2" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/random" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - aes-js "3.0.0" - scrypt-js "3.0.1" - -"@ethersproject/keccak256@5.7.0", "@ethersproject/keccak256@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/keccak256/-/keccak256-5.7.0.tgz#3186350c6e1cd6aba7940384ec7d6d9db01f335a" - integrity sha512-2UcPboeL/iW+pSg6vZ6ydF8tCnv3Iu/8tUmLLzWWGzxWKFFqOBQFLo6uLUv6BDrLgCDfN28RJ/wtByx+jZ4KBg== - dependencies: - "@ethersproject/bytes" "^5.7.0" - js-sha3 "0.8.0" - -"@ethersproject/logger@5.7.0", "@ethersproject/logger@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/logger/-/logger-5.7.0.tgz#6ce9ae168e74fecf287be17062b590852c311892" - integrity sha512-0odtFdXu/XHtjQXJYA3u9G0G8btm0ND5Cu8M7i5vhEcE8/HmF4Lbdqanwyv4uQTr2tx6b7fQRmgLrsnpQlmnig== - -"@ethersproject/networks@5.7.1", "@ethersproject/networks@^5.7.0": - version "5.7.1" - resolved "https://registry.yarnpkg.com/@ethersproject/networks/-/networks-5.7.1.tgz#118e1a981d757d45ccea6bb58d9fd3d9db14ead6" - integrity sha512-n/MufjFYv3yFcUyfhnXotyDlNdFb7onmkSy8aQERi2PjNcnWQ66xXxa3XlS8nCcA8aJKJjIIMNJTC7tu80GwpQ== - dependencies: - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/pbkdf2@5.7.0", "@ethersproject/pbkdf2@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/pbkdf2/-/pbkdf2-5.7.0.tgz#d2267d0a1f6e123f3771007338c47cccd83d3102" - integrity sha512-oR/dBRZR6GTyaofd86DehG72hY6NpAjhabkhxgr3X2FpJtJuodEl2auADWBZfhDHgVCbu3/H/Ocq2uC6dpNjjw== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/sha2" "^5.7.0" - -"@ethersproject/properties@5.7.0", "@ethersproject/properties@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/properties/-/properties-5.7.0.tgz#a6e12cb0439b878aaf470f1902a176033067ed30" - integrity sha512-J87jy8suntrAkIZtecpxEPxY//szqr1mlBaYlQ0r4RCaiD2hjheqF9s1LVE8vVuJCXisjIP+JgtK/Do54ej4Sw== - dependencies: - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/providers@5.7.2", "@ethersproject/providers@^5.7.1", "@ethersproject/providers@^5.7.2": - version "5.7.2" - resolved "https://registry.yarnpkg.com/@ethersproject/providers/-/providers-5.7.2.tgz#f8b1a4f275d7ce58cf0a2eec222269a08beb18cb" - integrity sha512-g34EWZ1WWAVgr4aptGlVBF8mhl3VWjv+8hoAnzStu8Ah22VHBsuGzP17eb6xDVRzw895G4W7vvx60lFFur/1Rg== - dependencies: - "@ethersproject/abstract-provider" "^5.7.0" - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/base64" "^5.7.0" - "@ethersproject/basex" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/hash" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/networks" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/random" "^5.7.0" - "@ethersproject/rlp" "^5.7.0" - "@ethersproject/sha2" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - "@ethersproject/web" "^5.7.0" - bech32 "1.1.4" - ws "7.4.6" - -"@ethersproject/random@5.7.0", "@ethersproject/random@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/random/-/random-5.7.0.tgz#af19dcbc2484aae078bb03656ec05df66253280c" - integrity sha512-19WjScqRA8IIeWclFme75VMXSBvi4e6InrUNuaR4s5pTF2qNhcGdCUwdxUVGtDDqC00sDLCO93jPQoDUH4HVmQ== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/rlp@5.7.0", "@ethersproject/rlp@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/rlp/-/rlp-5.7.0.tgz#de39e4d5918b9d74d46de93af80b7685a9c21304" - integrity sha512-rBxzX2vK8mVF7b0Tol44t5Tb8gomOHkj5guL+HhzQ1yBh/ydjGnpw6at+X6Iw0Kp3OzzzkcKp8N9r0W4kYSs9w== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/sha2@5.7.0", "@ethersproject/sha2@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/sha2/-/sha2-5.7.0.tgz#9a5f7a7824ef784f7f7680984e593a800480c9fb" - integrity sha512-gKlH42riwb3KYp0reLsFTokByAKoJdgFCwI+CCiX/k+Jm2mbNs6oOaCjYQSlI1+XBVejwH2KrmCbMAT/GnRDQw== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - hash.js "1.1.7" - -"@ethersproject/signing-key@5.7.0", "@ethersproject/signing-key@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/signing-key/-/signing-key-5.7.0.tgz#06b2df39411b00bc57c7c09b01d1e41cf1b16ab3" - integrity sha512-MZdy2nL3wO0u7gkB4nA/pEf8lu1TlFswPNmy8AiYkfKTdO6eXBJyUdmHO/ehm/htHw9K/qF8ujnTyUAD+Ry54Q== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - bn.js "^5.2.1" - elliptic "6.5.4" - hash.js "1.1.7" - -"@ethersproject/solidity@5.7.0", "@ethersproject/solidity@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/solidity/-/solidity-5.7.0.tgz#5e9c911d8a2acce2a5ebb48a5e2e0af20b631cb8" - integrity sha512-HmabMd2Dt/raavyaGukF4XxizWKhKQ24DoLtdNbBmNKUOPqwjsKQSdV9GQtj9CBEea9DlzETlVER1gYeXXBGaA== - dependencies: - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/sha2" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - -"@ethersproject/strings@5.7.0", "@ethersproject/strings@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/strings/-/strings-5.7.0.tgz#54c9d2a7c57ae8f1205c88a9d3a56471e14d5ed2" - integrity sha512-/9nu+lj0YswRNSH0NXYqrh8775XNyEdUQAuf3f+SmOrnVewcJ5SBNAjF7lpgehKi4abvNNXyf+HX86czCdJ8Mg== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/transactions@5.7.0", "@ethersproject/transactions@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/transactions/-/transactions-5.7.0.tgz#91318fc24063e057885a6af13fdb703e1f993d3b" - integrity sha512-kmcNicCp1lp8qanMTC3RIikGgoJ80ztTyvtsFvCYpSCfkjhD0jZ2LOrnbcuxuToLIUYYf+4XwD1rP+B/erDIhQ== - dependencies: - "@ethersproject/address" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/rlp" "^5.7.0" - "@ethersproject/signing-key" "^5.7.0" - -"@ethersproject/units@5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/units/-/units-5.7.0.tgz#637b563d7e14f42deeee39245275d477aae1d8b1" - integrity sha512-pD3xLMy3SJu9kG5xDGI7+xhTEmGXlEqXU4OfNapmfnxLVY4EMSSRp7j1k7eezutBPH7RBN/7QPnwR7hzNlEFeg== - dependencies: - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - -"@ethersproject/wallet@5.7.0", "@ethersproject/wallet@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/wallet/-/wallet-5.7.0.tgz#4e5d0790d96fe21d61d38fb40324e6c7ef350b2d" - integrity sha512-MhmXlJXEJFBFVKrDLB4ZdDzxcBxQ3rLyCkhNqVu3CDYvR97E+8r01UgrI+TI99Le+aYm/in/0vp86guJuM7FCA== - dependencies: - "@ethersproject/abstract-provider" "^5.7.0" - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/hash" "^5.7.0" - "@ethersproject/hdnode" "^5.7.0" - "@ethersproject/json-wallets" "^5.7.0" - "@ethersproject/keccak256" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/random" "^5.7.0" - "@ethersproject/signing-key" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - "@ethersproject/wordlists" "^5.7.0" - -"@ethersproject/web@5.7.1", "@ethersproject/web@^5.7.0": - version "5.7.1" - resolved "https://registry.yarnpkg.com/@ethersproject/web/-/web-5.7.1.tgz#de1f285b373149bee5928f4eb7bcb87ee5fbb4ae" - integrity sha512-Gueu8lSvyjBWL4cYsWsjh6MtMwM0+H4HvqFPZfB6dV8ctbP9zFAO73VG1cMWae0FLPCtz0peKPpZY8/ugJJX2w== - dependencies: - "@ethersproject/base64" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - -"@ethersproject/wordlists@5.7.0", "@ethersproject/wordlists@^5.7.0": - version "5.7.0" - resolved "https://registry.yarnpkg.com/@ethersproject/wordlists/-/wordlists-5.7.0.tgz#8fb2c07185d68c3e09eb3bfd6e779ba2774627f5" - integrity sha512-S2TFNJNfHWVHNE6cNDjbVlZ6MgE17MIxMbMg2zv3wn+3XSJGosL1m9ZVv3GXCf/2ymSsQ+hRI5IzoMJTG6aoVA== - dependencies: - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/hash" "^5.7.0" - "@ethersproject/logger" "^5.7.0" - "@ethersproject/properties" "^5.7.0" - "@ethersproject/strings" "^5.7.0" - -"@jridgewell/resolve-uri@^3.0.3": - version "3.1.1" - resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz#c08679063f279615a3326583ba3a90d1d82cc721" - integrity sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA== - -"@jridgewell/sourcemap-codec@^1.4.10": - version "1.4.15" - resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" - integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== - -"@jridgewell/trace-mapping@0.3.9": - version "0.3.9" - resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz#6534fd5933a53ba7cbf3a17615e273a0d1273ff9" - integrity sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ== - dependencies: - "@jridgewell/resolve-uri" "^3.0.3" - "@jridgewell/sourcemap-codec" "^1.4.10" - -"@metamask/eth-sig-util@^4.0.0": - version "4.0.1" - resolved "https://registry.yarnpkg.com/@metamask/eth-sig-util/-/eth-sig-util-4.0.1.tgz#3ad61f6ea9ad73ba5b19db780d40d9aae5157088" - integrity sha512-tghyZKLHZjcdlDqCA3gNZmLeR0XvOE9U1qoQO9ohyAZT6Pya+H9vkBPcsyXytmYLNgVoin7CKCmweo/R43V+tQ== - dependencies: - ethereumjs-abi "^0.6.8" - ethereumjs-util "^6.2.1" - ethjs-util "^0.1.6" - tweetnacl "^1.0.3" - tweetnacl-util "^0.15.1" - -"@noble/hashes@1.2.0", "@noble/hashes@~1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@noble/hashes/-/hashes-1.2.0.tgz#a3150eeb09cc7ab207ebf6d7b9ad311a9bdbed12" - integrity sha512-FZfhjEDbT5GRswV3C6uvLPHMiVD6lQBmpoX5+eSiPaMTXte/IKqI5dykDxzZB/WBeK/CDuQRBWarPdi3FNY2zQ== - -"@noble/secp256k1@1.7.1", "@noble/secp256k1@~1.7.0": - version "1.7.1" - resolved "https://registry.yarnpkg.com/@noble/secp256k1/-/secp256k1-1.7.1.tgz#b251c70f824ce3ca7f8dc3df08d58f005cc0507c" - integrity sha512-hOUk6AyBFmqVrv7k5WAw/LpszxVbj9gGN4JRkIX52fdFAj1UA61KXmZDvqVEm+pOyec3+fIeZB02LYa/pWOArw== - -"@nodelib/fs.scandir@2.1.5": - version "2.1.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" - integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== - dependencies: - "@nodelib/fs.stat" "2.0.5" - run-parallel "^1.1.9" - -"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": - version "2.0.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" - integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== - -"@nodelib/fs.walk@^1.2.3": - version "1.2.8" - resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" - integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== - dependencies: - "@nodelib/fs.scandir" "2.1.5" - fastq "^1.6.0" - -"@nomicfoundation/ethereumjs-block@5.0.1": - version "5.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-block/-/ethereumjs-block-5.0.1.tgz#6f89664f55febbd723195b6d0974773d29ee133d" - integrity sha512-u1Yioemi6Ckj3xspygu/SfFvm8vZEO8/Yx5a1QLzi6nVU0jz3Pg2OmHKJ5w+D9Ogk1vhwRiqEBAqcb0GVhCyHw== - dependencies: - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-trie" "6.0.1" - "@nomicfoundation/ethereumjs-tx" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - ethereum-cryptography "0.1.3" - ethers "^5.7.1" - -"@nomicfoundation/ethereumjs-blockchain@7.0.1": - version "7.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-blockchain/-/ethereumjs-blockchain-7.0.1.tgz#80e0bd3535bfeb9baa29836b6f25123dab06a726" - integrity sha512-NhzndlGg829XXbqJEYrF1VeZhAwSPgsK/OB7TVrdzft3y918hW5KNd7gIZ85sn6peDZOdjBsAXIpXZ38oBYE5A== - dependencies: - "@nomicfoundation/ethereumjs-block" "5.0.1" - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-ethash" "3.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-trie" "6.0.1" - "@nomicfoundation/ethereumjs-tx" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - abstract-level "^1.0.3" - debug "^4.3.3" - ethereum-cryptography "0.1.3" - level "^8.0.0" - lru-cache "^5.1.1" - memory-level "^1.0.0" - -"@nomicfoundation/ethereumjs-common@4.0.1": - version "4.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-common/-/ethereumjs-common-4.0.1.tgz#4702d82df35b07b5407583b54a45bf728e46a2f0" - integrity sha512-OBErlkfp54GpeiE06brBW/TTbtbuBJV5YI5Nz/aB2evTDo+KawyEzPjBlSr84z/8MFfj8wS2wxzQX1o32cev5g== - dependencies: - "@nomicfoundation/ethereumjs-util" "9.0.1" - crc-32 "^1.2.0" - -"@nomicfoundation/ethereumjs-ethash@3.0.1": - version "3.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-ethash/-/ethereumjs-ethash-3.0.1.tgz#65ca494d53e71e8415c9a49ef48bc921c538fc41" - integrity sha512-KDjGIB5igzWOp8Ik5I6QiRH5DH+XgILlplsHR7TEuWANZA759G6krQ6o8bvj+tRUz08YygMQu/sGd9mJ1DYT8w== - dependencies: - "@nomicfoundation/ethereumjs-block" "5.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - abstract-level "^1.0.3" - bigint-crypto-utils "^3.0.23" - ethereum-cryptography "0.1.3" - -"@nomicfoundation/ethereumjs-evm@2.0.1": - version "2.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-evm/-/ethereumjs-evm-2.0.1.tgz#f35681e203363f69ce2b3d3bf9f44d4e883ca1f1" - integrity sha512-oL8vJcnk0Bx/onl+TgQOQ1t/534GKFaEG17fZmwtPFeH8S5soiBYPCLUrvANOl4sCp9elYxIMzIiTtMtNNN8EQ== - dependencies: - "@ethersproject/providers" "^5.7.1" - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-tx" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - debug "^4.3.3" - ethereum-cryptography "0.1.3" - mcl-wasm "^0.7.1" - rustbn.js "~0.2.0" - -"@nomicfoundation/ethereumjs-rlp@5.0.1": - version "5.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-rlp/-/ethereumjs-rlp-5.0.1.tgz#0b30c1cf77d125d390408e391c4bb5291ef43c28" - integrity sha512-xtxrMGa8kP4zF5ApBQBtjlSbN5E2HI8m8FYgVSYAnO6ssUoY5pVPGy2H8+xdf/bmMa22Ce8nWMH3aEW8CcqMeQ== - -"@nomicfoundation/ethereumjs-statemanager@2.0.1": - version "2.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-statemanager/-/ethereumjs-statemanager-2.0.1.tgz#8824a97938db4471911e2d2f140f79195def5935" - integrity sha512-B5ApMOnlruVOR7gisBaYwFX+L/AP7i/2oAahatssjPIBVDF6wTX1K7Qpa39E/nzsH8iYuL3krkYeUFIdO3EMUQ== - dependencies: - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - debug "^4.3.3" - ethereum-cryptography "0.1.3" - ethers "^5.7.1" - js-sdsl "^4.1.4" - -"@nomicfoundation/ethereumjs-trie@6.0.1": - version "6.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-trie/-/ethereumjs-trie-6.0.1.tgz#662c55f6b50659fd4b22ea9f806a7401cafb7717" - integrity sha512-A64It/IMpDVODzCgxDgAAla8jNjNtsoQZIzZUfIV5AY6Coi4nvn7+VReBn5itlxMiL2yaTlQr9TRWp3CSI6VoA== - dependencies: - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - "@types/readable-stream" "^2.3.13" - ethereum-cryptography "0.1.3" - readable-stream "^3.6.0" - -"@nomicfoundation/ethereumjs-tx@5.0.1": - version "5.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-tx/-/ethereumjs-tx-5.0.1.tgz#7629dc2036b4a33c34e9f0a592b43227ef4f0c7d" - integrity sha512-0HwxUF2u2hrsIM1fsasjXvlbDOq1ZHFV2dd1yGq8CA+MEYhaxZr8OTScpVkkxqMwBcc5y83FyPl0J9MZn3kY0w== - dependencies: - "@chainsafe/ssz" "^0.9.2" - "@ethersproject/providers" "^5.7.2" - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - ethereum-cryptography "0.1.3" - -"@nomicfoundation/ethereumjs-util@9.0.1": - version "9.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-util/-/ethereumjs-util-9.0.1.tgz#530cda8bae33f8b5020a8f199ed1d0a2ce48ec89" - integrity sha512-TwbhOWQ8QoSCFhV/DDfSmyfFIHjPjFBj957219+V3jTZYZ2rf9PmDtNOeZWAE3p3vlp8xb02XGpd0v6nTUPbsA== - dependencies: - "@chainsafe/ssz" "^0.10.0" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - ethereum-cryptography "0.1.3" - -"@nomicfoundation/ethereumjs-vm@7.0.1": - version "7.0.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/ethereumjs-vm/-/ethereumjs-vm-7.0.1.tgz#7d035e0993bcad10716c8b36e61dfb87fa3ca05f" - integrity sha512-rArhyn0jPsS/D+ApFsz3yVJMQ29+pVzNZ0VJgkzAZ+7FqXSRtThl1C1prhmlVr3YNUlfpZ69Ak+RUT4g7VoOuQ== - dependencies: - "@nomicfoundation/ethereumjs-block" "5.0.1" - "@nomicfoundation/ethereumjs-blockchain" "7.0.1" - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-evm" "2.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-statemanager" "2.0.1" - "@nomicfoundation/ethereumjs-trie" "6.0.1" - "@nomicfoundation/ethereumjs-tx" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - debug "^4.3.3" - ethereum-cryptography "0.1.3" - mcl-wasm "^0.7.1" - rustbn.js "~0.2.0" - -"@nomicfoundation/hardhat-chai-matchers@^1.0.3": - version "1.0.6" - resolved "https://registry.yarnpkg.com/@nomicfoundation/hardhat-chai-matchers/-/hardhat-chai-matchers-1.0.6.tgz#72a2e312e1504ee5dd73fe302932736432ba96bc" - integrity sha512-f5ZMNmabZeZegEfuxn/0kW+mm7+yV7VNDxLpMOMGXWFJ2l/Ct3QShujzDRF9cOkK9Ui/hbDeOWGZqyQALDXVCQ== - dependencies: - "@ethersproject/abi" "^5.1.2" - "@types/chai-as-promised" "^7.1.3" - chai-as-promised "^7.1.1" - deep-eql "^4.0.1" - ordinal "^1.0.3" - -"@nomicfoundation/hardhat-foundry@^1.0.1": - version "1.0.2" - resolved "https://registry.yarnpkg.com/@nomicfoundation/hardhat-foundry/-/hardhat-foundry-1.0.2.tgz#281627e4872bba47c1cd4fcf47fff2259df8d5c6" - integrity sha512-NbOrtIKcss51h+1h/TaZkCxOn9KaGbLd6/l75V4X7oDhonGmMWevwrKTNMHC90wCATDkV+B37jmn3fGbWCs+Vg== - dependencies: - chalk "^2.4.2" - -"@nomicfoundation/solidity-analyzer-darwin-arm64@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-darwin-arm64/-/solidity-analyzer-darwin-arm64-0.1.1.tgz#4c858096b1c17fe58a474fe81b46815f93645c15" - integrity sha512-KcTodaQw8ivDZyF+D76FokN/HdpgGpfjc/gFCImdLUyqB6eSWVaZPazMbeAjmfhx3R0zm/NYVzxwAokFKgrc0w== - -"@nomicfoundation/solidity-analyzer-darwin-x64@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-darwin-x64/-/solidity-analyzer-darwin-x64-0.1.1.tgz#6e25ccdf6e2d22389c35553b64fe6f3fdaec432c" - integrity sha512-XhQG4BaJE6cIbjAVtzGOGbK3sn1BO9W29uhk9J8y8fZF1DYz0Doj8QDMfpMu+A6TjPDs61lbsmeYodIDnfveSA== - -"@nomicfoundation/solidity-analyzer-freebsd-x64@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-freebsd-x64/-/solidity-analyzer-freebsd-x64-0.1.1.tgz#0a224ea50317139caeebcdedd435c28a039d169c" - integrity sha512-GHF1VKRdHW3G8CndkwdaeLkVBi5A9u2jwtlS7SLhBc8b5U/GcoL39Q+1CSO3hYqePNP+eV5YI7Zgm0ea6kMHoA== - -"@nomicfoundation/solidity-analyzer-linux-arm64-gnu@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-linux-arm64-gnu/-/solidity-analyzer-linux-arm64-gnu-0.1.1.tgz#dfa085d9ffab9efb2e7b383aed3f557f7687ac2b" - integrity sha512-g4Cv2fO37ZsUENQ2vwPnZc2zRenHyAxHcyBjKcjaSmmkKrFr64yvzeNO8S3GBFCo90rfochLs99wFVGT/0owpg== - -"@nomicfoundation/solidity-analyzer-linux-arm64-musl@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-linux-arm64-musl/-/solidity-analyzer-linux-arm64-musl-0.1.1.tgz#c9e06b5d513dd3ab02a7ac069c160051675889a4" - integrity sha512-WJ3CE5Oek25OGE3WwzK7oaopY8xMw9Lhb0mlYuJl/maZVo+WtP36XoQTb7bW/i8aAdHW5Z+BqrHMux23pvxG3w== - -"@nomicfoundation/solidity-analyzer-linux-x64-gnu@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-linux-x64-gnu/-/solidity-analyzer-linux-x64-gnu-0.1.1.tgz#8d328d16839e52571f72f2998c81e46bf320f893" - integrity sha512-5WN7leSr5fkUBBjE4f3wKENUy9HQStu7HmWqbtknfXkkil+eNWiBV275IOlpXku7v3uLsXTOKpnnGHJYI2qsdA== - -"@nomicfoundation/solidity-analyzer-linux-x64-musl@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-linux-x64-musl/-/solidity-analyzer-linux-x64-musl-0.1.1.tgz#9b49d0634b5976bb5ed1604a1e1b736f390959bb" - integrity sha512-KdYMkJOq0SYPQMmErv/63CwGwMm5XHenEna9X9aB8mQmhDBrYrlAOSsIPgFCUSL0hjxE3xHP65/EPXR/InD2+w== - -"@nomicfoundation/solidity-analyzer-win32-arm64-msvc@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-win32-arm64-msvc/-/solidity-analyzer-win32-arm64-msvc-0.1.1.tgz#e2867af7264ebbcc3131ef837878955dd6a3676f" - integrity sha512-VFZASBfl4qiBYwW5xeY20exWhmv6ww9sWu/krWSesv3q5hA0o1JuzmPHR4LPN6SUZj5vcqci0O6JOL8BPw+APg== - -"@nomicfoundation/solidity-analyzer-win32-ia32-msvc@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-win32-ia32-msvc/-/solidity-analyzer-win32-ia32-msvc-0.1.1.tgz#0685f78608dd516c8cdfb4896ed451317e559585" - integrity sha512-JnFkYuyCSA70j6Si6cS1A9Gh1aHTEb8kOTBApp/c7NRTFGNMH8eaInKlyuuiIbvYFhlXW4LicqyYuWNNq9hkpQ== - -"@nomicfoundation/solidity-analyzer-win32-x64-msvc@0.1.1": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer-win32-x64-msvc/-/solidity-analyzer-win32-x64-msvc-0.1.1.tgz#c9a44f7108646f083b82e851486e0f6aeb785836" - integrity sha512-HrVJr6+WjIXGnw3Q9u6KQcbZCtk0caVWhCdFADySvRyUxJ8PnzlaP+MhwNE8oyT8OZ6ejHBRrrgjSqDCFXGirw== - -"@nomicfoundation/solidity-analyzer@^0.1.0": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@nomicfoundation/solidity-analyzer/-/solidity-analyzer-0.1.1.tgz#f5f4d36d3f66752f59a57e7208cd856f3ddf6f2d" - integrity sha512-1LMtXj1puAxyFusBgUIy5pZk3073cNXYnXUpuNKFghHbIit/xZgbk0AokpUADbNm3gyD6bFWl3LRFh3dhVdREg== - optionalDependencies: - "@nomicfoundation/solidity-analyzer-darwin-arm64" "0.1.1" - "@nomicfoundation/solidity-analyzer-darwin-x64" "0.1.1" - "@nomicfoundation/solidity-analyzer-freebsd-x64" "0.1.1" - "@nomicfoundation/solidity-analyzer-linux-arm64-gnu" "0.1.1" - "@nomicfoundation/solidity-analyzer-linux-arm64-musl" "0.1.1" - "@nomicfoundation/solidity-analyzer-linux-x64-gnu" "0.1.1" - "@nomicfoundation/solidity-analyzer-linux-x64-musl" "0.1.1" - "@nomicfoundation/solidity-analyzer-win32-arm64-msvc" "0.1.1" - "@nomicfoundation/solidity-analyzer-win32-ia32-msvc" "0.1.1" - "@nomicfoundation/solidity-analyzer-win32-x64-msvc" "0.1.1" - -"@nomiclabs/hardhat-ethers@^2.0.3": - version "2.2.3" - resolved "https://registry.yarnpkg.com/@nomiclabs/hardhat-ethers/-/hardhat-ethers-2.2.3.tgz#b41053e360c31a32c2640c9a45ee981a7e603fe0" - integrity sha512-YhzPdzb612X591FOe68q+qXVXGG2ANZRvDo0RRUtimev85rCrAlv/TLMEZw5c+kq9AbzocLTVX/h2jVIFPL9Xg== - -"@oclif/command@^1.8.0", "@oclif/command@^1.8.15": - version "1.8.35" - resolved "https://registry.yarnpkg.com/@oclif/command/-/command-1.8.35.tgz#7023f48a6b058d33ccb578c28a1522fba192efd2" - integrity sha512-oILFTe3n6WjEbhXaSJd6FPsU4H97WxkC3Q0+Y63pfTXIZ424Fb9Hlg1CazscWcJqCrhuuUag6mItdgYo0kpinw== - dependencies: - "@oclif/config" "^1.18.2" - "@oclif/errors" "^1.3.6" - "@oclif/help" "^1.0.1" - "@oclif/parser" "^3.8.16" - debug "^4.1.1" - semver "^7.5.4" - -"@oclif/config@1.18.15": - version "1.18.15" - resolved "https://registry.yarnpkg.com/@oclif/config/-/config-1.18.15.tgz#3be95862dda32d759fc61bcadff1e7819915a112" - integrity sha512-eBTiFXGfXSzghc4Yjp3EutYU+6MrHX1kzk4j5i4CsR5AEor43ynXFrzpO6v7IwbR1KyUo+9SYE2D69Y+sHIMpg== - dependencies: - "@oclif/errors" "^1.3.6" - "@oclif/parser" "^3.8.15" - debug "^4.3.4" - globby "^11.1.0" - is-wsl "^2.1.1" - tslib "^2.5.0" - -"@oclif/config@1.18.2": - version "1.18.2" - resolved "https://registry.yarnpkg.com/@oclif/config/-/config-1.18.2.tgz#5bfe74a9ba6a8ca3dceb314a81bd9ce2e15ebbfe" - integrity sha512-cE3qfHWv8hGRCP31j7fIS7BfCflm/BNZ2HNqHexH+fDrdF2f1D5S8VmXWLC77ffv3oDvWyvE9AZeR0RfmHCCaA== - dependencies: - "@oclif/errors" "^1.3.3" - "@oclif/parser" "^3.8.0" - debug "^4.1.1" - globby "^11.0.1" - is-wsl "^2.1.1" - tslib "^2.0.0" - -"@oclif/config@^1.17.0", "@oclif/config@^1.18.2": - version "1.18.16" - resolved "https://registry.yarnpkg.com/@oclif/config/-/config-1.18.16.tgz#3235d260ab1eb8388ebb6255bca3dd956249d796" - integrity sha512-VskIxVcN22qJzxRUq+raalq6Q3HUde7sokB7/xk5TqRZGEKRVbFeqdQBxDWwQeudiJEgcNiMvIFbMQ43dY37FA== - dependencies: - "@oclif/errors" "^1.3.6" - "@oclif/parser" "^3.8.16" - debug "^4.3.4" - globby "^11.1.0" - is-wsl "^2.1.1" - tslib "^2.6.1" - -"@oclif/errors@1.3.5": - version "1.3.5" - resolved "https://registry.yarnpkg.com/@oclif/errors/-/errors-1.3.5.tgz#a1e9694dbeccab10fe2fe15acb7113991bed636c" - integrity sha512-OivucXPH/eLLlOT7FkCMoZXiaVYf8I/w1eTAM1+gKzfhALwWTusxEx7wBmW0uzvkSg/9ovWLycPaBgJbM3LOCQ== - dependencies: - clean-stack "^3.0.0" - fs-extra "^8.1" - indent-string "^4.0.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" - -"@oclif/errors@1.3.6", "@oclif/errors@^1.3.3", "@oclif/errors@^1.3.6": - version "1.3.6" - resolved "https://registry.yarnpkg.com/@oclif/errors/-/errors-1.3.6.tgz#e8fe1fc12346cb77c4f274e26891964f5175f75d" - integrity sha512-fYaU4aDceETd89KXP+3cLyg9EHZsLD3RxF2IU9yxahhBpspWjkWi3Dy3bTgcwZ3V47BgxQaGapzJWDM33XIVDQ== - dependencies: - clean-stack "^3.0.0" - fs-extra "^8.1" - indent-string "^4.0.0" - strip-ansi "^6.0.1" - wrap-ansi "^7.0.0" - -"@oclif/help@^1.0.1": - version "1.0.14" - resolved "https://registry.yarnpkg.com/@oclif/help/-/help-1.0.14.tgz#da5f9fdf6f57b40b133f095cbb9c78c480975ca3" - integrity sha512-Hu2/Dyo91cgLNaqN3wkvkBGuZ7eqb0TQNVKrzGButZyaBpJzmwW4L6D4tAF390WDYZG7EubmLePlNYb+rNB4jw== - dependencies: - "@oclif/config" "1.18.15" - "@oclif/errors" "1.3.6" - chalk "^4.1.2" - indent-string "^4.0.0" - lodash "^4.17.21" - string-width "^4.2.0" - strip-ansi "^6.0.0" - widest-line "^3.1.0" - wrap-ansi "^6.2.0" - -"@oclif/linewrap@^1.0.0": - version "1.0.0" - resolved "https://registry.yarnpkg.com/@oclif/linewrap/-/linewrap-1.0.0.tgz#aedcb64b479d4db7be24196384897b5000901d91" - integrity sha512-Ups2dShK52xXa8w6iBWLgcjPJWjais6KPJQq3gQ/88AY6BXoTX+MIGFPrWQO1KLMiQfoTpcLnUwloN4brrVUHw== - -"@oclif/parser@^3.8.0", "@oclif/parser@^3.8.15", "@oclif/parser@^3.8.16": - version "3.8.16" - resolved "https://registry.yarnpkg.com/@oclif/parser/-/parser-3.8.16.tgz#bedfc55153075b8b2925657f8865035aa877515c" - integrity sha512-jeleXSh5izmBQ6vwyCJmbFPahPpd/ajxASi25FaYAWcvwVMzP/vKAKQXKWZun6T9K/gd6ywSsTpfAXiZAjBd6g== - dependencies: - "@oclif/errors" "^1.3.6" - "@oclif/linewrap" "^1.0.0" - chalk "^4.1.0" - tslib "^2.6.1" - -"@oclif/plugin-help@^3.2.0": - version "3.3.1" - resolved "https://registry.yarnpkg.com/@oclif/plugin-help/-/plugin-help-3.3.1.tgz#36adb4e0173f741df409bb4b69036d24a53bfb24" - integrity sha512-QuSiseNRJygaqAdABYFWn/H1CwIZCp9zp/PLid6yXvy6VcQV7OenEFF5XuYaCvSARe2Tg9r8Jqls5+fw1A9CbQ== - dependencies: - "@oclif/command" "^1.8.15" - "@oclif/config" "1.18.2" - "@oclif/errors" "1.3.5" - "@oclif/help" "^1.0.1" - chalk "^4.1.2" - indent-string "^4.0.0" - lodash "^4.17.21" - string-width "^4.2.0" - strip-ansi "^6.0.0" - widest-line "^3.1.0" - wrap-ansi "^6.2.0" - -"@openzeppelin/contracts@4.7.3": - version "4.7.3" - resolved "https://registry.yarnpkg.com/@openzeppelin/contracts/-/contracts-4.7.3.tgz#939534757a81f8d69cc854c7692805684ff3111e" - integrity sha512-dGRS0agJzu8ybo44pCIf3xBaPQN/65AIXNgK8+4gzKd5kbvlqyxryUYVLJv7fK98Seyd2hDZzVEHSWAh0Bt1Yw== - -"@scure/base@~1.1.0": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@scure/base/-/base-1.1.1.tgz#ebb651ee52ff84f420097055f4bf46cfba403938" - integrity sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA== - -"@scure/bip32@1.1.5": - version "1.1.5" - resolved "https://registry.yarnpkg.com/@scure/bip32/-/bip32-1.1.5.tgz#d2ccae16dcc2e75bc1d75f5ef3c66a338d1ba300" - integrity sha512-XyNh1rB0SkEqd3tXcXMi+Xe1fvg+kUIcoRIEujP1Jgv7DqW2r9lg3Ah0NkFaCs9sTkQAQA8kw7xiRXzENi9Rtw== - dependencies: - "@noble/hashes" "~1.2.0" - "@noble/secp256k1" "~1.7.0" - "@scure/base" "~1.1.0" - -"@scure/bip39@1.1.1": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@scure/bip39/-/bip39-1.1.1.tgz#b54557b2e86214319405db819c4b6a370cf340c5" - integrity sha512-t+wDck2rVkh65Hmv280fYdVdY25J9YeEUIgn2LG1WM6gxFkGzcksoDiUkWVpVp3Oex9xGC68JU2dSbUfwZ2jPg== - dependencies: - "@noble/hashes" "~1.2.0" - "@scure/base" "~1.1.0" - -"@sentry/core@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/core/-/core-5.30.0.tgz#6b203664f69e75106ee8b5a2fe1d717379b331f3" - integrity sha512-TmfrII8w1PQZSZgPpUESqjB+jC6MvZJZdLtE/0hZ+SrnKhW3x5WlYLvTXZpcWePYBku7rl2wn1RZu6uT0qCTeg== - dependencies: - "@sentry/hub" "5.30.0" - "@sentry/minimal" "5.30.0" - "@sentry/types" "5.30.0" - "@sentry/utils" "5.30.0" - tslib "^1.9.3" - -"@sentry/hub@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/hub/-/hub-5.30.0.tgz#2453be9b9cb903404366e198bd30c7ca74cdc100" - integrity sha512-2tYrGnzb1gKz2EkMDQcfLrDTvmGcQPuWxLnJKXJvYTQDGLlEvi2tWz1VIHjunmOvJrB5aIQLhm+dcMRwFZDCqQ== - dependencies: - "@sentry/types" "5.30.0" - "@sentry/utils" "5.30.0" - tslib "^1.9.3" - -"@sentry/minimal@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/minimal/-/minimal-5.30.0.tgz#ce3d3a6a273428e0084adcb800bc12e72d34637b" - integrity sha512-BwWb/owZKtkDX+Sc4zCSTNcvZUq7YcH3uAVlmh/gtR9rmUvbzAA3ewLuB3myi4wWRAMEtny6+J/FN/x+2wn9Xw== - dependencies: - "@sentry/hub" "5.30.0" - "@sentry/types" "5.30.0" - tslib "^1.9.3" - -"@sentry/node@^5.18.1": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/node/-/node-5.30.0.tgz#4ca479e799b1021285d7fe12ac0858951c11cd48" - integrity sha512-Br5oyVBF0fZo6ZS9bxbJZG4ApAjRqAnqFFurMVJJdunNb80brh7a5Qva2kjhm+U6r9NJAB5OmDyPkA1Qnt+QVg== - dependencies: - "@sentry/core" "5.30.0" - "@sentry/hub" "5.30.0" - "@sentry/tracing" "5.30.0" - "@sentry/types" "5.30.0" - "@sentry/utils" "5.30.0" - cookie "^0.4.1" - https-proxy-agent "^5.0.0" - lru_map "^0.3.3" - tslib "^1.9.3" - -"@sentry/tracing@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/tracing/-/tracing-5.30.0.tgz#501d21f00c3f3be7f7635d8710da70d9419d4e1f" - integrity sha512-dUFowCr0AIMwiLD7Fs314Mdzcug+gBVo/+NCMyDw8tFxJkwWAKl7Qa2OZxLQ0ZHjakcj1hNKfCQJ9rhyfOl4Aw== - dependencies: - "@sentry/hub" "5.30.0" - "@sentry/minimal" "5.30.0" - "@sentry/types" "5.30.0" - "@sentry/utils" "5.30.0" - tslib "^1.9.3" - -"@sentry/types@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/types/-/types-5.30.0.tgz#19709bbe12a1a0115bc790b8942917da5636f402" - integrity sha512-R8xOqlSTZ+htqrfteCWU5Nk0CDN5ApUTvrlvBuiH1DyP6czDZ4ktbZB0hAgBlVcK0U+qpD3ag3Tqqpa5Q67rPw== - -"@sentry/utils@5.30.0": - version "5.30.0" - resolved "https://registry.yarnpkg.com/@sentry/utils/-/utils-5.30.0.tgz#9a5bd7ccff85ccfe7856d493bffa64cabc41e980" - integrity sha512-zaYmoH0NWWtvnJjC9/CBseXMtKHm/tm40sz3YfJRxeQjyzRqNQPgivpd9R/oDJCYj999mzdW382p/qi2ypjLww== - dependencies: - "@sentry/types" "5.30.0" - tslib "^1.9.3" - -"@solidity-parser/parser@^0.14.0": - version "0.14.5" - resolved "https://registry.yarnpkg.com/@solidity-parser/parser/-/parser-0.14.5.tgz#87bc3cc7b068e08195c219c91cd8ddff5ef1a804" - integrity sha512-6dKnHZn7fg/iQATVEzqyUOyEidbn05q7YA2mQ9hC0MMXhhV3/JrsxmFSYZAcr7j1yUP700LLhTruvJ3MiQmjJg== - dependencies: - antlr4ts "^0.5.0-alpha.4" - -"@solidity-parser/parser@^0.16.0": - version "0.16.1" - resolved "https://registry.yarnpkg.com/@solidity-parser/parser/-/parser-0.16.1.tgz#f7c8a686974e1536da0105466c4db6727311253c" - integrity sha512-PdhRFNhbTtu3x8Axm0uYpqOy/lODYQK+MlYSgqIsq2L8SFYEHJPHNUiOTAJbDGzNjjr1/n9AcIayxafR/fWmYw== - dependencies: - antlr4ts "^0.5.0-alpha.4" - -"@solidstate/hardhat-4byte-uploader@^1.1.0": - version "1.1.0" - resolved "https://registry.yarnpkg.com/@solidstate/hardhat-4byte-uploader/-/hardhat-4byte-uploader-1.1.0.tgz#de1b9964827c1caeb516f048855c8a4082fd98fc" - integrity sha512-OCyBrPqtLoC7/WPlq7c9fosEOKgAT8jqRHCy/fJ8cK1DSQgYymcgC9g619Je9XjaLKPFgamRgt/HuTpTQnAFdQ== - dependencies: - axios "^0.24.0" - -"@tsconfig/node10@^1.0.7": - version "1.0.9" - resolved "https://registry.yarnpkg.com/@tsconfig/node10/-/node10-1.0.9.tgz#df4907fc07a886922637b15e02d4cebc4c0021b2" - integrity sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA== - -"@tsconfig/node12@^1.0.7": - version "1.0.11" - resolved "https://registry.yarnpkg.com/@tsconfig/node12/-/node12-1.0.11.tgz#ee3def1f27d9ed66dac6e46a295cffb0152e058d" - integrity sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag== - -"@tsconfig/node14@^1.0.0": - version "1.0.3" - resolved "https://registry.yarnpkg.com/@tsconfig/node14/-/node14-1.0.3.tgz#e4386316284f00b98435bf40f72f75a09dabf6c1" - integrity sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow== - -"@tsconfig/node16@^1.0.2": - version "1.0.4" - resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.4.tgz#0b92dcc0cc1c81f6f306a381f28e31b1a56536e9" - integrity sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA== - -"@typechain/ethers-v5@^8.0.5": - version "8.0.5" - resolved "https://registry.yarnpkg.com/@typechain/ethers-v5/-/ethers-v5-8.0.5.tgz#d469420e9a73deb7fa076cde9edb45d713dd1b8c" - integrity sha512-ntpj4cS3v4WlDu+hSKSyj9A3o1tKtWC30RX1gobeYymZColeJiUemC1Kgfa0MWGmInm5CKxoHVhEvYVgPOZn1A== - dependencies: - lodash "^4.17.15" - ts-essentials "^7.0.1" - -"@typechain/hardhat@^3.0.0": - version "3.1.0" - resolved "https://registry.yarnpkg.com/@typechain/hardhat/-/hardhat-3.1.0.tgz#88bd9e9d55e30fbece6fbb34c03ecd40a8b2013a" - integrity sha512-C6Be6l+vTpao19PvMH2CB/lhL1TRLkhdPkvQCF/zqkY1e+0iqY2Bb9Jd3PTt6I8QvMm89ZDerrCJC9927ZHmlg== - dependencies: - fs-extra "^9.1.0" - -"@types/bn.js@^4.11.3": - version "4.11.6" - resolved "https://registry.yarnpkg.com/@types/bn.js/-/bn.js-4.11.6.tgz#c306c70d9358aaea33cd4eda092a742b9505967c" - integrity sha512-pqr857jrp2kPuO9uRjZ3PwnJTjoQy+fcdxvBTvHm6dkmEL9q+hDD/2j/0ELOBPtPnS8LjCX0gI9nbl8lVkadpg== - dependencies: - "@types/node" "*" - -"@types/bn.js@^5.1.0": - version "5.1.1" - resolved "https://registry.yarnpkg.com/@types/bn.js/-/bn.js-5.1.1.tgz#b51e1b55920a4ca26e9285ff79936bbdec910682" - integrity sha512-qNrYbZqMx0uJAfKnKclPh+dTwK33KfLHYqtyODwd5HnXOjnkhc4qgn3BrK6RWyGZm5+sIFE7Q7Vz6QQtJB7w7g== - dependencies: - "@types/node" "*" - -"@types/chai-as-promised@^7.1.3": - version "7.1.5" - resolved "https://registry.yarnpkg.com/@types/chai-as-promised/-/chai-as-promised-7.1.5.tgz#6e016811f6c7a64f2eed823191c3a6955094e255" - integrity sha512-jStwss93SITGBwt/niYrkf2C+/1KTeZCZl1LaeezTlqppAKeoQC7jxyqYuP72sxBGKCIbw7oHgbYssIRzT5FCQ== - dependencies: - "@types/chai" "*" - -"@types/chai@*", "@types/chai@^4.3.0": - version "4.3.5" - resolved "https://registry.yarnpkg.com/@types/chai/-/chai-4.3.5.tgz#ae69bcbb1bebb68c4ac0b11e9d8ed04526b3562b" - integrity sha512-mEo1sAde+UCE6b2hxn332f1g1E8WfYRu6p5SvTKr2ZKC1f7gFJXk4h5PyGP9Dt6gCaG8y8XhwnXWC6Iy2cmBng== - -"@types/concat-stream@^1.6.0": - version "1.6.1" - resolved "https://registry.yarnpkg.com/@types/concat-stream/-/concat-stream-1.6.1.tgz#24bcfc101ecf68e886aaedce60dfd74b632a1b74" - integrity sha512-eHE4cQPoj6ngxBZMvVf6Hw7Mh4jMW4U9lpGmS5GBPB9RYxlFg+CHaVN7ErNY4W9XfLIEn20b4VDYaIrbq0q4uA== - dependencies: - "@types/node" "*" - -"@types/form-data@0.0.33": - version "0.0.33" - resolved "https://registry.yarnpkg.com/@types/form-data/-/form-data-0.0.33.tgz#c9ac85b2a5fd18435b8c85d9ecb50e6d6c893ff8" - integrity sha512-8BSvG1kGm83cyJITQMZSulnl6QV8jqAGreJsc5tPu1Jq0vTSOiY/k24Wx82JRpWwZSqrala6sd5rWi6aNXvqcw== - dependencies: - "@types/node" "*" - -"@types/fs-extra@11.0.1": - version "11.0.1" - resolved "https://registry.yarnpkg.com/@types/fs-extra/-/fs-extra-11.0.1.tgz#f542ec47810532a8a252127e6e105f487e0a6ea5" - integrity sha512-MxObHvNl4A69ofaTRU8DFqvgzzv8s9yRtaPPm5gud9HDNvpB3GPQFvNuTWAI59B9huVGV5jXYJwbCsmBsOGYWA== - dependencies: - "@types/jsonfile" "*" - "@types/node" "*" - -"@types/jsonfile@*": - version "6.1.1" - resolved "https://registry.yarnpkg.com/@types/jsonfile/-/jsonfile-6.1.1.tgz#ac84e9aefa74a2425a0fb3012bdea44f58970f1b" - integrity sha512-GSgiRCVeapDN+3pqA35IkQwasaCh/0YFH5dEF6S88iDvEn901DjOeH3/QPY+XYP1DFzDZPvIvfeEgk+7br5png== - dependencies: - "@types/node" "*" - -"@types/lru-cache@^5.1.0": - version "5.1.1" - resolved "https://registry.yarnpkg.com/@types/lru-cache/-/lru-cache-5.1.1.tgz#c48c2e27b65d2a153b19bfc1a317e30872e01eef" - integrity sha512-ssE3Vlrys7sdIzs5LOxCzTVMsU7i9oa/IaW92wF32JFb3CVczqOkru2xspuKczHEbG3nvmPY7IFqVmGGHdNbYw== - -"@types/mocha@^9.0.0": - version "9.1.1" - resolved "https://registry.yarnpkg.com/@types/mocha/-/mocha-9.1.1.tgz#e7c4f1001eefa4b8afbd1eee27a237fee3bf29c4" - integrity sha512-Z61JK7DKDtdKTWwLeElSEBcWGRLY8g95ic5FoQqI9CMx0ns/Ghep3B4DfcEimiKMvtamNVULVNKEsiwV3aQmXw== - -"@types/node@*": - version "20.4.5" - resolved "https://registry.yarnpkg.com/@types/node/-/node-20.4.5.tgz#9dc0a5cb1ccce4f7a731660935ab70b9c00a5d69" - integrity sha512-rt40Nk13II9JwQBdeYqmbn2Q6IVTA5uPhvSO+JVqdXw/6/4glI6oR9ezty/A9Hg5u7JH4OmYmuQ+XvjKm0Datg== - -"@types/node@^10.0.3": - version "10.17.60" - resolved "https://registry.yarnpkg.com/@types/node/-/node-10.17.60.tgz#35f3d6213daed95da7f0f73e75bcc6980e90597b" - integrity sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw== - -"@types/node@^17.0.0": - version "17.0.45" - resolved "https://registry.yarnpkg.com/@types/node/-/node-17.0.45.tgz#2c0fafd78705e7a18b7906b5201a522719dc5190" - integrity sha512-w+tIMs3rq2afQdsPJlODhoUEKzFP1ayaoyl1CcnwtIlsVe7K7bA1NGm4s3PraqTLlXnbIN84zuBlxBWo1u9BLw== - -"@types/node@^8.0.0": - version "8.10.66" - resolved "https://registry.yarnpkg.com/@types/node/-/node-8.10.66.tgz#dd035d409df322acc83dff62a602f12a5783bbb3" - integrity sha512-tktOkFUA4kXx2hhhrB8bIFb5TbwzS4uOhKEmwiD+NoiL0qtP2OQ9mFldbgD4dV1djrlBYP6eBuQZiWjuHUpqFw== - -"@types/pbkdf2@^3.0.0": - version "3.1.0" - resolved "https://registry.yarnpkg.com/@types/pbkdf2/-/pbkdf2-3.1.0.tgz#039a0e9b67da0cdc4ee5dab865caa6b267bb66b1" - integrity sha512-Cf63Rv7jCQ0LaL8tNXmEyqTHuIJxRdlS5vMh1mj5voN4+QFhVZnlZruezqpWYDiJ8UTzhP0VmeLXCmBk66YrMQ== - dependencies: - "@types/node" "*" - -"@types/prettier@^2.1.1": - version "2.7.3" - resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.7.3.tgz#3e51a17e291d01d17d3fc61422015a933af7a08f" - integrity sha512-+68kP9yzs4LMp7VNh8gdzMSPZFL44MLGqiHWvttYJe+6qnuVr4Ek9wSBQoveqY/r+LwjCcU29kNVkidwim+kYA== - -"@types/qs@^6.2.31", "@types/qs@^6.9.7": - version "6.9.7" - resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.7.tgz#63bb7d067db107cc1e457c303bc25d511febf6cb" - integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw== - -"@types/readable-stream@^2.3.13": - version "2.3.15" - resolved "https://registry.yarnpkg.com/@types/readable-stream/-/readable-stream-2.3.15.tgz#3d79c9ceb1b6a57d5f6e6976f489b9b5384321ae" - integrity sha512-oM5JSKQCcICF1wvGgmecmHldZ48OZamtMxcGGVICOJA8o8cahXC1zEVAif8iwoc5j8etxFaRFnf095+CDsuoFQ== - dependencies: - "@types/node" "*" - safe-buffer "~5.1.1" - -"@types/secp256k1@^4.0.1": - version "4.0.3" - resolved "https://registry.yarnpkg.com/@types/secp256k1/-/secp256k1-4.0.3.tgz#1b8e55d8e00f08ee7220b4d59a6abe89c37a901c" - integrity sha512-Da66lEIFeIz9ltsdMZcpQvmrmmoqrfju8pm1BH8WbYjZSwUgCwXLb9C+9XYogwBITnbsSaMdVPb2ekf7TV+03w== - dependencies: - "@types/node" "*" - -abort-controller@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" - integrity sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg== - dependencies: - event-target-shim "^5.0.0" - -abstract-level@^1.0.0, abstract-level@^1.0.2, abstract-level@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/abstract-level/-/abstract-level-1.0.3.tgz#78a67d3d84da55ee15201486ab44c09560070741" - integrity sha512-t6jv+xHy+VYwc4xqZMn2Pa9DjcdzvzZmQGRjTFc8spIbRGHgBrEKbPq+rYXc7CCo0lxgYvSgKVg9qZAhpVQSjA== - dependencies: - buffer "^6.0.3" - catering "^2.1.0" - is-buffer "^2.0.5" - level-supports "^4.0.0" - level-transcoder "^1.0.1" - module-error "^1.0.1" - queue-microtask "^1.2.3" - -acorn-walk@^8.1.1: - version "8.2.0" - resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" - integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== - -acorn@^8.4.1: - version "8.10.0" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.10.0.tgz#8be5b3907a67221a81ab23c7889c4c5526b62ec5" - integrity sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw== - -adm-zip@^0.4.16: - version "0.4.16" - resolved "https://registry.yarnpkg.com/adm-zip/-/adm-zip-0.4.16.tgz#cf4c508fdffab02c269cbc7f471a875f05570365" - integrity sha512-TFi4HBKSGfIKsK5YCkKaaFG2m4PEDyViZmEwof3MTIgzimHLto6muaHVpbrljdIvIrFZzEq/p4nafOeLcYegrg== - -aes-js@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/aes-js/-/aes-js-3.0.0.tgz#e21df10ad6c2053295bcbb8dab40b09dbea87e4d" - integrity sha512-H7wUZRn8WpTq9jocdxQ2c8x2sKo9ZVmzfRE13GiNJXfp7NcKYEdvl3vspKjXox6RIG2VtaRe4JFvxG4rqp2Zuw== - -agent-base@6: - version "6.0.2" - resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" - integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== - dependencies: - debug "4" - -aggregate-error@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" - integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== - dependencies: - clean-stack "^2.0.0" - indent-string "^4.0.0" - -ajv@^6.12.3, ajv@^6.12.6: - version "6.12.6" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" - integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== - dependencies: - fast-deep-equal "^3.1.1" - fast-json-stable-stringify "^2.0.0" - json-schema-traverse "^0.4.1" - uri-js "^4.2.2" - -ajv@^8.0.1: - version "8.12.0" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" - integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== - dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" - -ansi-colors@3.2.3: - version "3.2.3" - resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-3.2.3.tgz#57d35b8686e851e2cc04c403f1c00203976a1813" - integrity sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw== - -ansi-colors@4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" - integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== - -ansi-colors@^4.1.1: - version "4.1.3" - resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.3.tgz#37611340eb2243e70cc604cad35d63270d48781b" - integrity sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw== - -ansi-escapes@^4.3.0: - version "4.3.2" - resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" - integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== - dependencies: - type-fest "^0.21.3" - -ansi-regex@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.1.tgz#123d6479e92ad45ad897d4054e3c7ca7db4944e1" - integrity sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw== - -ansi-regex@^4.1.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.1.tgz#164daac87ab2d6f6db3a29875e2d1766582dabed" - integrity sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g== - -ansi-regex@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" - integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== - -ansi-regex@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-6.0.1.tgz#3183e38fae9a65d7cb5e53945cd5897d0260a06a" - integrity sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA== - -ansi-styles@^3.2.0, ansi-styles@^3.2.1: - version "3.2.1" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" - integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== - dependencies: - color-convert "^1.9.0" - -ansi-styles@^4.0.0, ansi-styles@^4.1.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" - integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== - dependencies: - color-convert "^2.0.1" - -ansi-styles@^6.0.0: - version "6.2.1" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.2.1.tgz#0e62320cf99c21afff3b3012192546aacbfb05c5" - integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug== - -antlr4@^4.11.0: - version "4.13.0" - resolved "https://registry.yarnpkg.com/antlr4/-/antlr4-4.13.0.tgz#25c0b17f0d9216de114303d38bafd6f181d5447f" - integrity sha512-zooUbt+UscjnWyOrsuY/tVFL4rwrAGwOivpQmvmUDE22hy/lUA467Rc1rcixyRwcRUIXFYBwv7+dClDSHdmmew== - -antlr4ts@^0.5.0-alpha.4: - version "0.5.0-alpha.4" - resolved "https://registry.yarnpkg.com/antlr4ts/-/antlr4ts-0.5.0-alpha.4.tgz#71702865a87478ed0b40c0709f422cf14d51652a" - integrity sha512-WPQDt1B74OfPv/IMS2ekXAKkTZIHl88uMetg6q3OTqgFxZ/dxDXI0EWLyZid/1Pe6hTftyg5N7gel5wNAGxXyQ== - -anymatch@~3.1.1, anymatch@~3.1.2: - version "3.1.3" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e" - integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw== - dependencies: - normalize-path "^3.0.0" - picomatch "^2.0.4" - -arg@^4.1.0: - version "4.1.3" - resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" - integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== - -argparse@^1.0.7: - version "1.0.10" - resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" - integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== - dependencies: - sprintf-js "~1.0.2" - -argparse@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" - integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== - -array-back@^3.0.1, array-back@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/array-back/-/array-back-3.1.0.tgz#b8859d7a508871c9a7b2cf42f99428f65e96bfb0" - integrity sha512-TkuxA4UCOvxuDK6NZYXCalszEzj+TLszyASooky+i742l9TqsOdYCMJJupxRic61hwquNtppB3hgcuq9SVSH1Q== - -array-back@^4.0.1, array-back@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/array-back/-/array-back-4.0.2.tgz#8004e999a6274586beeb27342168652fdb89fa1e" - integrity sha512-NbdMezxqf94cnNfWLL7V/im0Ub+Anbb0IoZhvzie8+4HJ4nMQuzHuy49FkGYCJK2yAloZ3meiB6AVMClbrI1vg== - -array-buffer-byte-length@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz#fabe8bc193fea865f317fe7807085ee0dee5aead" - integrity sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A== - dependencies: - call-bind "^1.0.2" - is-array-buffer "^3.0.1" - -array-union@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" - integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== - -array-uniq@1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/array-uniq/-/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6" - integrity sha512-MNha4BWQ6JbwhFhj03YK552f7cb3AzoE8SzeljgChvL1dl3IcvggXVz1DilzySZkCja+CXuZbdW7yATchWn8/Q== - -array.prototype.reduce@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/array.prototype.reduce/-/array.prototype.reduce-1.0.5.tgz#6b20b0daa9d9734dd6bc7ea66b5bbce395471eac" - integrity sha512-kDdugMl7id9COE8R7MHF5jWk7Dqt/fs4Pv+JXoICnYwqpjjjbUurz6w5fT5IG6brLdJhv6/VoHB0H7oyIBXd+Q== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" - es-array-method-boxes-properly "^1.0.0" - is-string "^1.0.7" - -arraybuffer.prototype.slice@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.1.tgz#9b5ea3868a6eebc30273da577eb888381c0044bb" - integrity sha512-09x0ZWFEjj4WD8PDbykUwo3t9arLn8NIzmmYEJFpYekOAQjpkGSyrQhNoRTcwwcFRu+ycWF78QZ63oWTqSjBcw== - dependencies: - array-buffer-byte-length "^1.0.0" - call-bind "^1.0.2" - define-properties "^1.2.0" - get-intrinsic "^1.2.1" - is-array-buffer "^3.0.2" - is-shared-array-buffer "^1.0.2" - -asap@~2.0.6: - version "2.0.6" - resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.6.tgz#e50347611d7e690943208bbdafebcbc2fb866d46" - integrity sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA== - -asn1@~0.2.3: - version "0.2.6" - resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.6.tgz#0d3a7bb6e64e02a90c0303b31f292868ea09a08d" - integrity sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ== - dependencies: - safer-buffer "~2.1.0" - -assert-plus@1.0.0, assert-plus@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" - integrity sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw== - -assertion-error@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-1.1.0.tgz#e60b6b0e8f301bd97e5375215bda406c85118c0b" - integrity sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw== - -ast-parents@^0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/ast-parents/-/ast-parents-0.0.1.tgz#508fd0f05d0c48775d9eccda2e174423261e8dd3" - integrity sha512-XHusKxKz3zoYk1ic8Un640joHbFMhbqneyoZfoKnEGtf2ey9Uh/IdpcQplODdO/kENaMIWsD0nJm4+wX3UNLHA== - -astral-regex@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" - integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== - -asynckit@^0.4.0: - version "0.4.0" - resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" - integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== - -at-least-node@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" - integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== - -available-typed-arrays@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz#92f95616501069d07d10edb2fc37d3e1c65123b7" - integrity sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw== - -aws-sign2@~0.7.0: - version "0.7.0" - resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" - integrity sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA== - -aws4@^1.8.0: - version "1.12.0" - resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.12.0.tgz#ce1c9d143389679e253b314241ea9aa5cec980d3" - integrity sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg== - -axios@^0.21.1: - version "0.21.4" - resolved "https://registry.yarnpkg.com/axios/-/axios-0.21.4.tgz#c67b90dc0568e5c1cf2b0b858c43ba28e2eda575" - integrity sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg== - dependencies: - follow-redirects "^1.14.0" - -axios@^0.24.0: - version "0.24.0" - resolved "https://registry.yarnpkg.com/axios/-/axios-0.24.0.tgz#804e6fa1e4b9c5288501dd9dff56a7a0940d20d6" - integrity sha512-Q6cWsys88HoPgAaFAVUb0WpPk0O8iTeisR9IMqy9G8AbO4NlpVknrnQS03zzF9PGAWgO3cgletO3VjV/P7VztA== - dependencies: - follow-redirects "^1.14.4" - -balanced-match@^1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" - integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== - -base-x@^3.0.2: - version "3.0.9" - resolved "https://registry.yarnpkg.com/base-x/-/base-x-3.0.9.tgz#6349aaabb58526332de9f60995e548a53fe21320" - integrity sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ== - dependencies: - safe-buffer "^5.0.1" - -base64-js@^1.3.1: - version "1.5.1" - resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" - integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== - -bcrypt-pbkdf@^1.0.0: - version "1.0.2" - resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" - integrity sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w== - dependencies: - tweetnacl "^0.14.3" - -bech32@1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/bech32/-/bech32-1.1.4.tgz#e38c9f37bf179b8eb16ae3a772b40c356d4832e9" - integrity sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ== - -bigint-crypto-utils@^3.0.23: - version "3.3.0" - resolved "https://registry.yarnpkg.com/bigint-crypto-utils/-/bigint-crypto-utils-3.3.0.tgz#72ad00ae91062cf07f2b1def9594006c279c1d77" - integrity sha512-jOTSb+drvEDxEq6OuUybOAv/xxoh3cuYRUIPyu8sSHQNKM303UQ2R1DAo45o1AkcIXw6fzbaFI1+xGGdaXs2lg== - -binary-extensions@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" - integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== - -blakejs@^1.1.0: - version "1.2.1" - resolved "https://registry.yarnpkg.com/blakejs/-/blakejs-1.2.1.tgz#5057e4206eadb4a97f7c0b6e197a505042fc3814" - integrity sha512-QXUSXI3QVc/gJME0dBpXrag1kbzOqCjCX8/b54ntNyW6sjtoqxqRk3LTmXzaJoh71zMsDCjM+47jS7XiwN/+fQ== - -bn.js@^4.11.0, bn.js@^4.11.8, bn.js@^4.11.9: - version "4.12.0" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" - integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== - -bn.js@^5.2.0, bn.js@^5.2.1: - version "5.2.1" - resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-5.2.1.tgz#0bc527a6a0d18d0aa8d5b0538ce4a77dccfa7b70" - integrity sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ== - -brace-expansion@^1.1.7: - version "1.1.11" - resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" - integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== - dependencies: - balanced-match "^1.0.0" - concat-map "0.0.1" - -brace-expansion@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" - integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== - dependencies: - balanced-match "^1.0.0" - -braces@^3.0.2, braces@~3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" - integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== - dependencies: - fill-range "^7.0.1" - -brorand@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f" - integrity sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w== - -browser-level@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/browser-level/-/browser-level-1.0.1.tgz#36e8c3183d0fe1c405239792faaab5f315871011" - integrity sha512-XECYKJ+Dbzw0lbydyQuJzwNXtOpbMSq737qxJN11sIRTErOMShvDpbzTlgju7orJKvx4epULolZAuJGLzCmWRQ== - dependencies: - abstract-level "^1.0.2" - catering "^2.1.1" - module-error "^1.0.2" - run-parallel-limit "^1.1.0" - -browser-stdout@1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/browser-stdout/-/browser-stdout-1.3.1.tgz#baa559ee14ced73452229bad7326467c61fabd60" - integrity sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw== - -browserify-aes@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.2.0.tgz#326734642f403dabc3003209853bb70ad428ef48" - integrity sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA== - dependencies: - buffer-xor "^1.0.3" - cipher-base "^1.0.0" - create-hash "^1.1.0" - evp_bytestokey "^1.0.3" - inherits "^2.0.1" - safe-buffer "^5.0.1" - -bs58@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/bs58/-/bs58-4.0.1.tgz#be161e76c354f6f788ae4071f63f34e8c4f0a42a" - integrity sha512-Ok3Wdf5vOIlBrgCvTq96gBkJw+JUEzdBgyaza5HLtPm7yTHkjRy8+JzNyHF7BHa0bNWOQIp3m5YF0nnFcOIKLw== - dependencies: - base-x "^3.0.2" - -bs58check@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/bs58check/-/bs58check-2.1.2.tgz#53b018291228d82a5aa08e7d796fdafda54aebfc" - integrity sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA== - dependencies: - bs58 "^4.0.0" - create-hash "^1.1.0" - safe-buffer "^5.1.2" - -buffer-from@^1.0.0: - version "1.1.2" - resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" - integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== - -buffer-xor@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9" - integrity sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ== - -buffer@^6.0.3: - version "6.0.3" - resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" - integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== - dependencies: - base64-js "^1.3.1" - ieee754 "^1.2.1" - -busboy@^1.6.0: - version "1.6.0" - resolved "https://registry.yarnpkg.com/busboy/-/busboy-1.6.0.tgz#966ea36a9502e43cdb9146962523b92f531f6893" - integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== - dependencies: - streamsearch "^1.1.0" - -bytes@3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" - integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== - -call-bind@^1.0.0, call-bind@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" - integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== - dependencies: - function-bind "^1.1.1" - get-intrinsic "^1.0.2" - -callsites@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" - integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== - -camelcase@^5.0.0: - version "5.3.1" - resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" - integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== - -camelcase@^6.0.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.3.0.tgz#5685b95eb209ac9c0c177467778c9c84df58ba9a" - integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== - -case@^1.6.3: - version "1.6.3" - resolved "https://registry.yarnpkg.com/case/-/case-1.6.3.tgz#0a4386e3e9825351ca2e6216c60467ff5f1ea1c9" - integrity sha512-mzDSXIPaFwVDvZAHqZ9VlbyF4yyXRuX6IvB06WvPYkqJVO24kX1PPhv9bfpKNFZyxYFmmgo03HUiD8iklmJYRQ== - -caseless@^0.12.0, caseless@~0.12.0: - version "0.12.0" - resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" - integrity sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw== - -catering@^2.1.0, catering@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/catering/-/catering-2.1.1.tgz#66acba06ed5ee28d5286133982a927de9a04b510" - integrity sha512-K7Qy8O9p76sL3/3m7/zLKbRkyOlSZAgzEaLhyj2mXS8PsCud2Eo4hAb8aLtZqHh0QGqLcb9dlJSu6lHRVENm1w== - -chai-as-promised@^7.1.1: - version "7.1.1" - resolved "https://registry.yarnpkg.com/chai-as-promised/-/chai-as-promised-7.1.1.tgz#08645d825deb8696ee61725dbf590c012eb00ca0" - integrity sha512-azL6xMoi+uxu6z4rhWQ1jbdUhOMhis2PvscD/xjLqNMkv3BPPp2JyyuTHOrf9BOosGpNQ11v6BKv/g57RXbiaA== - dependencies: - check-error "^1.0.2" - -chai@^4.3.4: - version "4.3.7" - resolved "https://registry.yarnpkg.com/chai/-/chai-4.3.7.tgz#ec63f6df01829088e8bf55fca839bcd464a8ec51" - integrity sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A== - dependencies: - assertion-error "^1.1.0" - check-error "^1.0.2" - deep-eql "^4.1.2" - get-func-name "^2.0.0" - loupe "^2.3.1" - pathval "^1.1.1" - type-detect "^4.0.5" - -chalk@5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-5.2.0.tgz#249623b7d66869c673699fb66d65723e54dfcfb3" - integrity sha512-ree3Gqw/nazQAPuJJEy+avdl7QfZMcUvmHIKgEZkGL+xOBzRvup5Hxo6LHuMceSxOabuJLJm5Yp/92R9eMmMvA== - -chalk@^2.0.0, chalk@^2.4.2: - version "2.4.2" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" - integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== - dependencies: - ansi-styles "^3.2.1" - escape-string-regexp "^1.0.5" - supports-color "^5.3.0" - -chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" - integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== - dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" - -"charenc@>= 0.0.1": - version "0.0.2" - resolved "https://registry.yarnpkg.com/charenc/-/charenc-0.0.2.tgz#c0a1d2f3a7092e03774bfa83f14c0fc5790a8667" - integrity sha512-yrLQ/yVUFXkzg7EDQsPieE/53+0RlaWTs+wBrvW36cyilJ2SaDWfl4Yj7MtLTXleV9uEKefbAGUPv2/iWSooRA== - -check-error@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.2.tgz#574d312edd88bb5dd8912e9286dd6c0aed4aac82" - integrity sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA== - -chokidar@3.3.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.3.0.tgz#12c0714668c55800f659e262d4962a97faf554a6" - integrity sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A== - dependencies: - anymatch "~3.1.1" - braces "~3.0.2" - glob-parent "~5.1.0" - is-binary-path "~2.1.0" - is-glob "~4.0.1" - normalize-path "~3.0.0" - readdirp "~3.2.0" - optionalDependencies: - fsevents "~2.1.1" - -chokidar@3.5.3, chokidar@^3.4.0, chokidar@^3.5.2: - version "3.5.3" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" - integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== - dependencies: - anymatch "~3.1.2" - braces "~3.0.2" - glob-parent "~5.1.2" - is-binary-path "~2.1.0" - is-glob "~4.0.1" - normalize-path "~3.0.0" - readdirp "~3.6.0" - optionalDependencies: - fsevents "~2.3.2" - -ci-info@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" - integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== - -cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de" - integrity sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q== - dependencies: - inherits "^2.0.1" - safe-buffer "^5.0.1" - -classic-level@^1.2.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/classic-level/-/classic-level-1.3.0.tgz#5e36680e01dc6b271775c093f2150844c5edd5c8" - integrity sha512-iwFAJQYtqRTRM0F6L8h4JCt00ZSGdOyqh7yVrhhjrOpFhmBjNlRUey64MCiyo6UmQHMJ+No3c81nujPv+n9yrg== - dependencies: - abstract-level "^1.0.2" - catering "^2.1.0" - module-error "^1.0.1" - napi-macros "^2.2.2" - node-gyp-build "^4.3.0" - -clean-stack@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" - integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== - -clean-stack@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-3.0.1.tgz#155bf0b2221bf5f4fba89528d24c5953f17fe3a8" - integrity sha512-lR9wNiMRcVQjSB3a7xXGLuz4cr4wJuuXlaAEbRutGowQTmlp7R72/DOgN21e8jdwblMWl9UOJMJXarX94pzKdg== - dependencies: - escape-string-regexp "4.0.0" - -cli-cursor@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-3.1.0.tgz#264305a7ae490d1d03bf0c9ba7c925d1753af307" - integrity sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw== - dependencies: - restore-cursor "^3.1.0" - -cli-table3@^0.5.0: - version "0.5.1" - resolved "https://registry.yarnpkg.com/cli-table3/-/cli-table3-0.5.1.tgz#0252372d94dfc40dbd8df06005f48f31f656f202" - integrity sha512-7Qg2Jrep1S/+Q3EceiZtQcDPWxhAvBw+ERf1162v4sikJrvojMHFqXt8QIVha8UlH9rgU0BeWPytZ9/TzYqlUw== - dependencies: - object-assign "^4.1.0" - string-width "^2.1.1" - optionalDependencies: - colors "^1.1.2" - -cli-table3@^0.6.0: - version "0.6.3" - resolved "https://registry.yarnpkg.com/cli-table3/-/cli-table3-0.6.3.tgz#61ab765aac156b52f222954ffc607a6f01dbeeb2" - integrity sha512-w5Jac5SykAeZJKntOxJCrm63Eg5/4dhMWIcuTbo9rpE+brgaSZo0RuNJZeOyMgsUdhDeojvgyQLmjI+K50ZGyg== - dependencies: - string-width "^4.2.0" - optionalDependencies: - "@colors/colors" "1.5.0" - -cli-truncate@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-2.1.0.tgz#c39e28bf05edcde5be3b98992a22deed5a2b93c7" - integrity sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg== - dependencies: - slice-ansi "^3.0.0" - string-width "^4.2.0" - -cli-truncate@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-3.1.0.tgz#3f23ab12535e3d73e839bb43e73c9de487db1389" - integrity sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA== - dependencies: - slice-ansi "^5.0.0" - string-width "^5.0.0" - -cliui@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-5.0.0.tgz#deefcfdb2e800784aa34f46fa08e06851c7bbbc5" - integrity sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA== - dependencies: - string-width "^3.1.0" - strip-ansi "^5.2.0" - wrap-ansi "^5.1.0" - -cliui@^7.0.2: - version "7.0.4" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" - integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== - dependencies: - string-width "^4.2.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" - -color-convert@^1.9.0: - version "1.9.3" - resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" - integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== - dependencies: - color-name "1.1.3" - -color-convert@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" - integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== - dependencies: - color-name "~1.1.4" - -color-name@1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" - integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== - -color-name@~1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" - integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== - -colorette@^2.0.19: - version "2.0.20" - resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" - integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== - -colors@1.4.0, colors@^1.1.2: - version "1.4.0" - resolved "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78" - integrity sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA== - -combined-stream@^1.0.6, combined-stream@^1.0.8, combined-stream@~1.0.6: - version "1.0.8" - resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" - integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== - dependencies: - delayed-stream "~1.0.0" - -command-exists@^1.2.8: - version "1.2.9" - resolved "https://registry.yarnpkg.com/command-exists/-/command-exists-1.2.9.tgz#c50725af3808c8ab0260fd60b01fbfa25b954f69" - integrity sha512-LTQ/SGc+s0Xc0Fu5WaKnR0YiygZkm9eKFvyS+fRsU7/ZWFF8ykFM6Pc9aCVf1+xasOOZpO3BAVgVrKvsqKHV7w== - -command-line-args@^5.1.1: - version "5.2.1" - resolved "https://registry.yarnpkg.com/command-line-args/-/command-line-args-5.2.1.tgz#c44c32e437a57d7c51157696893c5909e9cec42e" - integrity sha512-H4UfQhZyakIjC74I9d34fGYDwk3XpSr17QhEd0Q3I9Xq1CETHo4Hcuo87WyWHpAF1aSLjLRf5lD9ZGX2qStUvg== - dependencies: - array-back "^3.1.0" - find-replace "^3.0.0" - lodash.camelcase "^4.3.0" - typical "^4.0.0" - -command-line-usage@^6.1.0: - version "6.1.3" - resolved "https://registry.yarnpkg.com/command-line-usage/-/command-line-usage-6.1.3.tgz#428fa5acde6a838779dfa30e44686f4b6761d957" - integrity sha512-sH5ZSPr+7UStsloltmDh7Ce5fb8XPlHyoPzTpyyMuYCtervL65+ubVZ6Q61cFtFl62UyJlc8/JwERRbAFPUqgw== - dependencies: - array-back "^4.0.2" - chalk "^2.4.2" - table-layout "^1.0.2" - typical "^5.2.0" - -commander@3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/commander/-/commander-3.0.2.tgz#6837c3fb677ad9933d1cfba42dd14d5117d6b39e" - integrity sha512-Gar0ASD4BDyKC4hl4DwHqDrmvjoxWKZigVnAbn5H1owvm4CxCPdb0HQDehwNYMJpla5+M2tPmPARzhtYuwpHow== - -commander@^10.0.0: - version "10.0.1" - resolved "https://registry.yarnpkg.com/commander/-/commander-10.0.1.tgz#881ee46b4f77d1c1dccc5823433aa39b022cbe06" - integrity sha512-y4Mg2tXshplEbSGzx7amzPwKKOCGuoSRP/CjEdwwk0FOGlUbq6lKuoyDZTNZkmxHdJtp54hdfY/JUrdL7Xfdug== - -commander@^8.1.0: - version "8.3.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66" - integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww== - -concat-map@0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" - integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== - -concat-stream@^1.6.0, concat-stream@^1.6.2: - version "1.6.2" - resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz#904bdf194cd3122fc675c77fc4ac3d4ff0fd1a34" - integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== - dependencies: - buffer-from "^1.0.0" - inherits "^2.0.3" - readable-stream "^2.2.2" - typedarray "^0.0.6" - -console-table-printer@^2.9.0: - version "2.11.2" - resolved "https://registry.yarnpkg.com/console-table-printer/-/console-table-printer-2.11.2.tgz#549757033a7e3cde7e26e030038c9392ce600ee5" - integrity sha512-uuUHie0sfPP542TKGzPFal0W1wo1beuKAqIZdaavcONx8OoqdnJRKjkinbRTOta4FaCa1RcIL+7mMJWX3pQGVg== - dependencies: - simple-wcswidth "^1.0.1" - -cookie@^0.4.1: - version "0.4.2" - resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.2.tgz#0e41f24de5ecf317947c82fc789e06a884824432" - integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== - -core-util-is@1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" - integrity sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ== - -core-util-is@~1.0.0: - version "1.0.3" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" - integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== - -cosmiconfig@^8.0.0: - version "8.2.0" - resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-8.2.0.tgz#f7d17c56a590856cd1e7cee98734dca272b0d8fd" - integrity sha512-3rTMnFJA1tCOPwRxtgF4wd7Ab2qvDbL8jX+3smjIbS4HlZBagTlpERbdN7iAbWlrfxE3M8c27kTwTawQ7st+OQ== - dependencies: - import-fresh "^3.2.1" - js-yaml "^4.1.0" - parse-json "^5.0.0" - path-type "^4.0.0" - -crc-32@^1.2.0: - version "1.2.2" - resolved "https://registry.yarnpkg.com/crc-32/-/crc-32-1.2.2.tgz#3cad35a934b8bf71f25ca524b6da51fb7eace2ff" - integrity sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ== - -create-hash@^1.1.0, create-hash@^1.1.2, create-hash@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.2.0.tgz#889078af11a63756bcfb59bd221996be3a9ef196" - integrity sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg== - dependencies: - cipher-base "^1.0.1" - inherits "^2.0.1" - md5.js "^1.3.4" - ripemd160 "^2.0.1" - sha.js "^2.4.0" - -create-hmac@^1.1.4, create-hmac@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.7.tgz#69170c78b3ab957147b2b8b04572e47ead2243ff" - integrity sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg== - dependencies: - cipher-base "^1.0.3" - create-hash "^1.1.0" - inherits "^2.0.1" - ripemd160 "^2.0.0" - safe-buffer "^5.0.1" - sha.js "^2.4.8" - -create-require@^1.1.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" - integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== - -cross-spawn@^7.0.3: - version "7.0.3" - resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" - integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== - dependencies: - path-key "^3.1.0" - shebang-command "^2.0.0" - which "^2.0.1" - -"crypt@>= 0.0.1": - version "0.0.2" - resolved "https://registry.yarnpkg.com/crypt/-/crypt-0.0.2.tgz#88d7ff7ec0dfb86f713dc87bbb42d044d3e6c41b" - integrity sha512-mCxBlsHFYh9C+HVpiEacem8FEBnMXgU9gy4zmNC+SXAZNB/1idgp/aulFJ4FgCi7GPEVbfyng092GqL2k2rmow== - -dashdash@^1.12.0: - version "1.14.1" - resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" - integrity sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g== - dependencies: - assert-plus "^1.0.0" - -debug@3.2.6: - version "3.2.6" - resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz#e83d17de16d8a7efb7717edbe5fb10135eee629b" - integrity sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ== - dependencies: - ms "^2.1.1" - -debug@4, debug@4.3.4, debug@^4.1.1, debug@^4.3.2, debug@^4.3.3, debug@^4.3.4: - version "4.3.4" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" - integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== - dependencies: - ms "2.1.2" - -decamelize@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" - integrity sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA== - -decamelize@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" - integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== - -deep-eql@^4.0.1, deep-eql@^4.1.2: - version "4.1.3" - resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-4.1.3.tgz#7c7775513092f7df98d8df9996dd085eb668cc6d" - integrity sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw== - dependencies: - type-detect "^4.0.0" - -deep-extend@~0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" - integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== - -define-properties@^1.1.2, define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.0.tgz#52988570670c9eacedd8064f4a990f2405849bd5" - integrity sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA== - dependencies: - has-property-descriptors "^1.0.0" - object-keys "^1.1.1" - -delayed-stream@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" - integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== - -depd@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" - integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== - -diff@3.5.0: - version "3.5.0" - resolved "https://registry.yarnpkg.com/diff/-/diff-3.5.0.tgz#800c0dd1e0a8bfbc95835c202ad220fe317e5a12" - integrity sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA== - -diff@5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/diff/-/diff-5.0.0.tgz#7ed6ad76d859d030787ec35855f5b1daf31d852b" - integrity sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w== - -diff@^4.0.1: - version "4.0.2" - resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" - integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== - -dir-glob@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" - integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== - dependencies: - path-type "^4.0.0" - -dotenv@^10.0.0: - version "10.0.0" - resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-10.0.0.tgz#3d4227b8fb95f81096cdd2b66653fb2c7085ba81" - integrity sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q== - -eastasianwidth@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/eastasianwidth/-/eastasianwidth-0.2.0.tgz#696ce2ec0aa0e6ea93a397ffcf24aa7840c827cb" - integrity sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA== - -ecc-jsbn@~0.1.1: - version "0.1.2" - resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" - integrity sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw== - dependencies: - jsbn "~0.1.0" - safer-buffer "^2.1.0" - -elliptic@6.5.4, elliptic@^6.5.2, elliptic@^6.5.4: - version "6.5.4" - resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.5.4.tgz#da37cebd31e79a1367e941b592ed1fbebd58abbb" - integrity sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ== - dependencies: - bn.js "^4.11.9" - brorand "^1.1.0" - hash.js "^1.0.0" - hmac-drbg "^1.0.1" - inherits "^2.0.4" - minimalistic-assert "^1.0.1" - minimalistic-crypto-utils "^1.0.1" - -emoji-regex@^7.0.1: - version "7.0.3" - resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" - integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== - -emoji-regex@^8.0.0: - version "8.0.0" - resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" - integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== - -emoji-regex@^9.2.2: - version "9.2.2" - resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" - integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== - -encode-utf8@^1.0.2: - version "1.0.3" - resolved "https://registry.yarnpkg.com/encode-utf8/-/encode-utf8-1.0.3.tgz#f30fdd31da07fb596f281beb2f6b027851994cda" - integrity sha512-ucAnuBEhUK4boH2HjVYG5Q2mQyPorvv0u/ocS+zhdw0S8AlHYY+GOFhP1Gio5z4icpP2ivFSvhtFjQi8+T9ppw== - -enquirer@^2.3.0, enquirer@^2.3.6: - version "2.4.1" - resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.4.1.tgz#93334b3fbd74fc7097b224ab4a8fb7e40bf4ae56" - integrity sha512-rRqJg/6gd538VHvR3PSrdRBb/1Vy2YfzHqzvbhGIQpDRKIa4FgV/54b5Q1xYSxOOwKvjXweS26E0Q+nAMwp2pQ== - dependencies: - ansi-colors "^4.1.1" - strip-ansi "^6.0.1" - -env-paths@^2.2.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" - integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== - -error-ex@^1.3.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" - integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== - dependencies: - is-arrayish "^0.2.1" - -es-abstract@^1.19.0, es-abstract@^1.20.4, es-abstract@^1.21.2: - version "1.22.1" - resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.22.1.tgz#8b4e5fc5cefd7f1660f0f8e1a52900dfbc9d9ccc" - integrity sha512-ioRRcXMO6OFyRpyzV3kE1IIBd4WG5/kltnzdxSCqoP8CMGs/Li+M1uF5o7lOkZVFjDs+NLesthnF66Pg/0q0Lw== - dependencies: - array-buffer-byte-length "^1.0.0" - arraybuffer.prototype.slice "^1.0.1" - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - es-set-tostringtag "^2.0.1" - es-to-primitive "^1.2.1" - function.prototype.name "^1.1.5" - get-intrinsic "^1.2.1" - get-symbol-description "^1.0.0" - globalthis "^1.0.3" - gopd "^1.0.1" - has "^1.0.3" - has-property-descriptors "^1.0.0" - has-proto "^1.0.1" - has-symbols "^1.0.3" - internal-slot "^1.0.5" - is-array-buffer "^3.0.2" - is-callable "^1.2.7" - is-negative-zero "^2.0.2" - is-regex "^1.1.4" - is-shared-array-buffer "^1.0.2" - is-string "^1.0.7" - is-typed-array "^1.1.10" - is-weakref "^1.0.2" - object-inspect "^1.12.3" - object-keys "^1.1.1" - object.assign "^4.1.4" - regexp.prototype.flags "^1.5.0" - safe-array-concat "^1.0.0" - safe-regex-test "^1.0.0" - string.prototype.trim "^1.2.7" - string.prototype.trimend "^1.0.6" - string.prototype.trimstart "^1.0.6" - typed-array-buffer "^1.0.0" - typed-array-byte-length "^1.0.0" - typed-array-byte-offset "^1.0.0" - typed-array-length "^1.0.4" - unbox-primitive "^1.0.2" - which-typed-array "^1.1.10" - -es-array-method-boxes-properly@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz#873f3e84418de4ee19c5be752990b2e44718d09e" - integrity sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA== - -es-set-tostringtag@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/es-set-tostringtag/-/es-set-tostringtag-2.0.1.tgz#338d502f6f674301d710b80c8592de8a15f09cd8" - integrity sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg== - dependencies: - get-intrinsic "^1.1.3" - has "^1.0.3" - has-tostringtag "^1.0.0" - -es-to-primitive@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz#e55cd4c9cdc188bcefb03b366c736323fc5c898a" - integrity sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA== - dependencies: - is-callable "^1.1.4" - is-date-object "^1.0.1" - is-symbol "^1.0.2" - -escalade@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" - integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== - -escape-string-regexp@1.0.5, escape-string-regexp@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" - integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== - -escape-string-regexp@4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" - integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== - -esprima@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" - integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== - -eth-gas-reporter@^0.2.25: - version "0.2.25" - resolved "https://registry.yarnpkg.com/eth-gas-reporter/-/eth-gas-reporter-0.2.25.tgz#546dfa946c1acee93cb1a94c2a1162292d6ff566" - integrity sha512-1fRgyE4xUB8SoqLgN3eDfpDfwEfRxh2Sz1b7wzFbyQA+9TekMmvSjjoRu9SKcSVyK+vLkLIsVbJDsTWjw195OQ== - dependencies: - "@ethersproject/abi" "^5.0.0-beta.146" - "@solidity-parser/parser" "^0.14.0" - cli-table3 "^0.5.0" - colors "1.4.0" - ethereum-cryptography "^1.0.3" - ethers "^4.0.40" - fs-readdir-recursive "^1.1.0" - lodash "^4.17.14" - markdown-table "^1.1.3" - mocha "^7.1.1" - req-cwd "^2.0.0" - request "^2.88.0" - request-promise-native "^1.0.5" - sha1 "^1.1.1" - sync-request "^6.0.0" - -ethereum-cryptography@0.1.3, ethereum-cryptography@^0.1.3: - version "0.1.3" - resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-0.1.3.tgz#8d6143cfc3d74bf79bbd8edecdf29e4ae20dd191" - integrity sha512-w8/4x1SGGzc+tO97TASLja6SLd3fRIK2tLVcV2Gx4IB21hE19atll5Cq9o3d0ZmAYC/8aw0ipieTSiekAea4SQ== - dependencies: - "@types/pbkdf2" "^3.0.0" - "@types/secp256k1" "^4.0.1" - blakejs "^1.1.0" - browserify-aes "^1.2.0" - bs58check "^2.1.2" - create-hash "^1.2.0" - create-hmac "^1.1.7" - hash.js "^1.1.7" - keccak "^3.0.0" - pbkdf2 "^3.0.17" - randombytes "^2.1.0" - safe-buffer "^5.1.2" - scrypt-js "^3.0.0" - secp256k1 "^4.0.1" - setimmediate "^1.0.5" - -ethereum-cryptography@^1.0.3: - version "1.2.0" - resolved "https://registry.yarnpkg.com/ethereum-cryptography/-/ethereum-cryptography-1.2.0.tgz#5ccfa183e85fdaf9f9b299a79430c044268c9b3a" - integrity sha512-6yFQC9b5ug6/17CQpCyE3k9eKBMdhyVjzUy1WkiuY/E4vj/SXDBbCw8QEIaXqf0Mf2SnY6RmpDcwlUmBSS0EJw== - dependencies: - "@noble/hashes" "1.2.0" - "@noble/secp256k1" "1.7.1" - "@scure/bip32" "1.1.5" - "@scure/bip39" "1.1.1" - -ethereumjs-abi@^0.6.8: - version "0.6.8" - resolved "https://registry.yarnpkg.com/ethereumjs-abi/-/ethereumjs-abi-0.6.8.tgz#71bc152db099f70e62f108b7cdfca1b362c6fcae" - integrity sha512-Tx0r/iXI6r+lRsdvkFDlut0N08jWMnKRZ6Gkq+Nmw75lZe4e6o3EkSnkaBP5NF6+m5PTGAr9JP43N3LyeoglsA== - dependencies: - bn.js "^4.11.8" - ethereumjs-util "^6.0.0" - -ethereumjs-util@^6.0.0, ethereumjs-util@^6.2.1: - version "6.2.1" - resolved "https://registry.yarnpkg.com/ethereumjs-util/-/ethereumjs-util-6.2.1.tgz#fcb4e4dd5ceacb9d2305426ab1a5cd93e3163b69" - integrity sha512-W2Ktez4L01Vexijrm5EB6w7dg4n/TgpoYU4avuT5T3Vmnw/eCRtiBrJfQYS/DCSvDIOLn2k57GcHdeBcgVxAqw== - dependencies: - "@types/bn.js" "^4.11.3" - bn.js "^4.11.0" - create-hash "^1.1.2" - elliptic "^6.5.2" - ethereum-cryptography "^0.1.3" - ethjs-util "0.1.6" - rlp "^2.2.3" - -ethers@^4.0.40: - version "4.0.49" - resolved "https://registry.yarnpkg.com/ethers/-/ethers-4.0.49.tgz#0eb0e9161a0c8b4761be547396bbe2fb121a8894" - integrity sha512-kPltTvWiyu+OktYy1IStSO16i2e7cS9D9OxZ81q2UUaiNPVrm/RTcbxamCXF9VUSKzJIdJV68EAIhTEVBalRWg== - dependencies: - aes-js "3.0.0" - bn.js "^4.11.9" - elliptic "6.5.4" - hash.js "1.1.3" - js-sha3 "0.5.7" - scrypt-js "2.0.4" - setimmediate "1.0.4" - uuid "2.0.1" - xmlhttprequest "1.8.0" - -ethers@^5.5.2, ethers@^5.5.3, ethers@^5.7.1: - version "5.7.2" - resolved "https://registry.yarnpkg.com/ethers/-/ethers-5.7.2.tgz#3a7deeabbb8c030d4126b24f84e525466145872e" - integrity sha512-wswUsmWo1aOK8rR7DIKiWSw9DbLWe6x98Jrn8wcTflTVvaXhAMaB5zGAXy0GYQEQp9iO1iSHWVyARQm11zUtyg== - dependencies: - "@ethersproject/abi" "5.7.0" - "@ethersproject/abstract-provider" "5.7.0" - "@ethersproject/abstract-signer" "5.7.0" - "@ethersproject/address" "5.7.0" - "@ethersproject/base64" "5.7.0" - "@ethersproject/basex" "5.7.0" - "@ethersproject/bignumber" "5.7.0" - "@ethersproject/bytes" "5.7.0" - "@ethersproject/constants" "5.7.0" - "@ethersproject/contracts" "5.7.0" - "@ethersproject/hash" "5.7.0" - "@ethersproject/hdnode" "5.7.0" - "@ethersproject/json-wallets" "5.7.0" - "@ethersproject/keccak256" "5.7.0" - "@ethersproject/logger" "5.7.0" - "@ethersproject/networks" "5.7.1" - "@ethersproject/pbkdf2" "5.7.0" - "@ethersproject/properties" "5.7.0" - "@ethersproject/providers" "5.7.2" - "@ethersproject/random" "5.7.0" - "@ethersproject/rlp" "5.7.0" - "@ethersproject/sha2" "5.7.0" - "@ethersproject/signing-key" "5.7.0" - "@ethersproject/solidity" "5.7.0" - "@ethersproject/strings" "5.7.0" - "@ethersproject/transactions" "5.7.0" - "@ethersproject/units" "5.7.0" - "@ethersproject/wallet" "5.7.0" - "@ethersproject/web" "5.7.1" - "@ethersproject/wordlists" "5.7.0" - -ethjs-util@0.1.6, ethjs-util@^0.1.6: - version "0.1.6" - resolved "https://registry.yarnpkg.com/ethjs-util/-/ethjs-util-0.1.6.tgz#f308b62f185f9fe6237132fb2a9818866a5cd536" - integrity sha512-CUnVOQq7gSpDHZVVrQW8ExxUETWrnrvXYvYz55wOU8Uj4VCgw56XC2B/fVqQN+f7gmrnRHSLVnFAwsCuNwji8w== - dependencies: - is-hex-prefixed "1.0.0" - strip-hex-prefix "1.0.0" - -event-target-shim@^5.0.0: - version "5.0.1" - resolved "https://registry.yarnpkg.com/event-target-shim/-/event-target-shim-5.0.1.tgz#5d4d3ebdf9583d63a5333ce2deb7480ab2b05789" - integrity sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ== - -evp_bytestokey@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02" - integrity sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA== - dependencies: - md5.js "^1.3.4" - safe-buffer "^5.1.1" - -execa@^7.0.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/execa/-/execa-7.2.0.tgz#657e75ba984f42a70f38928cedc87d6f2d4fe4e9" - integrity sha512-UduyVP7TLB5IcAQl+OzLyLcS/l32W/GLg+AhHJ+ow40FOk2U3SAllPwR44v4vmdFwIWqpdwxxpQbF1n5ta9seA== - dependencies: - cross-spawn "^7.0.3" - get-stream "^6.0.1" - human-signals "^4.3.0" - is-stream "^3.0.0" - merge-stream "^2.0.0" - npm-run-path "^5.1.0" - onetime "^6.0.0" - signal-exit "^3.0.7" - strip-final-newline "^3.0.0" - -extend@~3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" - integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== - -extsprintf@1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" - integrity sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g== - -extsprintf@^1.2.0: - version "1.4.1" - resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.1.tgz#8d172c064867f235c0c84a596806d279bf4bcc07" - integrity sha512-Wrk35e8ydCKDj/ArClo1VrPVmN8zph5V4AtHwIuHhvMXsKf73UT3BOD+azBIW+3wOJ4FhEH7zyaJCFvChjYvMA== - -fast-deep-equal@^3.1.1: - version "3.1.3" - resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" - integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== - -fast-diff@^1.2.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.3.0.tgz#ece407fa550a64d638536cd727e129c61616e0f0" - integrity sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw== - -fast-glob@^3.2.9: - version "3.3.1" - resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.1.tgz#784b4e897340f3dbbef17413b3f11acf03c874c4" - integrity sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg== - dependencies: - "@nodelib/fs.stat" "^2.0.2" - "@nodelib/fs.walk" "^1.2.3" - glob-parent "^5.1.2" - merge2 "^1.3.0" - micromatch "^4.0.4" - -fast-json-stable-stringify@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" - integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== - -fastq@^1.6.0: - version "1.15.0" - resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" - integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== - dependencies: - reusify "^1.0.4" - -fill-range@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" - integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== - dependencies: - to-regex-range "^5.0.1" - -find-replace@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/find-replace/-/find-replace-3.0.0.tgz#3e7e23d3b05167a76f770c9fbd5258b0def68c38" - integrity sha512-6Tb2myMioCAgv5kfvP5/PkZZ/ntTpVK39fHY7WkWBgvbeE+VHd/tZuZ4mrC+bxh4cfOZeYKVPaJIZtZXV7GNCQ== - dependencies: - array-back "^3.0.1" - -find-up@3.0.0, find-up@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" - integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== - dependencies: - locate-path "^3.0.0" - -find-up@5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" - integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== - dependencies: - locate-path "^6.0.0" - path-exists "^4.0.0" - -find-up@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7" - integrity sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ== - dependencies: - locate-path "^2.0.0" - -flat@^4.1.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/flat/-/flat-4.1.1.tgz#a392059cc382881ff98642f5da4dde0a959f309b" - integrity sha512-FmTtBsHskrU6FJ2VxCnsDb84wu9zhmO3cUX2kGFb5tuwhfXxGciiT0oRY+cck35QmG+NmGh5eLz6lLCpWTqwpA== - dependencies: - is-buffer "~2.0.3" - -flat@^5.0.2: - version "5.0.2" - resolved "https://registry.yarnpkg.com/flat/-/flat-5.0.2.tgz#8ca6fe332069ffa9d324c327198c598259ceb241" - integrity sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ== - -fmix@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/fmix/-/fmix-0.1.0.tgz#c7bbf124dec42c9d191cfb947d0a9778dd986c0c" - integrity sha512-Y6hyofImk9JdzU8k5INtTXX1cu8LDlePWDFU5sftm9H+zKCr5SGrVjdhkvsim646cw5zD0nADj8oHyXMZmCZ9w== - dependencies: - imul "^1.0.0" - -follow-redirects@^1.12.1, follow-redirects@^1.14.0, follow-redirects@^1.14.4: - version "1.15.2" - resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" - integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== - -for-each@^0.3.3: - version "0.3.3" - resolved "https://registry.yarnpkg.com/for-each/-/for-each-0.3.3.tgz#69b447e88a0a5d32c3e7084f3f1710034b21376e" - integrity sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw== - dependencies: - is-callable "^1.1.3" - -forever-agent@~0.6.1: - version "0.6.1" - resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" - integrity sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw== - -form-data@^2.2.0: - version "2.5.1" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.5.1.tgz#f2cbec57b5e59e23716e128fe44d4e5dd23895f4" - integrity sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA== - dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.6" - mime-types "^2.1.12" - -form-data@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" - integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== - dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.8" - mime-types "^2.1.12" - -form-data@~2.3.2: - version "2.3.3" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6" - integrity sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ== - dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.6" - mime-types "^2.1.12" - -fp-ts@1.19.3: - version "1.19.3" - resolved "https://registry.yarnpkg.com/fp-ts/-/fp-ts-1.19.3.tgz#261a60d1088fbff01f91256f91d21d0caaaaa96f" - integrity sha512-H5KQDspykdHuztLTg+ajGN0Z2qUjcEf3Ybxc6hLt0k7/zPkn29XnKnxlBPyW2XIddWrGaJBzBl4VLYOtk39yZg== - -fp-ts@^1.0.0: - version "1.19.5" - resolved "https://registry.yarnpkg.com/fp-ts/-/fp-ts-1.19.5.tgz#3da865e585dfa1fdfd51785417357ac50afc520a" - integrity sha512-wDNqTimnzs8QqpldiId9OavWK2NptormjXnRJTQecNjzwfyp6P/8s/zG8e4h3ja3oqkKaY72UlTjQYt/1yXf9A== - -fs-extra@11.1.1: - version "11.1.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-11.1.1.tgz#da69f7c39f3b002378b0954bb6ae7efdc0876e2d" - integrity sha512-MGIE4HOvQCeUCzmlHs0vXpih4ysz4wg9qiSAu6cd42lVwPbTM1TjV7RusoyQqMmk/95gdQZX72u+YW+c3eEpFQ== - dependencies: - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - -fs-extra@^0.30.0: - version "0.30.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-0.30.0.tgz#f233ffcc08d4da7d432daa449776989db1df93f0" - integrity sha512-UvSPKyhMn6LEd/WpUaV9C9t3zATuqoqfWc3QdPhPLb58prN9tqYPlPWi8Krxi44loBoUzlobqZ3+8tGpxxSzwA== - dependencies: - graceful-fs "^4.1.2" - jsonfile "^2.1.0" - klaw "^1.0.0" - path-is-absolute "^1.0.0" - rimraf "^2.2.8" - -fs-extra@^10.0.0: - version "10.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" - integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ== - dependencies: - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - -fs-extra@^7.0.0, fs-extra@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" - integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== - dependencies: - graceful-fs "^4.1.2" - jsonfile "^4.0.0" - universalify "^0.1.0" - -fs-extra@^8.1: - version "8.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" - integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== - dependencies: - graceful-fs "^4.2.0" - jsonfile "^4.0.0" - universalify "^0.1.0" - -fs-extra@^9.1.0: - version "9.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" - integrity sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ== - dependencies: - at-least-node "^1.0.0" - graceful-fs "^4.2.0" - jsonfile "^6.0.1" - universalify "^2.0.0" - -fs-readdir-recursive@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz#e32fc030a2ccee44a6b5371308da54be0b397d27" - integrity sha512-GNanXlVr2pf02+sPN40XN8HG+ePaNcvM0q5mZBd668Obwb0yD5GiUbZOFgwn8kGMY6I3mdyDJzieUy3PTYyTRA== - -fs.realpath@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" - integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== - -fsevents@~2.1.1: - version "2.1.3" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.3.tgz#fb738703ae8d2f9fe900c33836ddebee8b97f23e" - integrity sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ== - -fsevents@~2.3.2: - version "2.3.2" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" - integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== - -function-bind@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" - integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== - -function.prototype.name@^1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" - integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.3" - es-abstract "^1.19.0" - functions-have-names "^1.2.2" - -functional-red-black-tree@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" - integrity sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g== - -functions-have-names@^1.2.2, functions-have-names@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" - integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== - -get-caller-file@^2.0.1, get-caller-file@^2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" - integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== - -get-func-name@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" - integrity sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig== - -get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@^1.2.0, get-intrinsic@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.1.tgz#d295644fed4505fc9cde952c37ee12b477a83d82" - integrity sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw== - dependencies: - function-bind "^1.1.1" - has "^1.0.3" - has-proto "^1.0.1" - has-symbols "^1.0.3" - -get-port@^3.1.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/get-port/-/get-port-3.2.0.tgz#dd7ce7de187c06c8bf353796ac71e099f0980ebc" - integrity sha512-x5UJKlgeUiNT8nyo/AcnwLnZuZNcSjSw0kogRB+Whd1fjjFq4B1hySFxSFWWSn4mIBzg3sRNUDFYc4g5gjPoLg== - -get-stream@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" - integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== - -get-symbol-description@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" - integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== - dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.1.1" - -getpass@^0.1.1: - version "0.1.7" - resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" - integrity sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng== - dependencies: - assert-plus "^1.0.0" - -glob-parent@^5.1.2, glob-parent@~5.1.0, glob-parent@~5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" - integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== - dependencies: - is-glob "^4.0.1" - -glob@7.1.3: - version "7.1.3" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.3.tgz#3960832d3f1574108342dafd3a67b332c0969df1" - integrity sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.0.4" - once "^1.3.0" - path-is-absolute "^1.0.0" - -glob@7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" - integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.0.4" - once "^1.3.0" - path-is-absolute "^1.0.0" - -glob@^7.1.3, glob@^7.1.6: - version "7.2.3" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" - integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.1.1" - once "^1.3.0" - path-is-absolute "^1.0.0" - -glob@^8.0.3: - version "8.1.0" - resolved "https://registry.yarnpkg.com/glob/-/glob-8.1.0.tgz#d388f656593ef708ee3e34640fdfb99a9fd1c33e" - integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^5.0.1" - once "^1.3.0" - -globalthis@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" - integrity sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA== - dependencies: - define-properties "^1.1.3" - -globby@^11.0.0, globby@^11.0.1, globby@^11.1.0: - version "11.1.0" - resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" - integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== - dependencies: - array-union "^2.1.0" - dir-glob "^3.0.1" - fast-glob "^3.2.9" - ignore "^5.2.0" - merge2 "^1.4.1" - slash "^3.0.0" - -gopd@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" - integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== - dependencies: - get-intrinsic "^1.1.3" - -graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.1.9, graceful-fs@^4.2.0: - version "4.2.11" - resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" - integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== - -growl@1.10.5: - version "1.10.5" - resolved "https://registry.yarnpkg.com/growl/-/growl-1.10.5.tgz#f2735dc2283674fa67478b10181059355c369e5e" - integrity sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA== - -handlebars@^4.7.6: - version "4.7.8" - resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-4.7.8.tgz#41c42c18b1be2365439188c77c6afae71c0cd9e9" - integrity sha512-vafaFqs8MZkRrSX7sFVUdo3ap/eNiLnb4IakshzvP56X5Nr1iGKAIqdX6tMlm6HcNRIkr6AxO5jFEoJzzpT8aQ== - dependencies: - minimist "^1.2.5" - neo-async "^2.6.2" - source-map "^0.6.1" - wordwrap "^1.0.0" - optionalDependencies: - uglify-js "^3.1.4" - -har-schema@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" - integrity sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q== - -har-validator@~5.1.3: - version "5.1.5" - resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd" - integrity sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w== - dependencies: - ajv "^6.12.3" - har-schema "^2.0.0" - -hardhat-contract-sizer@2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/hardhat-contract-sizer/-/hardhat-contract-sizer-2.8.0.tgz#730a9bf35ed200ba57b6865bd3f459a91c90f205" - integrity sha512-jXt2Si3uIDx5z99J+gvKa0yvIw156pE4dpH9X/PvTQv652BUd+qGj7WT93PXnHXGh5qhQLkjDYeZMYNOThfjFg== - dependencies: - chalk "^4.0.0" - cli-table3 "^0.6.0" - strip-ansi "^6.0.0" - -hardhat-deploy@0.11.29: - version "0.11.29" - resolved "https://registry.yarnpkg.com/hardhat-deploy/-/hardhat-deploy-0.11.29.tgz#e6d76e37fa2ed74d76d15b01f3849da3bda49a81" - integrity sha512-9F+MRFkEocelzB8d+SDDCcTL7edBYAj2S63ldknvfIIBSajeB6q1/jm+dlK1GjcWzAzw7EVoxtjJXzxAxZfZcg== - dependencies: - "@ethersproject/abi" "^5.7.0" - "@ethersproject/abstract-signer" "^5.7.0" - "@ethersproject/address" "^5.7.0" - "@ethersproject/bignumber" "^5.7.0" - "@ethersproject/bytes" "^5.7.0" - "@ethersproject/constants" "^5.7.0" - "@ethersproject/contracts" "^5.7.0" - "@ethersproject/providers" "^5.7.2" - "@ethersproject/solidity" "^5.7.0" - "@ethersproject/transactions" "^5.7.0" - "@ethersproject/wallet" "^5.7.0" - "@types/qs" "^6.9.7" - axios "^0.21.1" - chalk "^4.1.2" - chokidar "^3.5.2" - debug "^4.3.2" - enquirer "^2.3.6" - ethers "^5.5.3" - form-data "^4.0.0" - fs-extra "^10.0.0" - match-all "^1.2.6" - murmur-128 "^0.2.1" - qs "^6.9.4" - zksync-web3 "^0.14.3" - -hardhat-gas-reporter@^1.0.8: - version "1.0.9" - resolved "https://registry.yarnpkg.com/hardhat-gas-reporter/-/hardhat-gas-reporter-1.0.9.tgz#9a2afb354bc3b6346aab55b1c02ca556d0e16450" - integrity sha512-INN26G3EW43adGKBNzYWOlI3+rlLnasXTwW79YNnUhXPDa+yHESgt639dJEs37gCjhkbNKcRRJnomXEuMFBXJg== - dependencies: - array-uniq "1.0.3" - eth-gas-reporter "^0.2.25" - sha1 "^1.1.1" - -hardhat-storage-layout@^0.1.7: - version "0.1.7" - resolved "https://registry.yarnpkg.com/hardhat-storage-layout/-/hardhat-storage-layout-0.1.7.tgz#ad8a5afd8593ee51031eb1dd9476b4a2ed981785" - integrity sha512-q723g2iQnJpRdMC6Y8fbh/stG6MLHKNxa5jq/ohjtD5znOlOzQ6ojYuInY8V4o4WcPyG3ty4hzHYunLf66/1+A== - dependencies: - console-table-printer "^2.9.0" - -hardhat@2.14.0: - version "2.14.0" - resolved "https://registry.yarnpkg.com/hardhat/-/hardhat-2.14.0.tgz#b60c74861494aeb1b50803cf04cc47865a42b87a" - integrity sha512-73jsInY4zZahMSVFurSK+5TNCJTXMv+vemvGia0Ac34Mm19fYp6vEPVGF3sucbumszsYxiTT2TbS8Ii2dsDSoQ== - dependencies: - "@ethersproject/abi" "^5.1.2" - "@metamask/eth-sig-util" "^4.0.0" - "@nomicfoundation/ethereumjs-block" "5.0.1" - "@nomicfoundation/ethereumjs-blockchain" "7.0.1" - "@nomicfoundation/ethereumjs-common" "4.0.1" - "@nomicfoundation/ethereumjs-evm" "2.0.1" - "@nomicfoundation/ethereumjs-rlp" "5.0.1" - "@nomicfoundation/ethereumjs-statemanager" "2.0.1" - "@nomicfoundation/ethereumjs-trie" "6.0.1" - "@nomicfoundation/ethereumjs-tx" "5.0.1" - "@nomicfoundation/ethereumjs-util" "9.0.1" - "@nomicfoundation/ethereumjs-vm" "7.0.1" - "@nomicfoundation/solidity-analyzer" "^0.1.0" - "@sentry/node" "^5.18.1" - "@types/bn.js" "^5.1.0" - "@types/lru-cache" "^5.1.0" - abort-controller "^3.0.0" - adm-zip "^0.4.16" - aggregate-error "^3.0.0" - ansi-escapes "^4.3.0" - chalk "^2.4.2" - chokidar "^3.4.0" - ci-info "^2.0.0" - debug "^4.1.1" - enquirer "^2.3.0" - env-paths "^2.2.0" - ethereum-cryptography "^1.0.3" - ethereumjs-abi "^0.6.8" - find-up "^2.1.0" - fp-ts "1.19.3" - fs-extra "^7.0.1" - glob "7.2.0" - immutable "^4.0.0-rc.12" - io-ts "1.10.4" - keccak "^3.0.2" - lodash "^4.17.11" - mnemonist "^0.38.0" - mocha "^10.0.0" - p-map "^4.0.0" - qs "^6.7.0" - raw-body "^2.4.1" - resolve "1.17.0" - semver "^6.3.0" - solc "0.7.3" - source-map-support "^0.5.13" - stacktrace-parser "^0.1.10" - tsort "0.0.1" - undici "^5.14.0" - uuid "^8.3.2" - ws "^7.4.6" - -has-bigints@^1.0.1, has-bigints@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" - integrity sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ== - -has-flag@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" - integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== - -has-flag@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" - integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== - -has-property-descriptors@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" - integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== - dependencies: - get-intrinsic "^1.1.1" - -has-proto@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/has-proto/-/has-proto-1.0.1.tgz#1885c1305538958aff469fef37937c22795408e0" - integrity sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg== - -has-symbols@^1.0.0, has-symbols@^1.0.2, has-symbols@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" - integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== - -has-tostringtag@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" - integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== - dependencies: - has-symbols "^1.0.2" - -has@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" - integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== - dependencies: - function-bind "^1.1.1" - -hash-base@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.1.0.tgz#55c381d9e06e1d2997a883b4a3fddfe7f0d3af33" - integrity sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA== - dependencies: - inherits "^2.0.4" - readable-stream "^3.6.0" - safe-buffer "^5.2.0" - -hash.js@1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.3.tgz#340dedbe6290187151c1ea1d777a3448935df846" - integrity sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA== - dependencies: - inherits "^2.0.3" - minimalistic-assert "^1.0.0" - -hash.js@1.1.7, hash.js@^1.0.0, hash.js@^1.0.3, hash.js@^1.1.7: - version "1.1.7" - resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.7.tgz#0babca538e8d4ee4a0f8988d68866537a003cf42" - integrity sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA== - dependencies: - inherits "^2.0.3" - minimalistic-assert "^1.0.1" - -he@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" - integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== - -hmac-drbg@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1" - integrity sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg== - dependencies: - hash.js "^1.0.3" - minimalistic-assert "^1.0.0" - minimalistic-crypto-utils "^1.0.1" - -http-basic@^8.1.1: - version "8.1.3" - resolved "https://registry.yarnpkg.com/http-basic/-/http-basic-8.1.3.tgz#a7cabee7526869b9b710136970805b1004261bbf" - integrity sha512-/EcDMwJZh3mABI2NhGfHOGOeOZITqfkEO4p/xK+l3NpyncIHUQBoMvCSF/b5GqvKtySC2srL/GGG3+EtlqlmCw== - dependencies: - caseless "^0.12.0" - concat-stream "^1.6.2" - http-response-object "^3.0.1" - parse-cache-control "^1.0.1" - -http-errors@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" - integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== - dependencies: - depd "2.0.0" - inherits "2.0.4" - setprototypeof "1.2.0" - statuses "2.0.1" - toidentifier "1.0.1" - -http-response-object@^3.0.1: - version "3.0.2" - resolved "https://registry.yarnpkg.com/http-response-object/-/http-response-object-3.0.2.tgz#7f435bb210454e4360d074ef1f989d5ea8aa9810" - integrity sha512-bqX0XTF6fnXSQcEJ2Iuyr75yVakyjIDCqroJQ/aHfSdlM743Cwqoi2nDYMzLGWUcuTWGWy8AAvOKXTfiv6q9RA== - dependencies: - "@types/node" "^10.0.3" - -http-signature@~1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" - integrity sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ== - dependencies: - assert-plus "^1.0.0" - jsprim "^1.2.2" - sshpk "^1.7.0" - -https-proxy-agent@^5.0.0: - version "5.0.1" - resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" - integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== - dependencies: - agent-base "6" - debug "4" - -human-signals@^4.3.0: - version "4.3.1" - resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-4.3.1.tgz#ab7f811e851fca97ffbd2c1fe9a958964de321b2" - integrity sha512-nZXjEF2nbo7lIw3mgYjItAfgQXog3OjJogSbKa2CQIIvSGWcKgeJnQlNXip6NglNzYH45nSRiEVimMvYL8DDqQ== - -husky@^7.0.4: - version "7.0.4" - resolved "https://registry.yarnpkg.com/husky/-/husky-7.0.4.tgz#242048245dc49c8fb1bf0cc7cfb98dd722531535" - integrity sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ== - -iconv-lite@0.4.24: - version "0.4.24" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" - integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== - dependencies: - safer-buffer ">= 2.1.2 < 3" - -ieee754@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" - integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== - -ignore@^5.2.0, ignore@^5.2.4: - version "5.2.4" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.4.tgz#a291c0c6178ff1b960befe47fcdec301674a6324" - integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ== - -immutable@^4.0.0-rc.12: - version "4.3.1" - resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.3.1.tgz#17988b356097ab0719e2f741d56f3ec6c317f9dc" - integrity sha512-lj9cnmB/kVS0QHsJnYKD1uo3o39nrbKxszjnqS9Fr6NB7bZzW45U6WSGBPKXDL/CvDKqDNPA4r3DoDQ8GTxo2A== - -import-fresh@^3.2.1: - version "3.3.0" - resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" - integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== - dependencies: - parent-module "^1.0.0" - resolve-from "^4.0.0" - -imul@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/imul/-/imul-1.0.1.tgz#9d5867161e8b3de96c2c38d5dc7cb102f35e2ac9" - integrity sha512-WFAgfwPLAjU66EKt6vRdTlKj4nAgIDQzh29JonLa4Bqtl6D8JrIMvWjCnx7xEjVNmP3U0fM5o8ZObk7d0f62bA== - -indent-string@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" - integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== - -inflight@^1.0.4: - version "1.0.6" - resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" - integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== - dependencies: - once "^1.3.0" - wrappy "1" - -inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.3: - version "2.0.4" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" - integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== - -internal-slot@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.5.tgz#f2a2ee21f668f8627a4667f309dc0f4fb6674986" - integrity sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ== - dependencies: - get-intrinsic "^1.2.0" - has "^1.0.3" - side-channel "^1.0.4" - -io-ts@1.10.4: - version "1.10.4" - resolved "https://registry.yarnpkg.com/io-ts/-/io-ts-1.10.4.tgz#cd5401b138de88e4f920adbcb7026e2d1967e6e2" - integrity sha512-b23PteSnYXSONJ6JQXRAlvJhuw8KOtkqa87W4wDtvMrud/DTJd5X+NpOOI+O/zZwVq6v0VLAaJ+1EDViKEuN9g== - dependencies: - fp-ts "^1.0.0" - -is-array-buffer@^3.0.1, is-array-buffer@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.2.tgz#f2653ced8412081638ecb0ebbd0c41c6e0aecbbe" - integrity sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w== - dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.2.0" - is-typed-array "^1.1.10" - -is-arrayish@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" - integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== - -is-bigint@^1.0.1: - version "1.0.4" - resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.4.tgz#08147a1875bc2b32005d41ccd8291dffc6691df3" - integrity sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg== - dependencies: - has-bigints "^1.0.1" - -is-binary-path@~2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" - integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== - dependencies: - binary-extensions "^2.0.0" - -is-boolean-object@^1.1.0: - version "1.1.2" - resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.2.tgz#5c6dc200246dd9321ae4b885a114bb1f75f63719" - integrity sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA== - dependencies: - call-bind "^1.0.2" - has-tostringtag "^1.0.0" - -is-buffer@^2.0.5, is-buffer@~2.0.3: - version "2.0.5" - resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-2.0.5.tgz#ebc252e400d22ff8d77fa09888821a24a658c191" - integrity sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ== - -is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.7: - version "1.2.7" - resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.7.tgz#3bc2a85ea742d9e36205dcacdd72ca1fdc51b055" - integrity sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA== - -is-date-object@^1.0.1: - version "1.0.5" - resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.5.tgz#0841d5536e724c25597bf6ea62e1bd38298df31f" - integrity sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ== - dependencies: - has-tostringtag "^1.0.0" - -is-docker@^2.0.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa" - integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== - -is-extglob@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" - integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== - -is-fullwidth-code-point@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" - integrity sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w== - -is-fullwidth-code-point@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" - integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== - -is-fullwidth-code-point@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz#fae3167c729e7463f8461ce512b080a49268aa88" - integrity sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ== - -is-glob@^4.0.1, is-glob@~4.0.1: - version "4.0.3" - resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" - integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== - dependencies: - is-extglob "^2.1.1" - -is-hex-prefixed@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz#7d8d37e6ad77e5d127148913c573e082d777f554" - integrity sha512-WvtOiug1VFrE9v1Cydwm+FnXd3+w9GaeVUss5W4v/SLy3UW00vP+6iNF2SdnfiBoLy4bTqVdkftNGTUeOFVsbA== - -is-negative-zero@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" - integrity sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA== - -is-number-object@^1.0.4: - version "1.0.7" - resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.7.tgz#59d50ada4c45251784e9904f5246c742f07a42fc" - integrity sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ== - dependencies: - has-tostringtag "^1.0.0" - -is-number@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" - integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== - -is-plain-obj@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-2.1.0.tgz#45e42e37fccf1f40da8e5f76ee21515840c09287" - integrity sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA== - -is-regex@^1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" - integrity sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg== - dependencies: - call-bind "^1.0.2" - has-tostringtag "^1.0.0" - -is-shared-array-buffer@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" - integrity sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA== - dependencies: - call-bind "^1.0.2" - -is-stream@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-3.0.0.tgz#e6bfd7aa6bef69f4f472ce9bb681e3e57b4319ac" - integrity sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA== - -is-string@^1.0.5, is-string@^1.0.7: - version "1.0.7" - resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" - integrity sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg== - dependencies: - has-tostringtag "^1.0.0" - -is-symbol@^1.0.2, is-symbol@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.4.tgz#a6dac93b635b063ca6872236de88910a57af139c" - integrity sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg== - dependencies: - has-symbols "^1.0.2" - -is-typed-array@^1.1.10, is-typed-array@^1.1.9: - version "1.1.12" - resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.12.tgz#d0bab5686ef4a76f7a73097b95470ab199c57d4a" - integrity sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg== - dependencies: - which-typed-array "^1.1.11" - -is-typedarray@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" - integrity sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA== - -is-unicode-supported@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" - integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== - -is-weakref@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" - integrity sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ== - dependencies: - call-bind "^1.0.2" - -is-wsl@^2.1.1: - version "2.2.0" - resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" - integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== - dependencies: - is-docker "^2.0.0" - -isarray@^2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/isarray/-/isarray-2.0.5.tgz#8af1e4c1221244cc62459faf38940d4e644a5723" - integrity sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw== - -isarray@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" - integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== - -isexe@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" - integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== - -isstream@~0.1.2: - version "0.1.2" - resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" - integrity sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g== - -js-sdsl@^4.1.4: - version "4.4.2" - resolved "https://registry.yarnpkg.com/js-sdsl/-/js-sdsl-4.4.2.tgz#2e3c031b1f47d3aca8b775532e3ebb0818e7f847" - integrity sha512-dwXFwByc/ajSV6m5bcKAPwe4yDDF6D614pxmIi5odytzxRlwqF6nwoiCek80Ixc7Cvma5awClxrzFtxCQvcM8w== - -js-sha3@0.5.7: - version "0.5.7" - resolved "https://registry.yarnpkg.com/js-sha3/-/js-sha3-0.5.7.tgz#0d4ffd8002d5333aabaf4a23eed2f6374c9f28e7" - integrity sha512-GII20kjaPX0zJ8wzkTbNDYMY7msuZcTWk8S5UOh6806Jq/wz1J8/bnr8uGU0DAUmYDjj2Mr4X1cW8v/GLYnR+g== - -js-sha3@0.8.0, js-sha3@^0.8.0: - version "0.8.0" - resolved "https://registry.yarnpkg.com/js-sha3/-/js-sha3-0.8.0.tgz#b9b7a5da73afad7dedd0f8c463954cbde6818840" - integrity sha512-gF1cRrHhIzNfToc802P800N8PpXS+evLLXfsVpowqmAFR9uwbi89WvXg2QspOmXL8QL86J4T1EpFu+yUkwJY3Q== - -js-tokens@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" - integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== - -js-yaml@3.13.1: - version "3.13.1" - resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.13.1.tgz#aff151b30bfdfa8e49e05da22e7415e9dfa37847" - integrity sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw== - dependencies: - argparse "^1.0.7" - esprima "^4.0.0" - -js-yaml@4.1.0, js-yaml@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" - integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== - dependencies: - argparse "^2.0.1" - -jsbn@~0.1.0: - version "0.1.1" - resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" - integrity sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg== - -json-parse-even-better-errors@^2.3.0: - version "2.3.1" - resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" - integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== - -json-schema-traverse@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" - integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== - -json-schema-traverse@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" - integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== - -json-schema@0.4.0: - version "0.4.0" - resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" - integrity sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA== - -json-stringify-safe@~5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" - integrity sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA== - -json5@^2.1.3: - version "2.2.3" - resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" - integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== - -jsonfile@^2.1.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-2.4.0.tgz#3736a2b428b87bbda0cc83b53fa3d633a35c2ae8" - integrity sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw== - optionalDependencies: - graceful-fs "^4.1.6" - -jsonfile@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" - integrity sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg== - optionalDependencies: - graceful-fs "^4.1.6" - -jsonfile@^6.0.1: - version "6.1.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" - integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== - dependencies: - universalify "^2.0.0" - optionalDependencies: - graceful-fs "^4.1.6" - -jsprim@^1.2.2: - version "1.4.2" - resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.2.tgz#712c65533a15c878ba59e9ed5f0e26d5b77c5feb" - integrity sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw== - dependencies: - assert-plus "1.0.0" - extsprintf "1.3.0" - json-schema "0.4.0" - verror "1.10.0" - -keccak@^3.0.0, keccak@^3.0.2: - version "3.0.3" - resolved "https://registry.yarnpkg.com/keccak/-/keccak-3.0.3.tgz#4bc35ad917be1ef54ff246f904c2bbbf9ac61276" - integrity sha512-JZrLIAJWuZxKbCilMpNz5Vj7Vtb4scDG3dMXLOsbzBmQGyjwE61BbW7bJkfKKCShXiQZt3T6sBgALRtmd+nZaQ== - dependencies: - node-addon-api "^2.0.0" - node-gyp-build "^4.2.0" - readable-stream "^3.6.0" - -klaw@^1.0.0: - version "1.3.1" - resolved "https://registry.yarnpkg.com/klaw/-/klaw-1.3.1.tgz#4088433b46b3b1ba259d78785d8e96f73ba02439" - integrity sha512-TED5xi9gGQjGpNnvRWknrwAB1eL5GciPfVFOt3Vk1OJCVDQbzuSfrF3hkUQKlsgKrG1F+0t5W0m+Fje1jIt8rw== - optionalDependencies: - graceful-fs "^4.1.9" - -level-supports@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/level-supports/-/level-supports-4.0.1.tgz#431546f9d81f10ff0fea0e74533a0e875c08c66a" - integrity sha512-PbXpve8rKeNcZ9C1mUicC9auIYFyGpkV9/i6g76tLgANwWhtG2v7I4xNBUlkn3lE2/dZF3Pi0ygYGtLc4RXXdA== - -level-transcoder@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/level-transcoder/-/level-transcoder-1.0.1.tgz#f8cef5990c4f1283d4c86d949e73631b0bc8ba9c" - integrity sha512-t7bFwFtsQeD8cl8NIoQ2iwxA0CL/9IFw7/9gAjOonH0PWTTiRfY7Hq+Ejbsxh86tXobDQ6IOiddjNYIfOBs06w== - dependencies: - buffer "^6.0.3" - module-error "^1.0.1" - -level@^8.0.0: - version "8.0.0" - resolved "https://registry.yarnpkg.com/level/-/level-8.0.0.tgz#41b4c515dabe28212a3e881b61c161ffead14394" - integrity sha512-ypf0jjAk2BWI33yzEaaotpq7fkOPALKAgDBxggO6Q9HGX2MRXn0wbP1Jn/tJv1gtL867+YOjOB49WaUF3UoJNQ== - dependencies: - browser-level "^1.0.1" - classic-level "^1.2.0" - -lilconfig@2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/lilconfig/-/lilconfig-2.1.0.tgz#78e23ac89ebb7e1bfbf25b18043de756548e7f52" - integrity sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ== - -lines-and-columns@^1.1.6: - version "1.2.4" - resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" - integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== - -lint-staged@>=10: - version "13.2.3" - resolved "https://registry.yarnpkg.com/lint-staged/-/lint-staged-13.2.3.tgz#f899aad6c093473467e9c9e316e3c2d8a28f87a7" - integrity sha512-zVVEXLuQIhr1Y7R7YAWx4TZLdvuzk7DnmrsTNL0fax6Z3jrpFcas+vKbzxhhvp6TA55m1SQuWkpzI1qbfDZbAg== - dependencies: - chalk "5.2.0" - cli-truncate "^3.1.0" - commander "^10.0.0" - debug "^4.3.4" - execa "^7.0.0" - lilconfig "2.1.0" - listr2 "^5.0.7" - micromatch "^4.0.5" - normalize-path "^3.0.0" - object-inspect "^1.12.3" - pidtree "^0.6.0" - string-argv "^0.3.1" - yaml "^2.2.2" - -listr2@^5.0.7: - version "5.0.8" - resolved "https://registry.yarnpkg.com/listr2/-/listr2-5.0.8.tgz#a9379ffeb4bd83a68931a65fb223a11510d6ba23" - integrity sha512-mC73LitKHj9w6v30nLNGPetZIlfpUniNSsxxrbaPcWOjDb92SHPzJPi/t+v1YC/lxKz/AJ9egOjww0qUuFxBpA== - dependencies: - cli-truncate "^2.1.0" - colorette "^2.0.19" - log-update "^4.0.0" - p-map "^4.0.0" - rfdc "^1.3.0" - rxjs "^7.8.0" - through "^2.3.8" - wrap-ansi "^7.0.0" - -locate-path@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" - integrity sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA== - dependencies: - p-locate "^2.0.0" - path-exists "^3.0.0" - -locate-path@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" - integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== - dependencies: - p-locate "^3.0.0" - path-exists "^3.0.0" - -locate-path@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" - integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== - dependencies: - p-locate "^5.0.0" - -lodash.camelcase@^4.3.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" - integrity sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA== - -lodash.truncate@^4.4.2: - version "4.4.2" - resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193" - integrity sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw== - -lodash@^4.17.11, lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.21: - version "4.17.21" - resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" - integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== - -log-symbols@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-3.0.0.tgz#f3a08516a5dea893336a7dee14d18a1cfdab77c4" - integrity sha512-dSkNGuI7iG3mfvDzUuYZyvk5dD9ocYCYzNU6CYDE6+Xqd+gwme6Z00NS3dUh8mq/73HaEtT7m6W+yUPtU6BZnQ== - dependencies: - chalk "^2.4.2" - -log-symbols@4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-4.1.0.tgz#3fbdbb95b4683ac9fc785111e792e558d4abd503" - integrity sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg== - dependencies: - chalk "^4.1.0" - is-unicode-supported "^0.1.0" - -log-update@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/log-update/-/log-update-4.0.0.tgz#589ecd352471f2a1c0c570287543a64dfd20e0a1" - integrity sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg== - dependencies: - ansi-escapes "^4.3.0" - cli-cursor "^3.1.0" - slice-ansi "^4.0.0" - wrap-ansi "^6.2.0" - -loupe@^2.3.1: - version "2.3.6" - resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.6.tgz#76e4af498103c532d1ecc9be102036a21f787b53" - integrity sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA== - dependencies: - get-func-name "^2.0.0" - -lru-cache@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920" - integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== - dependencies: - yallist "^3.0.2" - -lru-cache@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" - integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== - dependencies: - yallist "^4.0.0" - -lru_map@^0.3.3: - version "0.3.3" - resolved "https://registry.yarnpkg.com/lru_map/-/lru_map-0.3.3.tgz#b5c8351b9464cbd750335a79650a0ec0e56118dd" - integrity sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ== - -make-error@^1.1.1: - version "1.3.6" - resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" - integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== - -markdown-table@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/markdown-table/-/markdown-table-1.1.3.tgz#9fcb69bcfdb8717bfd0398c6ec2d93036ef8de60" - integrity sha512-1RUZVgQlpJSPWYbFSpmudq5nHY1doEIv89gBtF0s4gW1GF2XorxcA/70M5vq7rLv0a6mhOUccRsqkwhwLCIQ2Q== - -match-all@^1.2.6: - version "1.2.6" - resolved "https://registry.yarnpkg.com/match-all/-/match-all-1.2.6.tgz#66d276ad6b49655551e63d3a6ee53e8be0566f8d" - integrity sha512-0EESkXiTkWzrQQntBu2uzKvLu6vVkUGz40nGPbSZuegcfE5UuSzNjLaIu76zJWuaT/2I3Z/8M06OlUOZLGwLlQ== - -mcl-wasm@^0.7.1: - version "0.7.9" - resolved "https://registry.yarnpkg.com/mcl-wasm/-/mcl-wasm-0.7.9.tgz#c1588ce90042a8700c3b60e40efb339fc07ab87f" - integrity sha512-iJIUcQWA88IJB/5L15GnJVnSQJmf/YaxxV6zRavv83HILHaJQb6y0iFyDMdDO0gN8X37tdxmAOrH/P8B6RB8sQ== - -md5.js@^1.3.4: - version "1.3.5" - resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.5.tgz#b5d07b8e3216e3e27cd728d72f70d1e6a342005f" - integrity sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg== - dependencies: - hash-base "^3.0.0" - inherits "^2.0.1" - safe-buffer "^5.1.2" - -memory-level@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/memory-level/-/memory-level-1.0.0.tgz#7323c3fd368f9af2f71c3cd76ba403a17ac41692" - integrity sha512-UXzwewuWeHBz5krr7EvehKcmLFNoXxGcvuYhC41tRnkrTbJohtS7kVn9akmgirtRygg+f7Yjsfi8Uu5SGSQ4Og== - dependencies: - abstract-level "^1.0.0" - functional-red-black-tree "^1.0.1" - module-error "^1.0.1" - -memorystream@^0.3.1: - version "0.3.1" - resolved "https://registry.yarnpkg.com/memorystream/-/memorystream-0.3.1.tgz#86d7090b30ce455d63fbae12dda51a47ddcaf9b2" - integrity sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw== - -merge-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" - integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== - -merge2@^1.3.0, merge2@^1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" - integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== - -micromatch@^4.0.2, micromatch@^4.0.4, micromatch@^4.0.5: - version "4.0.5" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" - integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== - dependencies: - braces "^3.0.2" - picomatch "^2.3.1" - -mime-db@1.52.0: - version "1.52.0" - resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" - integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== - -mime-types@^2.1.12, mime-types@~2.1.19: - version "2.1.35" - resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" - integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== - dependencies: - mime-db "1.52.0" - -mimic-fn@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" - integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== - -mimic-fn@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-4.0.0.tgz#60a90550d5cb0b239cca65d893b1a53b29871ecc" - integrity sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw== - -minimalistic-assert@^1.0.0, minimalistic-assert@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" - integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== - -minimalistic-crypto-utils@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a" - integrity sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg== - -minimatch@3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" - integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== - dependencies: - brace-expansion "^1.1.7" - -minimatch@5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.0.1.tgz#fb9022f7528125187c92bd9e9b6366be1cf3415b" - integrity sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g== - dependencies: - brace-expansion "^2.0.1" - -minimatch@^3.0.4, minimatch@^3.1.1: - version "3.1.2" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" - integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== - dependencies: - brace-expansion "^1.1.7" - -minimatch@^5.0.1: - version "5.1.6" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" - integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== - dependencies: - brace-expansion "^2.0.1" - -minimist@^1.2.5: - version "1.2.8" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" - integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== - -mkdirp@0.5.5: - version "0.5.5" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" - integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== - dependencies: - minimist "^1.2.5" - -mkdirp@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" - integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== - -mnemonist@^0.38.0: - version "0.38.5" - resolved "https://registry.yarnpkg.com/mnemonist/-/mnemonist-0.38.5.tgz#4adc7f4200491237fe0fa689ac0b86539685cade" - integrity sha512-bZTFT5rrPKtPJxj8KSV0WkPyNxl72vQepqqVUAW2ARUpUSF2qXMB6jZj7hW5/k7C1rtpzqbD/IIbJwLXUjCHeg== - dependencies: - obliterator "^2.0.0" - -mocha@^10.0.0: - version "10.2.0" - resolved "https://registry.yarnpkg.com/mocha/-/mocha-10.2.0.tgz#1fd4a7c32ba5ac372e03a17eef435bd00e5c68b8" - integrity sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg== - dependencies: - ansi-colors "4.1.1" - browser-stdout "1.3.1" - chokidar "3.5.3" - debug "4.3.4" - diff "5.0.0" - escape-string-regexp "4.0.0" - find-up "5.0.0" - glob "7.2.0" - he "1.2.0" - js-yaml "4.1.0" - log-symbols "4.1.0" - minimatch "5.0.1" - ms "2.1.3" - nanoid "3.3.3" - serialize-javascript "6.0.0" - strip-json-comments "3.1.1" - supports-color "8.1.1" - workerpool "6.2.1" - yargs "16.2.0" - yargs-parser "20.2.4" - yargs-unparser "2.0.0" - -mocha@^7.1.1: - version "7.2.0" - resolved "https://registry.yarnpkg.com/mocha/-/mocha-7.2.0.tgz#01cc227b00d875ab1eed03a75106689cfed5a604" - integrity sha512-O9CIypScywTVpNaRrCAgoUnJgozpIofjKUYmJhiCIJMiuYnLI6otcb1/kpW9/n/tJODHGZ7i8aLQoDVsMtOKQQ== - dependencies: - ansi-colors "3.2.3" - browser-stdout "1.3.1" - chokidar "3.3.0" - debug "3.2.6" - diff "3.5.0" - escape-string-regexp "1.0.5" - find-up "3.0.0" - glob "7.1.3" - growl "1.10.5" - he "1.2.0" - js-yaml "3.13.1" - log-symbols "3.0.0" - minimatch "3.0.4" - mkdirp "0.5.5" - ms "2.1.1" - node-environment-flags "1.0.6" - object.assign "4.1.0" - strip-json-comments "2.0.1" - supports-color "6.0.0" - which "1.3.1" - wide-align "1.1.3" - yargs "13.3.2" - yargs-parser "13.1.2" - yargs-unparser "1.6.0" - -module-error@^1.0.1, module-error@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/module-error/-/module-error-1.0.2.tgz#8d1a48897ca883f47a45816d4fb3e3c6ba404d86" - integrity sha512-0yuvsqSCv8LbaOKhnsQ/T5JhyFlCYLPXK3U2sgV10zoKQwzs/MyfuQUOZQ1V/6OCOJsK/TRgNVrPuPDqtdMFtA== - -ms@2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" - integrity sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg== - -ms@2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" - integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== - -ms@2.1.3, ms@^2.1.1: - version "2.1.3" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" - integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== - -murmur-128@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/murmur-128/-/murmur-128-0.2.1.tgz#a9f6568781d2350ecb1bf80c14968cadbeaa4b4d" - integrity sha512-WseEgiRkI6aMFBbj8Cg9yBj/y+OdipwVC7zUo3W2W1JAJITwouUOtpqsmGSg67EQmwwSyod7hsVsWY5LsrfQVg== - dependencies: - encode-utf8 "^1.0.2" - fmix "^0.1.0" - imul "^1.0.0" - -nanoid@3.3.3: - version "3.3.3" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.3.tgz#fd8e8b7aa761fe807dba2d1b98fb7241bb724a25" - integrity sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w== - -napi-macros@^2.2.2: - version "2.2.2" - resolved "https://registry.yarnpkg.com/napi-macros/-/napi-macros-2.2.2.tgz#817fef20c3e0e40a963fbf7b37d1600bd0201044" - integrity sha512-hmEVtAGYzVQpCKdbQea4skABsdXW4RUh5t5mJ2zzqowJS2OyXZTU1KhDVFhx+NlWZ4ap9mqR9TcDO3LTTttd+g== - -neo-async@^2.6.2: - version "2.6.2" - resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" - integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== - -node-addon-api@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-2.0.2.tgz#432cfa82962ce494b132e9d72a15b29f71ff5d32" - integrity sha512-Ntyt4AIXyaLIuMHF6IOoTakB3K+RWxwtsHNRxllEoA6vPwP9o4866g6YWDLUdnucilZhmkxiHwHr11gAENw+QA== - -node-environment-flags@1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/node-environment-flags/-/node-environment-flags-1.0.6.tgz#a30ac13621f6f7d674260a54dede048c3982c088" - integrity sha512-5Evy2epuL+6TM0lCQGpFIj6KwiEsGh1SrHUhTbNX+sLbBtjidPZFAnVK9y5yU1+h//RitLbRHTIMyxQPtxMdHw== - dependencies: - object.getownpropertydescriptors "^2.0.3" - semver "^5.7.0" - -node-gyp-build@^4.2.0, node-gyp-build@^4.3.0: - version "4.6.0" - resolved "https://registry.yarnpkg.com/node-gyp-build/-/node-gyp-build-4.6.0.tgz#0c52e4cbf54bbd28b709820ef7b6a3c2d6209055" - integrity sha512-NTZVKn9IylLwUzaKjkas1e4u2DLNcV4rdYagA4PWdPwW87Bi7z+BznyKSRwS/761tV/lzCGXplWsiaMjLqP2zQ== - -normalize-path@^3.0.0, normalize-path@~3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" - integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== - -npm-run-path@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-5.1.0.tgz#bc62f7f3f6952d9894bd08944ba011a6ee7b7e00" - integrity sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q== - dependencies: - path-key "^4.0.0" - -oauth-sign@~0.9.0: - version "0.9.0" - resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455" - integrity sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ== - -object-assign@^4.1.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" - integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== - -object-inspect@^1.12.3, object-inspect@^1.9.0: - version "1.12.3" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.3.tgz#ba62dffd67ee256c8c086dfae69e016cd1f198b9" - integrity sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g== - -object-keys@^1.0.11, object-keys@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" - integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== - -object.assign@4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.0.tgz#968bf1100d7956bb3ca086f006f846b3bc4008da" - integrity sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w== - dependencies: - define-properties "^1.1.2" - function-bind "^1.1.1" - has-symbols "^1.0.0" - object-keys "^1.0.11" - -object.assign@^4.1.4: - version "4.1.4" - resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" - integrity sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - has-symbols "^1.0.3" - object-keys "^1.1.1" - -object.getownpropertydescriptors@^2.0.3: - version "2.1.6" - resolved "https://registry.yarnpkg.com/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.6.tgz#5e5c384dd209fa4efffead39e3a0512770ccc312" - integrity sha512-lq+61g26E/BgHv0ZTFgRvi7NMEPuAxLkFU7rukXjc/AlwH4Am5xXVnIXy3un1bg/JPbXHrixRkK1itUzzPiIjQ== - dependencies: - array.prototype.reduce "^1.0.5" - call-bind "^1.0.2" - define-properties "^1.2.0" - es-abstract "^1.21.2" - safe-array-concat "^1.0.0" - -obliterator@^2.0.0: - version "2.0.4" - resolved "https://registry.yarnpkg.com/obliterator/-/obliterator-2.0.4.tgz#fa650e019b2d075d745e44f1effeb13a2adbe816" - integrity sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ== - -once@^1.3.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" - integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== - dependencies: - wrappy "1" - -onetime@^5.1.0: - version "5.1.2" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" - integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== - dependencies: - mimic-fn "^2.1.0" - -onetime@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-6.0.0.tgz#7c24c18ed1fd2e9bca4bd26806a33613c77d34b4" - integrity sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ== - dependencies: - mimic-fn "^4.0.0" - -ordinal@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/ordinal/-/ordinal-1.0.3.tgz#1a3c7726a61728112f50944ad7c35c06ae3a0d4d" - integrity sha512-cMddMgb2QElm8G7vdaa02jhUNbTSrhsgAGUz1OokD83uJTwSUn+nKoNoKVVaRa08yF6sgfO7Maou1+bgLd9rdQ== - -os-tmpdir@~1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" - integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== - -p-limit@^1.1.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.3.0.tgz#b86bd5f0c25690911c7590fcbfc2010d54b3ccb8" - integrity sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q== - dependencies: - p-try "^1.0.0" - -p-limit@^2.0.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" - integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== - dependencies: - p-try "^2.0.0" - -p-limit@^3.0.2: - version "3.1.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" - integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== - dependencies: - yocto-queue "^0.1.0" - -p-locate@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" - integrity sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg== - dependencies: - p-limit "^1.1.0" - -p-locate@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" - integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== - dependencies: - p-limit "^2.0.0" - -p-locate@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" - integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== - dependencies: - p-limit "^3.0.2" - -p-map@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" - integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== - dependencies: - aggregate-error "^3.0.0" - -p-try@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz#cbc79cdbaf8fd4228e13f621f2b1a237c1b207b3" - integrity sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww== - -p-try@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" - integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== - -parent-module@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" - integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== - dependencies: - callsites "^3.0.0" - -parse-cache-control@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/parse-cache-control/-/parse-cache-control-1.0.1.tgz#8eeab3e54fa56920fe16ba38f77fa21aacc2d74e" - integrity sha512-60zvsJReQPX5/QP0Kzfd/VrpjScIQ7SHBW6bFCYfEP+fp0Eppr1SHhIO5nd1PjZtvclzSzES9D/p5nFJurwfWg== - -parse-json@^5.0.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" - integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== - dependencies: - "@babel/code-frame" "^7.0.0" - error-ex "^1.3.1" - json-parse-even-better-errors "^2.3.0" - lines-and-columns "^1.1.6" - -path-exists@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" - integrity sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ== - -path-exists@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" - integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== - -path-is-absolute@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" - integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== - -path-key@^3.1.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" - integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== - -path-key@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-4.0.0.tgz#295588dc3aee64154f877adb9d780b81c554bf18" - integrity sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ== - -path-parse@^1.0.6: - version "1.0.7" - resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" - integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== - -path-type@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" - integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== - -pathval@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/pathval/-/pathval-1.1.1.tgz#8534e77a77ce7ac5a2512ea21e0fdb8fcf6c3d8d" - integrity sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ== - -pbkdf2@^3.0.17: - version "3.1.2" - resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.1.2.tgz#dd822aa0887580e52f1a039dc3eda108efae3075" - integrity sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA== - dependencies: - create-hash "^1.1.2" - create-hmac "^1.1.4" - ripemd160 "^2.0.1" - safe-buffer "^5.0.1" - sha.js "^2.4.8" - -performance-now@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" - integrity sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow== - -picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" - integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== - -pidtree@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/pidtree/-/pidtree-0.6.0.tgz#90ad7b6d42d5841e69e0a2419ef38f8883aa057c" - integrity sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g== - -pluralize@^8.0.0: - version "8.0.0" - resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-8.0.0.tgz#1a6fa16a38d12a1901e0320fa017051c539ce3b1" - integrity sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA== - -prettier-plugin-solidity@^1.0.0-beta.19: - version "1.1.3" - resolved "https://registry.yarnpkg.com/prettier-plugin-solidity/-/prettier-plugin-solidity-1.1.3.tgz#9a35124f578404caf617634a8cab80862d726cba" - integrity sha512-fQ9yucPi2sBbA2U2Xjh6m4isUTJ7S7QLc/XDDsktqqxYfTwdYKJ0EnnywXHwCGAaYbQNK+HIYPL1OemxuMsgeg== - dependencies: - "@solidity-parser/parser" "^0.16.0" - semver "^7.3.8" - solidity-comments-extractor "^0.0.7" - -prettier@^2.1.2, prettier@^2.5.1, prettier@^2.8.3: - version "2.8.8" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.8.tgz#e8c5d7e98a4305ffe3de2e1fc4aca1a71c28b1da" - integrity sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q== - -process-nextick-args@~2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" - integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== - -promise@^8.0.0: - version "8.3.0" - resolved "https://registry.yarnpkg.com/promise/-/promise-8.3.0.tgz#8cb333d1edeb61ef23869fbb8a4ea0279ab60e0a" - integrity sha512-rZPNPKTOYVNEEKFaq1HqTgOwZD+4/YHS5ukLzQCypkj+OkYx7iv0mA91lJlpPPZ8vMau3IIGj5Qlwrx+8iiSmg== - dependencies: - asap "~2.0.6" - -psl@^1.1.28: - version "1.9.0" - resolved "https://registry.yarnpkg.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" - integrity sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag== - -punycode@^2.1.0, punycode@^2.1.1: - version "2.3.0" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.0.tgz#f67fa67c94da8f4d0cfff981aee4118064199b8f" - integrity sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA== - -qs@^6.4.0, qs@^6.7.0, qs@^6.9.4: - version "6.11.2" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.11.2.tgz#64bea51f12c1f5da1bc01496f48ffcff7c69d7d9" - integrity sha512-tDNIz22aBzCDxLtVH++VnTfzxlfeK5CbqohpSqpJgj1Wg/cQbStNAz3NuqCs5vV+pjBsK4x4pN9HlVh7rcYRiA== - dependencies: - side-channel "^1.0.4" - -qs@~6.5.2: - version "6.5.3" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" - integrity sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA== - -queue-microtask@^1.2.2, queue-microtask@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" - integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== - -randombytes@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" - integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== - dependencies: - safe-buffer "^5.1.0" - -raw-body@^2.4.1: - version "2.5.2" - resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.2.tgz#99febd83b90e08975087e8f1f9419a149366b68a" - integrity sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA== - dependencies: - bytes "3.1.2" - http-errors "2.0.0" - iconv-lite "0.4.24" - unpipe "1.0.0" - -readable-stream@^2.2.2: - version "2.3.8" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.8.tgz#91125e8042bba1b9887f49345f6277027ce8be9b" - integrity sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA== - dependencies: - core-util-is "~1.0.0" - inherits "~2.0.3" - isarray "~1.0.0" - process-nextick-args "~2.0.0" - safe-buffer "~5.1.1" - string_decoder "~1.1.1" - util-deprecate "~1.0.1" - -readable-stream@^3.6.0: - version "3.6.2" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" - integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - -readdirp@~3.2.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.2.0.tgz#c30c33352b12c96dfb4b895421a49fd5a9593839" - integrity sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ== - dependencies: - picomatch "^2.0.4" - -readdirp@~3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" - integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== - dependencies: - picomatch "^2.2.1" - -reduce-flatten@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/reduce-flatten/-/reduce-flatten-2.0.0.tgz#734fd84e65f375d7ca4465c69798c25c9d10ae27" - integrity sha512-EJ4UNY/U1t2P/2k6oqotuX2Cc3T6nxJwsM0N0asT7dhrtH1ltUxDn4NalSYmPE2rCkVpcf/X6R0wDwcFpzhd4w== - -regexp.prototype.flags@^1.5.0: - version "1.5.0" - resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.0.tgz#fe7ce25e7e4cca8db37b6634c8a2c7009199b9cb" - integrity sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA== - dependencies: - call-bind "^1.0.2" - define-properties "^1.2.0" - functions-have-names "^1.2.3" - -req-cwd@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/req-cwd/-/req-cwd-2.0.0.tgz#d4082b4d44598036640fb73ddea01ed53db49ebc" - integrity sha512-ueoIoLo1OfB6b05COxAA9UpeoscNpYyM+BqYlA7H6LVF4hKGPXQQSSaD2YmvDVJMkk4UDpAHIeU1zG53IqjvlQ== - dependencies: - req-from "^2.0.0" - -req-from@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/req-from/-/req-from-2.0.0.tgz#d74188e47f93796f4aa71df6ee35ae689f3e0e70" - integrity sha512-LzTfEVDVQHBRfjOUMgNBA+V6DWsSnoeKzf42J7l0xa/B4jyPOuuF5MlNSmomLNGemWTnV2TIdjSSLnEn95fOQA== - dependencies: - resolve-from "^3.0.0" - -request-promise-core@1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/request-promise-core/-/request-promise-core-1.1.4.tgz#3eedd4223208d419867b78ce815167d10593a22f" - integrity sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw== - dependencies: - lodash "^4.17.19" - -request-promise-native@^1.0.5: - version "1.0.9" - resolved "https://registry.yarnpkg.com/request-promise-native/-/request-promise-native-1.0.9.tgz#e407120526a5efdc9a39b28a5679bf47b9d9dc28" - integrity sha512-wcW+sIUiWnKgNY0dqCpOZkUbF/I+YPi+f09JZIDa39Ec+q82CpSYniDp+ISgTTbKmnpJWASeJBPZmoxH84wt3g== - dependencies: - request-promise-core "1.1.4" - stealthy-require "^1.1.1" - tough-cookie "^2.3.3" - -request@^2.88.0: - version "2.88.2" - resolved "https://registry.yarnpkg.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3" - integrity sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw== - dependencies: - aws-sign2 "~0.7.0" - aws4 "^1.8.0" - caseless "~0.12.0" - combined-stream "~1.0.6" - extend "~3.0.2" - forever-agent "~0.6.1" - form-data "~2.3.2" - har-validator "~5.1.3" - http-signature "~1.2.0" - is-typedarray "~1.0.0" - isstream "~0.1.2" - json-stringify-safe "~5.0.1" - mime-types "~2.1.19" - oauth-sign "~0.9.0" - performance-now "^2.1.0" - qs "~6.5.2" - safe-buffer "^5.1.2" - tough-cookie "~2.5.0" - tunnel-agent "^0.6.0" - uuid "^3.3.2" - -require-directory@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" - integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== - -require-from-string@^2.0.0, require-from-string@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" - integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== - -require-main-filename@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b" - integrity sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg== - -resolve-from@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748" - integrity sha512-GnlH6vxLymXJNMBo7XP1fJIzBFbdYt49CuTwmB/6N53t+kMPRMFKz783LlQ4tv28XoQfMWinAJX6WCGf2IlaIw== - -resolve-from@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" - integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== - -resolve@1.17.0: - version "1.17.0" - resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.17.0.tgz#b25941b54968231cc2d1bb76a79cb7f2c0bf8444" - integrity sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w== - dependencies: - path-parse "^1.0.6" - -restore-cursor@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-3.1.0.tgz#39f67c54b3a7a58cea5236d95cf0034239631f7e" - integrity sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA== - dependencies: - onetime "^5.1.0" - signal-exit "^3.0.2" - -reusify@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" - integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== - -rfdc@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/rfdc/-/rfdc-1.3.0.tgz#d0b7c441ab2720d05dc4cf26e01c89631d9da08b" - integrity sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA== - -rimraf@^2.2.8: - version "2.7.1" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== - dependencies: - glob "^7.1.3" - -rimraf@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" - integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== - dependencies: - glob "^7.1.3" - -ripemd160@^2.0.0, ripemd160@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.2.tgz#a1c1a6f624751577ba5d07914cbc92850585890c" - integrity sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA== - dependencies: - hash-base "^3.0.0" - inherits "^2.0.1" - -rlp@^2.2.3: - version "2.2.7" - resolved "https://registry.yarnpkg.com/rlp/-/rlp-2.2.7.tgz#33f31c4afac81124ac4b283e2bd4d9720b30beaf" - integrity sha512-d5gdPmgQ0Z+AklL2NVXr/IoSjNZFfTVvQWzL/AM2AOcSzYP2xjlb0AC8YyCLc41MSNf6P6QVtjgPdmVtzb+4lQ== - dependencies: - bn.js "^5.2.0" - -run-parallel-limit@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/run-parallel-limit/-/run-parallel-limit-1.1.0.tgz#be80e936f5768623a38a963262d6bef8ff11e7ba" - integrity sha512-jJA7irRNM91jaKc3Hcl1npHsFLOXOoTkPCUL1JEa1R82O2miplXXRaGdjW/KM/98YQWDhJLiSs793CnXfblJUw== - dependencies: - queue-microtask "^1.2.2" - -run-parallel@^1.1.9: - version "1.2.0" - resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" - integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== - dependencies: - queue-microtask "^1.2.2" - -rustbn.js@~0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/rustbn.js/-/rustbn.js-0.2.0.tgz#8082cb886e707155fd1cb6f23bd591ab8d55d0ca" - integrity sha512-4VlvkRUuCJvr2J6Y0ImW7NvTCriMi7ErOAqWk1y69vAdoNIzCF3yPmgeNzx+RQTLEDFq5sHfscn1MwHxP9hNfA== - -rxjs@^7.8.0: - version "7.8.1" - resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-7.8.1.tgz#6f6f3d99ea8044291efd92e7c7fcf562c4057543" - integrity sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg== - dependencies: - tslib "^2.1.0" - -safe-array-concat@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/safe-array-concat/-/safe-array-concat-1.0.0.tgz#2064223cba3c08d2ee05148eedbc563cd6d84060" - integrity sha512-9dVEFruWIsnie89yym+xWTAYASdpw3CJV7Li/6zBewGf9z2i1j31rP6jnY0pHEO4QZh6N0K11bFjWmdR8UGdPQ== - dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.2.0" - has-symbols "^1.0.3" - isarray "^2.0.5" - -safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@^5.1.2, safe-buffer@^5.2.0, safe-buffer@~5.2.0: - version "5.2.1" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" - integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== - -safe-buffer@~5.1.0, safe-buffer@~5.1.1: - version "5.1.2" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== - -safe-regex-test@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.0.tgz#793b874d524eb3640d1873aad03596db2d4f2295" - integrity sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA== - dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.1.3" - is-regex "^1.1.4" - -"safer-buffer@>= 2.1.2 < 3", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: - version "2.1.2" - resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" - integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== - -scrypt-js@2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-2.0.4.tgz#32f8c5149f0797672e551c07e230f834b6af5f16" - integrity sha512-4KsaGcPnuhtCZQCxFxN3GVYIhKFPTdLd8PLC552XwbMndtD0cjRFAhDuuydXQ0h08ZfPgzqe6EKHozpuH74iDw== - -scrypt-js@3.0.1, scrypt-js@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/scrypt-js/-/scrypt-js-3.0.1.tgz#d314a57c2aef69d1ad98a138a21fe9eafa9ee312" - integrity sha512-cdwTTnqPu0Hyvf5in5asVdZocVDTNRmR7XEcJuIzMjJeSHybHl7vpB66AzwTaIg6CLSbtjcxc8fqcySfnTkccA== - -secp256k1@^4.0.1: - version "4.0.3" - resolved "https://registry.yarnpkg.com/secp256k1/-/secp256k1-4.0.3.tgz#c4559ecd1b8d3c1827ed2d1b94190d69ce267303" - integrity sha512-NLZVf+ROMxwtEj3Xa562qgv2BK5e2WNmXPiOdVIPLgs6lyTzMvBq0aWTYMI5XCP9jZMVKOcqZLw/Wc4vDkuxhA== - dependencies: - elliptic "^6.5.4" - node-addon-api "^2.0.0" - node-gyp-build "^4.2.0" - -semver@^5.5.0, semver@^5.7.0: - version "5.7.2" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.2.tgz#48d55db737c3287cd4835e17fa13feace1c41ef8" - integrity sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g== - -semver@^6.3.0: - version "6.3.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" - integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== - -semver@^7.3.2, semver@^7.3.8, semver@^7.5.4: - version "7.5.4" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" - integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== - dependencies: - lru-cache "^6.0.0" - -serialize-javascript@6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" - integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== - dependencies: - randombytes "^2.1.0" - -set-blocking@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" - integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== - -setimmediate@1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.4.tgz#20e81de622d4a02588ce0c8da8973cbcf1d3138f" - integrity sha512-/TjEmXQVEzdod/FFskf3o7oOAsGhHf2j1dZqRFbDzq4F3mvvxflIIi4Hd3bLQE9y/CpwqfSQam5JakI/mi3Pog== - -setimmediate@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" - integrity sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA== - -setprototypeof@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" - integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== - -sha.js@^2.4.0, sha.js@^2.4.8: - version "2.4.11" - resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.11.tgz#37a5cf0b81ecbc6943de109ba2960d1b26584ae7" - integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== - dependencies: - inherits "^2.0.1" - safe-buffer "^5.0.1" - -sha1@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/sha1/-/sha1-1.1.1.tgz#addaa7a93168f393f19eb2b15091618e2700f848" - integrity sha512-dZBS6OrMjtgVkopB1Gmo4RQCDKiZsqcpAQpkV/aaj+FCrCg8r4I4qMkDPQjBgLIxlmu9k4nUbWq6ohXahOneYA== - dependencies: - charenc ">= 0.0.1" - crypt ">= 0.0.1" - -shebang-command@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" - integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== - dependencies: - shebang-regex "^3.0.0" - -shebang-regex@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" - integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== - -side-channel@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" - integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== - dependencies: - call-bind "^1.0.0" - get-intrinsic "^1.0.2" - object-inspect "^1.9.0" - -signal-exit@^3.0.2, signal-exit@^3.0.7: - version "3.0.7" - resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" - integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== - -simple-wcswidth@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/simple-wcswidth/-/simple-wcswidth-1.0.1.tgz#8ab18ac0ae342f9d9b629604e54d2aa1ecb018b2" - integrity sha512-xMO/8eNREtaROt7tJvWJqHBDTMFN4eiQ5I4JRMuilwfnFcV5W9u7RUkueNkdw0jPqGMX36iCywelS5yilTuOxg== - -slash@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" - integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== - -slice-ansi@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-3.0.0.tgz#31ddc10930a1b7e0b67b08c96c2f49b77a789787" - integrity sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ== - dependencies: - ansi-styles "^4.0.0" - astral-regex "^2.0.0" - is-fullwidth-code-point "^3.0.0" - -slice-ansi@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b" - integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ== - dependencies: - ansi-styles "^4.0.0" - astral-regex "^2.0.0" - is-fullwidth-code-point "^3.0.0" - -slice-ansi@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-5.0.0.tgz#b73063c57aa96f9cd881654b15294d95d285c42a" - integrity sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ== - dependencies: - ansi-styles "^6.0.0" - is-fullwidth-code-point "^4.0.0" +# This file is generated by running "yarn install" inside your project. +# Manual changes might be lost - proceed with caution! + +__metadata: + version: 6 + cacheKey: 8 + +"@babel/code-frame@npm:^7.0.0": + version: 7.22.5 + resolution: "@babel/code-frame@npm:7.22.5" + dependencies: + "@babel/highlight": ^7.22.5 + checksum: cfe804f518f53faaf9a1d3e0f9f74127ab9a004912c3a16fda07fb6a633393ecb9918a053cb71804204c1b7ec3d49e1699604715e2cfb0c9f7bc4933d324ebb6 + languageName: node + linkType: hard + +"@babel/helper-validator-identifier@npm:^7.22.5": + version: 7.22.5 + resolution: "@babel/helper-validator-identifier@npm:7.22.5" + checksum: 7f0f30113474a28298c12161763b49de5018732290ca4de13cdaefd4fd0d635a6fe3f6686c37a02905fb1e64f21a5ee2b55140cf7b070e729f1bd66866506aea + languageName: node + linkType: hard + +"@babel/highlight@npm:^7.22.5": + version: 7.22.5 + resolution: "@babel/highlight@npm:7.22.5" + dependencies: + "@babel/helper-validator-identifier": ^7.22.5 + chalk: ^2.0.0 + js-tokens: ^4.0.0 + checksum: f61ae6de6ee0ea8d9b5bcf2a532faec5ab0a1dc0f7c640e5047fc61630a0edb88b18d8c92eb06566d30da7a27db841aca11820ecd3ebe9ce514c9350fbed39c4 + languageName: node + linkType: hard + +"@chainsafe/as-sha256@npm:^0.3.1": + version: 0.3.1 + resolution: "@chainsafe/as-sha256@npm:0.3.1" + checksum: 58ea733be1657b0e31dbf48b0dba862da0833df34a81c1460c7352f04ce90874f70003cbf34d0afb9e5e53a33ee2d63a261a8b12462be85b2ba0a6f7f13d6150 + languageName: node + linkType: hard + +"@chainsafe/persistent-merkle-tree@npm:^0.4.2": + version: 0.4.2 + resolution: "@chainsafe/persistent-merkle-tree@npm:0.4.2" + dependencies: + "@chainsafe/as-sha256": ^0.3.1 + checksum: f9cfcb2132a243992709715dbd28186ab48c7c0c696f29d30857693cca5526bf753974a505ef68ffd5623bbdbcaa10f9083f4dd40bf99eb6408e451cc26a1a9e + languageName: node + linkType: hard + +"@chainsafe/persistent-merkle-tree@npm:^0.5.0": + version: 0.5.0 + resolution: "@chainsafe/persistent-merkle-tree@npm:0.5.0" + dependencies: + "@chainsafe/as-sha256": ^0.3.1 + checksum: 2c67203da776c79cd3a6132e2d672fe132393b2e63dc71604e3134acc8c0ec25cc5e431051545939ea0f7c5ff2066fb806b9e5cab974ca085d046226a1671f7d + languageName: node + linkType: hard + +"@chainsafe/ssz@npm:^0.10.0": + version: 0.10.2 + resolution: "@chainsafe/ssz@npm:0.10.2" + dependencies: + "@chainsafe/as-sha256": ^0.3.1 + "@chainsafe/persistent-merkle-tree": ^0.5.0 + checksum: 6bb70cf741d0a19dd0b28b3f6f067b96fa39f556e2eefa6ac745b21db9c3b3a8393dc3cca8ff4a6ce065ed71ddc3fb1b2b390a92004b9d01067c26e2558e5503 + languageName: node + linkType: hard + +"@chainsafe/ssz@npm:^0.9.2": + version: 0.9.4 + resolution: "@chainsafe/ssz@npm:0.9.4" + dependencies: + "@chainsafe/as-sha256": ^0.3.1 + "@chainsafe/persistent-merkle-tree": ^0.4.2 + case: ^1.6.3 + checksum: c6eaedeae9e5618b3c666ff4507a27647f665a8dcf17d5ca86da4ed4788c5a93868f256d0005467d184fdf35ec03f323517ec2e55ec42492d769540a2ec396bc + languageName: node + linkType: hard + +"@colors/colors@npm:1.5.0": + version: 1.5.0 + resolution: "@colors/colors@npm:1.5.0" + checksum: d64d5260bed1d5012ae3fc617d38d1afc0329fec05342f4e6b838f46998855ba56e0a73833f4a80fa8378c84810da254f76a8a19c39d038260dc06dc4e007425 + languageName: node + linkType: hard + +"@cspotcode/source-map-support@npm:^0.8.0": + version: 0.8.1 + resolution: "@cspotcode/source-map-support@npm:0.8.1" + dependencies: + "@jridgewell/trace-mapping": 0.3.9 + checksum: 5718f267085ed8edb3e7ef210137241775e607ee18b77d95aa5bd7514f47f5019aa2d82d96b3bf342ef7aa890a346fa1044532ff7cc3009e7d24fce3ce6200fa + languageName: node + linkType: hard + +"@ethersproject/abi@npm:5.7.0, @ethersproject/abi@npm:^5.0.0-beta.146, @ethersproject/abi@npm:^5.1.2, @ethersproject/abi@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/abi@npm:5.7.0" + dependencies: + "@ethersproject/address": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/hash": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + checksum: bc6962bb6cb854e4d2a4d65b2c49c716477675b131b1363312234bdbb7e19badb7d9ce66f4ca2a70ae2ea84f7123dbc4e300a1bfe5d58864a7eafabc1466627e + languageName: node + linkType: hard + +"@ethersproject/abstract-provider@npm:5.7.0, @ethersproject/abstract-provider@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/abstract-provider@npm:5.7.0" + dependencies: + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/networks": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + "@ethersproject/web": ^5.7.0 + checksum: 74cf4696245cf03bb7cc5b6cbf7b4b89dd9a79a1c4688126d214153a938126d4972d42c93182198653ce1de35f2a2cad68be40337d4774b3698a39b28f0228a8 + languageName: node + linkType: hard + +"@ethersproject/abstract-signer@npm:5.7.0, @ethersproject/abstract-signer@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/abstract-signer@npm:5.7.0" + dependencies: + "@ethersproject/abstract-provider": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + checksum: a823dac9cfb761e009851050ebebd5b229d1b1cc4a75b125c2da130ff37e8218208f7f9d1386f77407705b889b23d4a230ad67185f8872f083143e0073cbfbe3 + languageName: node + linkType: hard + +"@ethersproject/address@npm:5.7.0, @ethersproject/address@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/address@npm:5.7.0" + dependencies: + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/rlp": ^5.7.0 + checksum: 64ea5ebea9cc0e845c413e6cb1e54e157dd9fc0dffb98e239d3a3efc8177f2ff798cd4e3206cf3660ee8faeb7bef1a47dc0ebef0d7b132c32e61e550c7d4c843 + languageName: node + linkType: hard + +"@ethersproject/base64@npm:5.7.0, @ethersproject/base64@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/base64@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + checksum: 7dd5d734d623582f08f665434f53685041a3d3b334a0e96c0c8afa8bbcaab934d50e5b6b980e826a8fde8d353e0b18f11e61faf17468177274b8e7c69cd9742b + languageName: node + linkType: hard + +"@ethersproject/basex@npm:5.7.0, @ethersproject/basex@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/basex@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + checksum: 326087b7e1f3787b5fe6cd1cf2b4b5abfafbc355a45e88e22e5e9d6c845b613ffc5301d629b28d5c4d5e2bfe9ec424e6782c804956dff79be05f0098cb5817de + languageName: node + linkType: hard + +"@ethersproject/bignumber@npm:5.7.0, @ethersproject/bignumber@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/bignumber@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + bn.js: ^5.2.1 + checksum: 8c9a134b76f3feb4ec26a5a27379efb4e156b8fb2de0678a67788a91c7f4e30abe9d948638458e4b20f2e42380da0adacc7c9389d05fce070692edc6ae9b4904 + languageName: node + linkType: hard + +"@ethersproject/bytes@npm:5.7.0, @ethersproject/bytes@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/bytes@npm:5.7.0" + dependencies: + "@ethersproject/logger": ^5.7.0 + checksum: 66ad365ceaab5da1b23b72225c71dce472cf37737af5118181fa8ab7447d696bea15ca22e3a0e8836fdd8cfac161afe321a7c67d0dde96f9f645ddd759676621 + languageName: node + linkType: hard + +"@ethersproject/constants@npm:5.7.0, @ethersproject/constants@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/constants@npm:5.7.0" + dependencies: + "@ethersproject/bignumber": ^5.7.0 + checksum: 6d4b1355747cce837b3e76ec3bde70e4732736f23b04f196f706ebfa5d4d9c2be50904a390d4d40ce77803b98d03d16a9b6898418e04ba63491933ce08c4ba8a + languageName: node + linkType: hard + +"@ethersproject/contracts@npm:5.7.0, @ethersproject/contracts@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/contracts@npm:5.7.0" + dependencies: + "@ethersproject/abi": ^5.7.0 + "@ethersproject/abstract-provider": ^5.7.0 + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + checksum: 6ccf1121cba01b31e02f8c507cb971ab6bfed85706484a9ec09878ef1594a62215f43c4fdef8f4a4875b99c4a800bc95e3be69b1803f8ce479e07634b5a740c0 + languageName: node + linkType: hard + +"@ethersproject/hash@npm:5.7.0, @ethersproject/hash@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/hash@npm:5.7.0" + dependencies: + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/base64": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + checksum: 6e9fa8d14eb08171cd32f17f98cc108ec2aeca74a427655f0d689c550fee0b22a83b3b400fad7fb3f41cf14d4111f87f170aa7905bcbcd1173a55f21b06262ef + languageName: node + linkType: hard + +"@ethersproject/hdnode@npm:5.7.0, @ethersproject/hdnode@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/hdnode@npm:5.7.0" + dependencies: + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/basex": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/pbkdf2": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/sha2": ^5.7.0 + "@ethersproject/signing-key": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + "@ethersproject/wordlists": ^5.7.0 + checksum: bfe5ca2d89a42de73655f853170ef4766b933c5f481cddad709b3aca18823275b096e572f92d1602a052f80b426edde44ad6b9d028799775a7dad4a5bbed2133 + languageName: node + linkType: hard + +"@ethersproject/json-wallets@npm:5.7.0, @ethersproject/json-wallets@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/json-wallets@npm:5.7.0" + dependencies: + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/hdnode": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/pbkdf2": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/random": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + aes-js: 3.0.0 + scrypt-js: 3.0.1 + checksum: f583458d22db62efaaf94d38dd243482776a45bf90f9f3882fbad5aa0b8fd288b41eb7c1ff8ec0b99c9b751088e43d6173530db64dd33c59f9d8daa8d7ad5aa2 + languageName: node + linkType: hard + +"@ethersproject/keccak256@npm:5.7.0, @ethersproject/keccak256@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/keccak256@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + js-sha3: 0.8.0 + checksum: ff70950d82203aab29ccda2553422cbac2e7a0c15c986bd20a69b13606ed8bb6e4fdd7b67b8d3b27d4f841e8222cbaccd33ed34be29f866fec7308f96ed244c6 + languageName: node + linkType: hard + +"@ethersproject/logger@npm:5.7.0, @ethersproject/logger@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/logger@npm:5.7.0" + checksum: 075ab2f605f1fd0813f2e39c3308f77b44a67732b36e712d9bc085f22a84aac4da4f71b39bee50fe78da3e1c812673fadc41180c9970fe5e486e91ea17befe0d + languageName: node + linkType: hard + +"@ethersproject/networks@npm:5.7.1, @ethersproject/networks@npm:^5.7.0": + version: 5.7.1 + resolution: "@ethersproject/networks@npm:5.7.1" + dependencies: + "@ethersproject/logger": ^5.7.0 + checksum: 0339f312304c17d9a0adce550edb825d4d2c8c9468c1634c44172c67a9ed256f594da62c4cda5c3837a0f28b7fabc03aca9b492f68ff1fdad337ee861b27bd5d + languageName: node + linkType: hard + +"@ethersproject/pbkdf2@npm:5.7.0, @ethersproject/pbkdf2@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/pbkdf2@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/sha2": ^5.7.0 + checksum: b895adb9e35a8a127e794f7aadc31a2424ef355a70e51cde10d457e3e888bb8102373199a540cf61f2d6b9a32e47358f9c65b47d559f42bf8e596b5fd67901e9 + languageName: node + linkType: hard + +"@ethersproject/properties@npm:5.7.0, @ethersproject/properties@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/properties@npm:5.7.0" + dependencies: + "@ethersproject/logger": ^5.7.0 + checksum: 6ab0ccf0c3aadc9221e0cdc5306ce6cd0df7f89f77d77bccdd1277182c9ead0202cd7521329ba3acde130820bf8af299e17cf567d0d497c736ee918207bbf59f + languageName: node + linkType: hard + +"@ethersproject/providers@npm:5.7.2, @ethersproject/providers@npm:^5.7.1, @ethersproject/providers@npm:^5.7.2": + version: 5.7.2 + resolution: "@ethersproject/providers@npm:5.7.2" + dependencies: + "@ethersproject/abstract-provider": ^5.7.0 + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/base64": ^5.7.0 + "@ethersproject/basex": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/hash": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/networks": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/random": ^5.7.0 + "@ethersproject/rlp": ^5.7.0 + "@ethersproject/sha2": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + "@ethersproject/web": ^5.7.0 + bech32: 1.1.4 + ws: 7.4.6 + checksum: 1754c731a5ca6782ae9677f4a9cd8b6246c4ef21a966c9a01b133750f3c578431ec43ec254e699969c4a0f87e84463ded50f96b415600aabd37d2056aee58c19 + languageName: node + linkType: hard + +"@ethersproject/random@npm:5.7.0, @ethersproject/random@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/random@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + checksum: 017829c91cff6c76470852855108115b0b52c611b6be817ed1948d56ba42d6677803ec2012aa5ae298a7660024156a64c11fcf544e235e239ab3f89f0fff7345 + languageName: node + linkType: hard + +"@ethersproject/rlp@npm:5.7.0, @ethersproject/rlp@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/rlp@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + checksum: bce165b0f7e68e4d091c9d3cf47b247cac33252df77a095ca4281d32d5eeaaa3695d9bc06b2b057c5015353a68df89f13a4a54a72e888e4beeabbe56b15dda6e + languageName: node + linkType: hard + +"@ethersproject/sha2@npm:5.7.0, @ethersproject/sha2@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/sha2@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + hash.js: 1.1.7 + checksum: 09321057c022effbff4cc2d9b9558228690b5dd916329d75c4b1ffe32ba3d24b480a367a7cc92d0f0c0b1c896814d03351ae4630e2f1f7160be2bcfbde435dbc + languageName: node + linkType: hard + +"@ethersproject/signing-key@npm:5.7.0, @ethersproject/signing-key@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/signing-key@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + bn.js: ^5.2.1 + elliptic: 6.5.4 + hash.js: 1.1.7 + checksum: 8f8de09b0aac709683bbb49339bc0a4cd2f95598f3546436c65d6f3c3a847ffa98e06d35e9ed2b17d8030bd2f02db9b7bd2e11c5cf8a71aad4537487ab4cf03a + languageName: node + linkType: hard + +"@ethersproject/solidity@npm:5.7.0, @ethersproject/solidity@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/solidity@npm:5.7.0" + dependencies: + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/sha2": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + checksum: 9a02f37f801c96068c3e7721f83719d060175bc4e80439fe060e92bd7acfcb6ac1330c7e71c49f4c2535ca1308f2acdcb01e00133129aac00581724c2d6293f3 + languageName: node + linkType: hard + +"@ethersproject/strings@npm:5.7.0, @ethersproject/strings@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/strings@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + checksum: 5ff78693ae3fdf3cf23e1f6dc047a61e44c8197d2408c42719fef8cb7b7b3613a4eec88ac0ed1f9f5558c74fe0de7ae3195a29ca91a239c74b9f444d8e8b50df + languageName: node + linkType: hard + +"@ethersproject/transactions@npm:5.7.0, @ethersproject/transactions@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/transactions@npm:5.7.0" + dependencies: + "@ethersproject/address": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/rlp": ^5.7.0 + "@ethersproject/signing-key": ^5.7.0 + checksum: a31b71996d2b283f68486241bff0d3ea3f1ba0e8f1322a8fffc239ccc4f4a7eb2ea9994b8fd2f093283fd75f87bae68171e01b6265261f821369aca319884a79 + languageName: node + linkType: hard + +"@ethersproject/units@npm:5.7.0": + version: 5.7.0 + resolution: "@ethersproject/units@npm:5.7.0" + dependencies: + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + checksum: 304714f848cd32e57df31bf545f7ad35c2a72adae957198b28cbc62166daa929322a07bff6e9c9ac4577ab6aa0de0546b065ed1b2d20b19e25748b7d475cb0fc + languageName: node + linkType: hard + +"@ethersproject/wallet@npm:5.7.0, @ethersproject/wallet@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/wallet@npm:5.7.0" + dependencies: + "@ethersproject/abstract-provider": ^5.7.0 + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/hash": ^5.7.0 + "@ethersproject/hdnode": ^5.7.0 + "@ethersproject/json-wallets": ^5.7.0 + "@ethersproject/keccak256": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/random": ^5.7.0 + "@ethersproject/signing-key": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + "@ethersproject/wordlists": ^5.7.0 + checksum: a4009bf7331eddab38e3015b5e9101ef92de7f705b00a6196b997db0e5635b6d83561674d46c90c6f77b87c0500fe4a6b0183ba13749efc22db59c99deb82fbd + languageName: node + linkType: hard + +"@ethersproject/web@npm:5.7.1, @ethersproject/web@npm:^5.7.0": + version: 5.7.1 + resolution: "@ethersproject/web@npm:5.7.1" + dependencies: + "@ethersproject/base64": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + checksum: 7028c47103f82fd2e2c197ce0eecfacaa9180ffeec7de7845b1f4f9b19d84081b7a48227aaddde05a4aaa526af574a9a0ce01cc0fc75e3e371f84b38b5b16b2b + languageName: node + linkType: hard + +"@ethersproject/wordlists@npm:5.7.0, @ethersproject/wordlists@npm:^5.7.0": + version: 5.7.0 + resolution: "@ethersproject/wordlists@npm:5.7.0" + dependencies: + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/hash": ^5.7.0 + "@ethersproject/logger": ^5.7.0 + "@ethersproject/properties": ^5.7.0 + "@ethersproject/strings": ^5.7.0 + checksum: 30eb6eb0731f9ef5faa44bf9c0c6e950bcaaef61e4d2d9ce0ae6d341f4e2d6d1f4ab4f8880bfce03b7aac4b862fb740e1421170cfbf8e2aafc359277d49e6e97 + languageName: node + linkType: hard + +"@isaacs/cliui@npm:^8.0.2": + version: 8.0.2 + resolution: "@isaacs/cliui@npm:8.0.2" + dependencies: + string-width: ^5.1.2 + string-width-cjs: "npm:string-width@^4.2.0" + strip-ansi: ^7.0.1 + strip-ansi-cjs: "npm:strip-ansi@^6.0.1" + wrap-ansi: ^8.1.0 + wrap-ansi-cjs: "npm:wrap-ansi@^7.0.0" + checksum: 4a473b9b32a7d4d3cfb7a614226e555091ff0c5a29a1734c28c72a182c2f6699b26fc6b5c2131dfd841e86b185aea714c72201d7c98c2fba5f17709333a67aeb + languageName: node + linkType: hard + +"@jridgewell/resolve-uri@npm:^3.0.3": + version: 3.1.1 + resolution: "@jridgewell/resolve-uri@npm:3.1.1" + checksum: f5b441fe7900eab4f9155b3b93f9800a916257f4e8563afbcd3b5a5337b55e52bd8ae6735453b1b745457d9f6cdb16d74cd6220bbdd98cf153239e13f6cbb653 + languageName: node + linkType: hard + +"@jridgewell/sourcemap-codec@npm:^1.4.10": + version: 1.4.15 + resolution: "@jridgewell/sourcemap-codec@npm:1.4.15" + checksum: b881c7e503db3fc7f3c1f35a1dd2655a188cc51a3612d76efc8a6eb74728bef5606e6758ee77423e564092b4a518aba569bbb21c9bac5ab7a35b0c6ae7e344c8 + languageName: node + linkType: hard + +"@jridgewell/trace-mapping@npm:0.3.9": + version: 0.3.9 + resolution: "@jridgewell/trace-mapping@npm:0.3.9" + dependencies: + "@jridgewell/resolve-uri": ^3.0.3 + "@jridgewell/sourcemap-codec": ^1.4.10 + checksum: d89597752fd88d3f3480845691a05a44bd21faac18e2185b6f436c3b0fd0c5a859fbbd9aaa92050c4052caf325ad3e10e2e1d1b64327517471b7d51babc0ddef + languageName: node + linkType: hard + +"@metamask/eth-sig-util@npm:^4.0.0": + version: 4.0.1 + resolution: "@metamask/eth-sig-util@npm:4.0.1" + dependencies: + ethereumjs-abi: ^0.6.8 + ethereumjs-util: ^6.2.1 + ethjs-util: ^0.1.6 + tweetnacl: ^1.0.3 + tweetnacl-util: ^0.15.1 + checksum: 740df4c92a1282e6be4c00c86c1a8ccfb93e767596e43f6da895aa5bab4a28fc3c2209f0327db34924a4a1e9db72bc4d3dddfcfc45cca0b218c9ccbf7d1b1445 + languageName: node + linkType: hard + +"@noble/hashes@npm:1.2.0, @noble/hashes@npm:~1.2.0": + version: 1.2.0 + resolution: "@noble/hashes@npm:1.2.0" + checksum: 8ca080ce557b8f40fb2f78d3aedffd95825a415ac8e13d7ffe3643f8626a8c2d99a3e5975b555027ac24316d8b3c02a35b8358567c0c23af681e6573602aa434 + languageName: node + linkType: hard + +"@noble/secp256k1@npm:1.7.1, @noble/secp256k1@npm:~1.7.0": + version: 1.7.1 + resolution: "@noble/secp256k1@npm:1.7.1" + checksum: d2301f1f7690368d8409a3152450458f27e54df47e3f917292de3de82c298770890c2de7c967d237eff9c95b70af485389a9695f73eb05a43e2bd562d18b18cb + languageName: node + linkType: hard + +"@nodelib/fs.scandir@npm:2.1.5": + version: 2.1.5 + resolution: "@nodelib/fs.scandir@npm:2.1.5" + dependencies: + "@nodelib/fs.stat": 2.0.5 + run-parallel: ^1.1.9 + checksum: a970d595bd23c66c880e0ef1817791432dbb7acbb8d44b7e7d0e7a22f4521260d4a83f7f9fd61d44fda4610105577f8f58a60718105fb38352baed612fd79e59 + languageName: node + linkType: hard + +"@nodelib/fs.stat@npm:2.0.5, @nodelib/fs.stat@npm:^2.0.2": + version: 2.0.5 + resolution: "@nodelib/fs.stat@npm:2.0.5" + checksum: 012480b5ca9d97bff9261571dbbec7bbc6033f69cc92908bc1ecfad0792361a5a1994bc48674b9ef76419d056a03efadfce5a6cf6dbc0a36559571a7a483f6f0 + languageName: node + linkType: hard + +"@nodelib/fs.walk@npm:^1.2.3": + version: 1.2.8 + resolution: "@nodelib/fs.walk@npm:1.2.8" + dependencies: + "@nodelib/fs.scandir": 2.1.5 + fastq: ^1.6.0 + checksum: 190c643f156d8f8f277bf2a6078af1ffde1fd43f498f187c2db24d35b4b4b5785c02c7dc52e356497b9a1b65b13edc996de08de0b961c32844364da02986dc53 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-block@npm:5.0.1": + version: 5.0.1 + resolution: "@nomicfoundation/ethereumjs-block@npm:5.0.1" + dependencies: + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-trie": 6.0.1 + "@nomicfoundation/ethereumjs-tx": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + ethereum-cryptography: 0.1.3 + ethers: ^5.7.1 + checksum: 02591bc9ba02b56edc5faf75a7991d6b9430bd98542864f2f6ab202f0f4aed09be156fdba60948375beb10e524ffa4e461475edc8a15b3098b1c58ff59a0137e + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-blockchain@npm:7.0.1": + version: 7.0.1 + resolution: "@nomicfoundation/ethereumjs-blockchain@npm:7.0.1" + dependencies: + "@nomicfoundation/ethereumjs-block": 5.0.1 + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-ethash": 3.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-trie": 6.0.1 + "@nomicfoundation/ethereumjs-tx": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + abstract-level: ^1.0.3 + debug: ^4.3.3 + ethereum-cryptography: 0.1.3 + level: ^8.0.0 + lru-cache: ^5.1.1 + memory-level: ^1.0.0 + checksum: 8b7a4e3613c2abbf59e92a927cb074d1df8640fbf6a0ec4be7fcb5ecaead1310ebbe3a41613c027253742f6dccca6eaeee8dde0a38315558de156313d0c8f313 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-common@npm:4.0.1": + version: 4.0.1 + resolution: "@nomicfoundation/ethereumjs-common@npm:4.0.1" + dependencies: + "@nomicfoundation/ethereumjs-util": 9.0.1 + crc-32: ^1.2.0 + checksum: af5b599bcc07430b57017e516b0bad70af04e812b970be9bfae0c1d3433ab26656b3d1db71717b3b0fb38a889db2b93071b45adc1857000e7cd58a99a8e29495 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-ethash@npm:3.0.1": + version: 3.0.1 + resolution: "@nomicfoundation/ethereumjs-ethash@npm:3.0.1" + dependencies: + "@nomicfoundation/ethereumjs-block": 5.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + abstract-level: ^1.0.3 + bigint-crypto-utils: ^3.0.23 + ethereum-cryptography: 0.1.3 + checksum: beeec9788a9ed57020ee47271447715bdc0a98990a0bd0e9d598c6de74ade836db17c0590275e6aab12fa9b0fbd81f1d02e3cdf1fb8497583cec693ec3ed6aed + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-evm@npm:2.0.1": + version: 2.0.1 + resolution: "@nomicfoundation/ethereumjs-evm@npm:2.0.1" + dependencies: + "@ethersproject/providers": ^5.7.1 + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-tx": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + debug: ^4.3.3 + ethereum-cryptography: 0.1.3 + mcl-wasm: ^0.7.1 + rustbn.js: ~0.2.0 + checksum: 0aa2e1460e1c311506fd3bf9d03602c7c3a5e03f352173a55a274a9cc1840bd774692d1c4e5c6e82a7eee015a7cf1585f1c5be02cfdf54cc2a771421820e3f84 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-rlp@npm:5.0.1": + version: 5.0.1 + resolution: "@nomicfoundation/ethereumjs-rlp@npm:5.0.1" + bin: + rlp: bin/rlp + checksum: 5a51d2cf92b84e50ce516cbdadff5d39cb4c6b71335e92eaf447dfb7d88f5499d78d599024b9252efd7ba99495de36f4d983cec6a89e77db286db691fc6328f7 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-statemanager@npm:2.0.1": + version: 2.0.1 + resolution: "@nomicfoundation/ethereumjs-statemanager@npm:2.0.1" + dependencies: + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + debug: ^4.3.3 + ethereum-cryptography: 0.1.3 + ethers: ^5.7.1 + js-sdsl: ^4.1.4 + checksum: 157b503fa3e45a3695ba2eba5b089b56719f7790274edd09c95bb0d223570820127f6a2cbfcb14f2d9d876d1440ea4dccb04a4922fa9e9e34b416fddd6517c20 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-trie@npm:6.0.1": + version: 6.0.1 + resolution: "@nomicfoundation/ethereumjs-trie@npm:6.0.1" + dependencies: + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + "@types/readable-stream": ^2.3.13 + ethereum-cryptography: 0.1.3 + readable-stream: ^3.6.0 + checksum: 7001c3204120fd4baba673b4bb52015594f5ad28311f24574cd16f38c015ef87ed51188d6f46d6362ffb9da589359a9e0f99e6068ef7a2f61cb66213e2f493d7 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-tx@npm:5.0.1": + version: 5.0.1 + resolution: "@nomicfoundation/ethereumjs-tx@npm:5.0.1" + dependencies: + "@chainsafe/ssz": ^0.9.2 + "@ethersproject/providers": ^5.7.2 + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + ethereum-cryptography: 0.1.3 + checksum: aa3829e4a43f5e10cfd66b87eacb3e737ba98f5e3755a3e6a4ccfbc257dbf10d926838cc3acb8fef8afa3362a023b7fd11b53e6ba53f94bb09c345f083cd29a8 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-util@npm:9.0.1": + version: 9.0.1 + resolution: "@nomicfoundation/ethereumjs-util@npm:9.0.1" + dependencies: + "@chainsafe/ssz": ^0.10.0 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + ethereum-cryptography: 0.1.3 + checksum: 5f8a50a25c68c974b717f36ad0a5828b786ce1aaea3c874663c2014593fa387de5ad5c8cea35e94379df306dbd1a58c55b310779fd82197dcb993d5dbd4de7a1 + languageName: node + linkType: hard + +"@nomicfoundation/ethereumjs-vm@npm:7.0.1": + version: 7.0.1 + resolution: "@nomicfoundation/ethereumjs-vm@npm:7.0.1" + dependencies: + "@nomicfoundation/ethereumjs-block": 5.0.1 + "@nomicfoundation/ethereumjs-blockchain": 7.0.1 + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-evm": 2.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-statemanager": 2.0.1 + "@nomicfoundation/ethereumjs-trie": 6.0.1 + "@nomicfoundation/ethereumjs-tx": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + debug: ^4.3.3 + ethereum-cryptography: 0.1.3 + mcl-wasm: ^0.7.1 + rustbn.js: ~0.2.0 + checksum: 0f637316322744140d6f75d894c21b8055e27a94c72dd8ae9b0b9b93c0d54d7f30fa2aaf909e802e183a3f1020b4aa6a8178dedb823a4ce70a227ac7b432f8c1 + languageName: node + linkType: hard + +"@nomicfoundation/hardhat-chai-matchers@npm:^1.0.3": + version: 1.0.6 + resolution: "@nomicfoundation/hardhat-chai-matchers@npm:1.0.6" + dependencies: + "@ethersproject/abi": ^5.1.2 + "@types/chai-as-promised": ^7.1.3 + chai-as-promised: ^7.1.1 + deep-eql: ^4.0.1 + ordinal: ^1.0.3 + peerDependencies: + "@nomiclabs/hardhat-ethers": ^2.0.0 + chai: ^4.2.0 + ethers: ^5.0.0 + hardhat: ^2.9.4 + checksum: c388e5ed9068f2ba7c227737ab7312dd03405d5fab195247b061f2fa52e700fbd0fb65359c2d4f2086f2905bfca642c19a9122d034533edd936f89aea65ac7f2 + languageName: node + linkType: hard + +"@nomicfoundation/hardhat-foundry@npm:^1.0.1": + version: 1.0.2 + resolution: "@nomicfoundation/hardhat-foundry@npm:1.0.2" + dependencies: + chalk: ^2.4.2 + peerDependencies: + hardhat: ^2.12.6 + checksum: a1f75fe156d7c333859f342aeeb35a036743540f878392d2f75f162d7e33738f32eae0e108def1182c0ae5ce1f2c7790bdf0195227701475deadb90a92b562e7 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-darwin-arm64@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-darwin-arm64@npm:0.1.1" + conditions: os=darwin & cpu=arm64 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-darwin-x64@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-darwin-x64@npm:0.1.1" + conditions: os=darwin & cpu=x64 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-freebsd-x64@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-freebsd-x64@npm:0.1.1" + conditions: os=freebsd & cpu=x64 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-linux-arm64-gnu@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-linux-arm64-gnu@npm:0.1.1" + conditions: os=linux & cpu=arm64 & libc=glibc + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-linux-arm64-musl@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-linux-arm64-musl@npm:0.1.1" + conditions: os=linux & cpu=arm64 & libc=musl + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-linux-x64-gnu@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-linux-x64-gnu@npm:0.1.1" + conditions: os=linux & cpu=x64 & libc=glibc + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-linux-x64-musl@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-linux-x64-musl@npm:0.1.1" + conditions: os=linux & cpu=x64 & libc=musl + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-win32-arm64-msvc@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-win32-arm64-msvc@npm:0.1.1" + conditions: os=win32 & cpu=arm64 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-win32-ia32-msvc@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-win32-ia32-msvc@npm:0.1.1" + conditions: os=win32 & cpu=ia32 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer-win32-x64-msvc@npm:0.1.1": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer-win32-x64-msvc@npm:0.1.1" + conditions: os=win32 & cpu=x64 + languageName: node + linkType: hard + +"@nomicfoundation/solidity-analyzer@npm:^0.1.0": + version: 0.1.1 + resolution: "@nomicfoundation/solidity-analyzer@npm:0.1.1" + dependencies: + "@nomicfoundation/solidity-analyzer-darwin-arm64": 0.1.1 + "@nomicfoundation/solidity-analyzer-darwin-x64": 0.1.1 + "@nomicfoundation/solidity-analyzer-freebsd-x64": 0.1.1 + "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": 0.1.1 + "@nomicfoundation/solidity-analyzer-linux-arm64-musl": 0.1.1 + "@nomicfoundation/solidity-analyzer-linux-x64-gnu": 0.1.1 + "@nomicfoundation/solidity-analyzer-linux-x64-musl": 0.1.1 + "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": 0.1.1 + "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": 0.1.1 + "@nomicfoundation/solidity-analyzer-win32-x64-msvc": 0.1.1 + dependenciesMeta: + "@nomicfoundation/solidity-analyzer-darwin-arm64": + optional: true + "@nomicfoundation/solidity-analyzer-darwin-x64": + optional: true + "@nomicfoundation/solidity-analyzer-freebsd-x64": + optional: true + "@nomicfoundation/solidity-analyzer-linux-arm64-gnu": + optional: true + "@nomicfoundation/solidity-analyzer-linux-arm64-musl": + optional: true + "@nomicfoundation/solidity-analyzer-linux-x64-gnu": + optional: true + "@nomicfoundation/solidity-analyzer-linux-x64-musl": + optional: true + "@nomicfoundation/solidity-analyzer-win32-arm64-msvc": + optional: true + "@nomicfoundation/solidity-analyzer-win32-ia32-msvc": + optional: true + "@nomicfoundation/solidity-analyzer-win32-x64-msvc": + optional: true + checksum: 038cffafd5769e25256b5b8bef88d95cc1c021274a65c020cf84aceb3237752a3b51645fdb0687f5516a2bdfebf166fcf50b08ab64857925100213e0654b266b + languageName: node + linkType: hard + +"@nomiclabs/hardhat-ethers@npm:^2.0.3": + version: 2.2.3 + resolution: "@nomiclabs/hardhat-ethers@npm:2.2.3" + peerDependencies: + ethers: ^5.0.0 + hardhat: ^2.0.0 + checksum: 72321317e55eb510306e04c42353c5f7ceb42d086fc76cc740120da6e1635b7ad5bbf23a8d6b02bd590754adcf646618933111624085ab249b1ff3482e773226 + languageName: node + linkType: hard + +"@npmcli/fs@npm:^3.1.0": + version: 3.1.0 + resolution: "@npmcli/fs@npm:3.1.0" + dependencies: + semver: ^7.3.5 + checksum: a50a6818de5fc557d0b0e6f50ec780a7a02ab8ad07e5ac8b16bf519e0ad60a144ac64f97d05c443c3367235d337182e1d012bbac0eb8dbae8dc7b40b193efd0e + languageName: node + linkType: hard + +"@oclif/command@npm:^1.8.0, @oclif/command@npm:^1.8.15": + version: 1.8.35 + resolution: "@oclif/command@npm:1.8.35" + dependencies: + "@oclif/config": ^1.18.2 + "@oclif/errors": ^1.3.6 + "@oclif/help": ^1.0.1 + "@oclif/parser": ^3.8.16 + debug: ^4.1.1 + semver: ^7.5.4 + peerDependencies: + "@oclif/config": ^1 + checksum: f983c2440251e8740623190af0dcda159ac139f21125703949abbd1f7c9cb218dfc53baf6de991fb0834b0c57da28d76f8a95e2dd3006e0bcf59c9d5301fba07 + languageName: node + linkType: hard + +"@oclif/config@npm:1.18.15": + version: 1.18.15 + resolution: "@oclif/config@npm:1.18.15" + dependencies: + "@oclif/errors": ^1.3.6 + "@oclif/parser": ^3.8.15 + debug: ^4.3.4 + globby: ^11.1.0 + is-wsl: ^2.1.1 + tslib: ^2.5.0 + checksum: 242d6575b45b90bd360a69b2a52676d6b2fe75400d01b572e5e125c6f6585273aa3fbe61fbf9dace130b76a6593adfeff5728a322a1af811f2c2e177a9f701af + languageName: node + linkType: hard + +"@oclif/config@npm:1.18.2": + version: 1.18.2 + resolution: "@oclif/config@npm:1.18.2" + dependencies: + "@oclif/errors": ^1.3.3 + "@oclif/parser": ^3.8.0 + debug: ^4.1.1 + globby: ^11.0.1 + is-wsl: ^2.1.1 + tslib: ^2.0.0 + checksum: edb82ae885bb5a7a244d99707f837f8f0c7a3286a9f19e6cda2af599a06c189c21221082acde9927dadf951d060bdc05bee9ea5f9e8223c12688956b94c3b1e0 + languageName: node + linkType: hard + +"@oclif/config@npm:^1.17.0, @oclif/config@npm:^1.18.2": + version: 1.18.16 + resolution: "@oclif/config@npm:1.18.16" + dependencies: + "@oclif/errors": ^1.3.6 + "@oclif/parser": ^3.8.16 + debug: ^4.3.4 + globby: ^11.1.0 + is-wsl: ^2.1.1 + tslib: ^2.6.1 + checksum: 951aa32b8938ec29575abaddc4bb6b96c68f6efb74821a83ee2105c8c73923001c26cd1f68c004192cb55b6dde647bfa420d0913bff02111efb2a4bbb26f2149 + languageName: node + linkType: hard + +"@oclif/errors@npm:1.3.5": + version: 1.3.5 + resolution: "@oclif/errors@npm:1.3.5" + dependencies: + clean-stack: ^3.0.0 + fs-extra: ^8.1 + indent-string: ^4.0.0 + strip-ansi: ^6.0.0 + wrap-ansi: ^7.0.0 + checksum: abce216ff1321ac4924fe405c50e9b2a93cfb51ad229d7e6ced8ee1c4bd01a85ee270b4433a12c73da9394dd8e9f6ec73443f8582da7ac46379b7e4991c3fa50 + languageName: node + linkType: hard + +"@oclif/errors@npm:1.3.6, @oclif/errors@npm:^1.3.3, @oclif/errors@npm:^1.3.6": + version: 1.3.6 + resolution: "@oclif/errors@npm:1.3.6" + dependencies: + clean-stack: ^3.0.0 + fs-extra: ^8.1 + indent-string: ^4.0.0 + strip-ansi: ^6.0.1 + wrap-ansi: ^7.0.0 + checksum: be9f686e30f91f792aeaba635e2473da5494c1d25bf98a55ff766aca52b78fd3cb2c75902b6c24f21d6c893841a45a69367645971e793cc677d643eeb39f146f + languageName: node + linkType: hard + +"@oclif/help@npm:^1.0.1": + version: 1.0.14 + resolution: "@oclif/help@npm:1.0.14" + dependencies: + "@oclif/config": 1.18.15 + "@oclif/errors": 1.3.6 + chalk: ^4.1.2 + indent-string: ^4.0.0 + lodash: ^4.17.21 + string-width: ^4.2.0 + strip-ansi: ^6.0.0 + widest-line: ^3.1.0 + wrap-ansi: ^6.2.0 + checksum: 9a631cf0535c1d6d0c3955904115a6aa9c4e625044f4aface416080b9aba209f457f5fa83dddbc29ca47777cadf476d94f47ba1403b286a7a157f08cdb35181a + languageName: node + linkType: hard + +"@oclif/linewrap@npm:^1.0.0": + version: 1.0.0 + resolution: "@oclif/linewrap@npm:1.0.0" + checksum: a072016a58b5e1331bbc21303ad5100fcda846ac4b181e344aec88bb24c5da09c416651e51313ffcc846a83514b74b8b987dd965982900f3edbb42b4e87cc246 + languageName: node + linkType: hard + +"@oclif/parser@npm:^3.8.0, @oclif/parser@npm:^3.8.15, @oclif/parser@npm:^3.8.16": + version: 3.8.16 + resolution: "@oclif/parser@npm:3.8.16" + dependencies: + "@oclif/errors": ^1.3.6 + "@oclif/linewrap": ^1.0.0 + chalk: ^4.1.0 + tslib: ^2.6.1 + checksum: 4ef723704efe53bee1a006d2ab866ae9178162851c813a5ab078569f52f4c153f352033213cd171d53a9d457eac2b45889db7f8af512ada28d80fcf8963d5f49 + languageName: node + linkType: hard + +"@oclif/plugin-help@npm:^3.2.0": + version: 3.3.1 + resolution: "@oclif/plugin-help@npm:3.3.1" + dependencies: + "@oclif/command": ^1.8.15 + "@oclif/config": 1.18.2 + "@oclif/errors": 1.3.5 + "@oclif/help": ^1.0.1 + chalk: ^4.1.2 + indent-string: ^4.0.0 + lodash: ^4.17.21 + string-width: ^4.2.0 + strip-ansi: ^6.0.0 + widest-line: ^3.1.0 + wrap-ansi: ^6.2.0 + checksum: 07c67a9ed32ea05a6407823325fac7379fdea2cd0b688ef927d6265f695c1e3707d13de6a706e2af5b1949ea4beb5720d11feb87e1f4323bfe5948846766d9e2 + languageName: node + linkType: hard + +"@openzeppelin/contracts@npm:4.7.3": + version: 4.7.3 + resolution: "@openzeppelin/contracts@npm:4.7.3" + checksum: 18382fcacf7cfd652f5dd0e70c08f08ea74eaa8ff11e9f9850639ada70198ae01a3f9493d89a52d724f2db394e9616bf6258017804612ba273167cf657fbb073 + languageName: node + linkType: hard + +"@pkgjs/parseargs@npm:^0.11.0": + version: 0.11.0 + resolution: "@pkgjs/parseargs@npm:0.11.0" + checksum: 6ad6a00fc4f2f2cfc6bff76fb1d88b8ee20bc0601e18ebb01b6d4be583733a860239a521a7fbca73b612e66705078809483549d2b18f370eb346c5155c8e4a0f + languageName: node + linkType: hard + +"@scure/base@npm:~1.1.0": + version: 1.1.1 + resolution: "@scure/base@npm:1.1.1" + checksum: b4fc810b492693e7e8d0107313ac74c3646970c198bbe26d7332820886fa4f09441991023ec9aa3a2a51246b74409ab5ebae2e8ef148bbc253da79ac49130309 + languageName: node + linkType: hard + +"@scure/bip32@npm:1.1.5": + version: 1.1.5 + resolution: "@scure/bip32@npm:1.1.5" + dependencies: + "@noble/hashes": ~1.2.0 + "@noble/secp256k1": ~1.7.0 + "@scure/base": ~1.1.0 + checksum: b08494ab0d2b1efee7226d1b5100db5157ebea22a78bb87126982a76a186cb3048413e8be0ba2622d00d048a20acbba527af730de86c132a77de616eb9907a3b + languageName: node + linkType: hard + +"@scure/bip39@npm:1.1.1": + version: 1.1.1 + resolution: "@scure/bip39@npm:1.1.1" + dependencies: + "@noble/hashes": ~1.2.0 + "@scure/base": ~1.1.0 + checksum: fbb594c50696fa9c14e891d872f382e50a3f919b6c96c55ef2fb10c7102c546dafb8f099a62bd114c12a00525b595dcf7381846f383f0ddcedeaa6e210747d2f + languageName: node + linkType: hard + +"@sentry/core@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/core@npm:5.30.0" + dependencies: + "@sentry/hub": 5.30.0 + "@sentry/minimal": 5.30.0 + "@sentry/types": 5.30.0 + "@sentry/utils": 5.30.0 + tslib: ^1.9.3 + checksum: 8a2b22687e70d76fa4381bce215d770b6c08561c5ff5d6afe39c8c3c509c18ee7384ad0be3aee18d3a858a3c88e1d2821cf10eb5e05646376a33200903b56da2 + languageName: node + linkType: hard + +"@sentry/hub@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/hub@npm:5.30.0" + dependencies: + "@sentry/types": 5.30.0 + "@sentry/utils": 5.30.0 + tslib: ^1.9.3 + checksum: 09f778cc78765213f1e35a3ee6da3a8e02a706e8a7e5b7f84614707f4b665c7297b700a1849ab2ca1f02ede5884fd9ae893e58dc65f04f35ccdfee17e99ee93d + languageName: node + linkType: hard + +"@sentry/minimal@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/minimal@npm:5.30.0" + dependencies: + "@sentry/hub": 5.30.0 + "@sentry/types": 5.30.0 + tslib: ^1.9.3 + checksum: 934650f6989ce51f425c7c4b4d4d9bfecface8162a36d21df8a241f780ab1716dd47b81e2170e4cc624797ed1eebe10f71e4876c1e25b787860daaef75ca7a0c + languageName: node + linkType: hard + +"@sentry/node@npm:^5.18.1": + version: 5.30.0 + resolution: "@sentry/node@npm:5.30.0" + dependencies: + "@sentry/core": 5.30.0 + "@sentry/hub": 5.30.0 + "@sentry/tracing": 5.30.0 + "@sentry/types": 5.30.0 + "@sentry/utils": 5.30.0 + cookie: ^0.4.1 + https-proxy-agent: ^5.0.0 + lru_map: ^0.3.3 + tslib: ^1.9.3 + checksum: 5f0367cc52f9d716c64ba727e2a5c8592364494c8fdadfb3df2d0ee9d7956b886fb3ec674370292d2a7b7e1d9a8e1b84c69c06e8a4a064be8d4687698df0090c + languageName: node + linkType: hard + +"@sentry/tracing@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/tracing@npm:5.30.0" + dependencies: + "@sentry/hub": 5.30.0 + "@sentry/minimal": 5.30.0 + "@sentry/types": 5.30.0 + "@sentry/utils": 5.30.0 + tslib: ^1.9.3 + checksum: 720c07b111e8128e70a939ab4e9f9cfd13dc23303b27575afddabab08d08f9b94499017c76a9ffe253bf3ca40833e8f9262cf6dc546ba24da6eb74fedae5f92b + languageName: node + linkType: hard + +"@sentry/types@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/types@npm:5.30.0" + checksum: de7df777824c8e311f143c6fd7de220b24f25b5018312fe8f67d93bebf0f3cdd32bbca9f155846f5c31441d940eebe27c8338000321559a743264c7e41dda560 + languageName: node + linkType: hard + +"@sentry/utils@npm:5.30.0": + version: 5.30.0 + resolution: "@sentry/utils@npm:5.30.0" + dependencies: + "@sentry/types": 5.30.0 + tslib: ^1.9.3 + checksum: 27b259a136c664427641dd32ee3dc490553f3b5e92986accfa829d14063ebc69b191e92209ac9c40fbc367f74cfa17dc93b4c40981d666711fd57b4d51a82062 + languageName: node + linkType: hard + +"@solidity-parser/parser@npm:^0.14.0": + version: 0.14.5 + resolution: "@solidity-parser/parser@npm:0.14.5" + dependencies: + antlr4ts: ^0.5.0-alpha.4 + checksum: 9e85a0d4f8a05a11db6022444b70b2f353e2358467b1cce44cdda703ae1e3c7337e1b8cbc2eec8e14a8f34f9c60b42f325e5fe9b3c934cc980e35091e292d7ee + languageName: node + linkType: hard + +"@solidity-parser/parser@npm:^0.16.0": + version: 0.16.1 + resolution: "@solidity-parser/parser@npm:0.16.1" + dependencies: + antlr4ts: ^0.5.0-alpha.4 + checksum: d9e2f7042434fb850a97a2c3679f5fbf4997c7845278d0a436b3de30169e6758fe3818191694ece36dc39a40f55ae0384c4ae0ae912790b5b0806728a50466c2 + languageName: node + linkType: hard + +"@solidstate/hardhat-4byte-uploader@npm:^1.1.0": + version: 1.1.0 + resolution: "@solidstate/hardhat-4byte-uploader@npm:1.1.0" + dependencies: + axios: ^0.24.0 + peerDependencies: + hardhat: ^2.0.0 + checksum: 2e0ca60717f1fbbd16b077ee66ff02e56b18fc883914d373bb6de33dec994bc9cf45c55944a5c954bcaa209d4bf7578fae6993063e9e66ccff9459d8d40cd976 + languageName: node + linkType: hard + +"@tootallnate/once@npm:2": + version: 2.0.0 + resolution: "@tootallnate/once@npm:2.0.0" + checksum: ad87447820dd3f24825d2d947ebc03072b20a42bfc96cbafec16bff8bbda6c1a81fcb0be56d5b21968560c5359a0af4038a68ba150c3e1694fe4c109a063bed8 + languageName: node + linkType: hard + +"@tsconfig/node10@npm:^1.0.7": + version: 1.0.9 + resolution: "@tsconfig/node10@npm:1.0.9" + checksum: a33ae4dc2a621c0678ac8ac4bceb8e512ae75dac65417a2ad9b022d9b5411e863c4c198b6ba9ef659e14b9fb609bbec680841a2e84c1172df7a5ffcf076539df + languageName: node + linkType: hard + +"@tsconfig/node12@npm:^1.0.7": + version: 1.0.11 + resolution: "@tsconfig/node12@npm:1.0.11" + checksum: 5ce29a41b13e7897a58b8e2df11269c5395999e588b9a467386f99d1d26f6c77d1af2719e407621412520ea30517d718d5192a32403b8dfcc163bf33e40a338a + languageName: node + linkType: hard + +"@tsconfig/node14@npm:^1.0.0": + version: 1.0.3 + resolution: "@tsconfig/node14@npm:1.0.3" + checksum: 19275fe80c4c8d0ad0abed6a96dbf00642e88b220b090418609c4376e1cef81bf16237bf170ad1b341452feddb8115d8dd2e5acdfdea1b27422071163dc9ba9d + languageName: node + linkType: hard + +"@tsconfig/node16@npm:^1.0.2": + version: 1.0.4 + resolution: "@tsconfig/node16@npm:1.0.4" + checksum: 202319785901f942a6e1e476b872d421baec20cf09f4b266a1854060efbf78cde16a4d256e8bc949d31e6cd9a90f1e8ef8fb06af96a65e98338a2b6b0de0a0ff + languageName: node + linkType: hard + +"@typechain/ethers-v5@npm:^8.0.5": + version: 8.0.5 + resolution: "@typechain/ethers-v5@npm:8.0.5" + dependencies: + lodash: ^4.17.15 + ts-essentials: ^7.0.1 + peerDependencies: + "@ethersproject/abi": ^5.0.0 + "@ethersproject/bytes": ^5.0.0 + "@ethersproject/providers": ^5.0.0 + ethers: ^5.1.3 + typechain: ^6.0.4 + typescript: ">=4.0.0" + checksum: d6c0f3114a9b853b6288ca00406f21e2ade75908cac8e230510be1d130c05da5a239923428cf221d547d2f9d79bdf234285f070948e62d4f87526e8ab433215b + languageName: node + linkType: hard + +"@typechain/hardhat@npm:^3.0.0": + version: 3.1.0 + resolution: "@typechain/hardhat@npm:3.1.0" + dependencies: + fs-extra: ^9.1.0 + peerDependencies: + hardhat: ^2.0.10 + lodash: ^4.17.15 + typechain: ^6.0.0 + checksum: 5eced0650fcfd7b0c4f118153aaa384bf0820659c05c701f0afbf64db3aa0e1755862dff0b0a5dd6cfea22d904dc3a3c3d4101adc925aadf6aced4b4006895e7 + languageName: node + linkType: hard + +"@types/bn.js@npm:^4.11.3": + version: 4.11.6 + resolution: "@types/bn.js@npm:4.11.6" + dependencies: + "@types/node": "*" + checksum: 7f66f2c7b7b9303b3205a57184261974b114495736b77853af5b18d857c0b33e82ce7146911e86e87a87837de8acae28986716fd381ac7c301fd6e8d8b6c811f + languageName: node + linkType: hard + +"@types/bn.js@npm:^5.1.0": + version: 5.1.1 + resolution: "@types/bn.js@npm:5.1.1" + dependencies: + "@types/node": "*" + checksum: e50ed2dd3abe997e047caf90e0352c71e54fc388679735217978b4ceb7e336e51477791b715f49fd77195ac26dd296c7bad08a3be9750e235f9b2e1edb1b51c2 + languageName: node + linkType: hard + +"@types/chai-as-promised@npm:^7.1.3": + version: 7.1.5 + resolution: "@types/chai-as-promised@npm:7.1.5" + dependencies: + "@types/chai": "*" + checksum: 7c1345c6e32513d52d8e562ec173c23161648d6b792046525f18803a9932d7b3ad3dca8f0181e3c529ec42b106099f174e34edeb184d61dc93e32c98b5132fd4 + languageName: node + linkType: hard + +"@types/chai@npm:*, @types/chai@npm:^4.3.0": + version: 4.3.5 + resolution: "@types/chai@npm:4.3.5" + checksum: c8f26a88c6b5b53a3275c7f5ff8f107028e3cbb9ff26795fff5f3d9dea07106a54ce9e2dce5e40347f7c4cc35657900aaf0c83934a25a1ae12e61e0f5516e431 + languageName: node + linkType: hard + +"@types/concat-stream@npm:^1.6.0": + version: 1.6.1 + resolution: "@types/concat-stream@npm:1.6.1" + dependencies: + "@types/node": "*" + checksum: 7d211e74331affd3578b5469244f5cef84a93775f38332adb3ef12413559a23862bc682c6873d0a404b01c9d5d5f7d3ae091fe835b435b633eb420e3055b3e56 + languageName: node + linkType: hard + +"@types/form-data@npm:0.0.33": + version: 0.0.33 + resolution: "@types/form-data@npm:0.0.33" + dependencies: + "@types/node": "*" + checksum: f0c283fdef2dd7191168a37b9cb2625af3cfbd7f72b5a514f938bea0a135669f79d736186d434b9e81150b47ef1bf20d97b188014a00583556fad6ce59fb9bbf + languageName: node + linkType: hard + +"@types/fs-extra@npm:11.0.1": + version: 11.0.1 + resolution: "@types/fs-extra@npm:11.0.1" + dependencies: + "@types/jsonfile": "*" + "@types/node": "*" + checksum: 3e930346e5d84f419deb8ced1c582beef8cb20d0bd8a0eb145a37d75bab0572a1895f0e48a0d681d386b3a58b9a992b2d2acecc464bcaec2548f53ea00718651 + languageName: node + linkType: hard + +"@types/jsonfile@npm:*": + version: 6.1.1 + resolution: "@types/jsonfile@npm:6.1.1" + dependencies: + "@types/node": "*" + checksum: 0f8fe0a9221a00e8413cffba723dfe16553868724b830237256fb0052ecd5cac96498189d1235a001cfa815f352008261c9ceb373f0aa58227f891e0c7a12c4d + languageName: node + linkType: hard + +"@types/lru-cache@npm:^5.1.0": + version: 5.1.1 + resolution: "@types/lru-cache@npm:5.1.1" + checksum: e1d6c0085f61b16ec5b3073ec76ad1be4844ea036561c3f145fc19f71f084b58a6eb600b14128aa95809d057d28f1d147c910186ae51219f58366ffd2ff2e118 + languageName: node + linkType: hard + +"@types/mocha@npm:^9.0.0": + version: 9.1.1 + resolution: "@types/mocha@npm:9.1.1" + checksum: 516077c0acd9806dc78317f88aaac0df5aaf0bdc2f63dfdadeabdf0b0137953b6ca65472e6ff7c30bc93ce4e0ae76eae70e8d46764b9a8eae4877a928b6ef49a + languageName: node + linkType: hard + +"@types/node@npm:*": + version: 20.4.5 + resolution: "@types/node@npm:20.4.5" + checksum: 36a0304a8dc346a1b2d2edac4c4633eecf70875793d61a5274d0df052d7a7af7a8e34f29884eac4fbd094c4f0201477dcb39c0ecd3307ca141688806538d1138 + languageName: node + linkType: hard + +"@types/node@npm:^10.0.3": + version: 10.17.60 + resolution: "@types/node@npm:10.17.60" + checksum: 2cdb3a77d071ba8513e5e8306fa64bf50e3c3302390feeaeff1fd325dd25c8441369715dfc8e3701011a72fed5958c7dfa94eb9239a81b3c286caa4d97db6eef + languageName: node + linkType: hard + +"@types/node@npm:^17.0.0": + version: 17.0.45 + resolution: "@types/node@npm:17.0.45" + checksum: aa04366b9103b7d6cfd6b2ef64182e0eaa7d4462c3f817618486ea0422984c51fc69fd0d436eae6c9e696ddfdbec9ccaa27a917f7c2e8c75c5d57827fe3d95e8 + languageName: node + linkType: hard + +"@types/node@npm:^8.0.0": + version: 8.10.66 + resolution: "@types/node@npm:8.10.66" + checksum: c52039de862654a139abdc6a51de532a69dd80516ac35a959c3b3a2831ecbaaf065b0df5f9db943f5e28b544ebb9a891730d52b52f7a169b86a82bc060210000 + languageName: node + linkType: hard + +"@types/pbkdf2@npm:^3.0.0": + version: 3.1.0 + resolution: "@types/pbkdf2@npm:3.1.0" + dependencies: + "@types/node": "*" + checksum: d15024b1957c21cf3b8887329d9bd8dfde754cf13a09d76ae25f1391cfc62bb8b8d7b760773c5dbaa748172fba8b3e0c3dbe962af6ccbd69b76df12a48dfba40 + languageName: node + linkType: hard + +"@types/prettier@npm:^2.1.1": + version: 2.7.3 + resolution: "@types/prettier@npm:2.7.3" + checksum: 705384209cea6d1433ff6c187c80dcc0b95d99d5c5ce21a46a9a58060c527973506822e428789d842761e0280d25e3359300f017fbe77b9755bc772ab3dc2f83 + languageName: node + linkType: hard + +"@types/qs@npm:^6.2.31, @types/qs@npm:^6.9.7": + version: 6.9.7 + resolution: "@types/qs@npm:6.9.7" + checksum: 7fd6f9c25053e9b5bb6bc9f9f76c1d89e6c04f7707a7ba0e44cc01f17ef5284adb82f230f542c2d5557d69407c9a40f0f3515e8319afd14e1e16b5543ac6cdba + languageName: node + linkType: hard + +"@types/readable-stream@npm:^2.3.13": + version: 2.3.15 + resolution: "@types/readable-stream@npm:2.3.15" + dependencies: + "@types/node": "*" + safe-buffer: ~5.1.1 + checksum: ec36f525cad09b6c65a1dafcb5ad99b9e2ed824ec49b7aa23180ac427e5d35b8a0706193ecd79ab4253a283ad485ba03d5917a98daaaa144f0ea34f4823e9d82 + languageName: node + linkType: hard + +"@types/secp256k1@npm:^4.0.1": + version: 4.0.3 + resolution: "@types/secp256k1@npm:4.0.3" + dependencies: + "@types/node": "*" + checksum: 1bd10b9afa724084b655dc81b7b315def3d2d0e272014ef16009fa76e17537411c07c0695fdea412bc7b36d2a02687f5fea33522d55b8ef29eda42992f812913 + languageName: node + linkType: hard + +"abbrev@npm:^1.0.0": + version: 1.1.1 + resolution: "abbrev@npm:1.1.1" + checksum: a4a97ec07d7ea112c517036882b2ac22f3109b7b19077dc656316d07d308438aac28e4d9746dc4d84bf6b1e75b4a7b0a5f3cb30592419f128ca9a8cee3bcfa17 + languageName: node + linkType: hard + +"abort-controller@npm:^3.0.0": + version: 3.0.0 + resolution: "abort-controller@npm:3.0.0" + dependencies: + event-target-shim: ^5.0.0 + checksum: 170bdba9b47b7e65906a28c8ce4f38a7a369d78e2271706f020849c1bfe0ee2067d4261df8bbb66eb84f79208fd5b710df759d64191db58cfba7ce8ef9c54b75 + languageName: node + linkType: hard + +"abstract-level@npm:^1.0.0, abstract-level@npm:^1.0.2, abstract-level@npm:^1.0.3": + version: 1.0.3 + resolution: "abstract-level@npm:1.0.3" + dependencies: + buffer: ^6.0.3 + catering: ^2.1.0 + is-buffer: ^2.0.5 + level-supports: ^4.0.0 + level-transcoder: ^1.0.1 + module-error: ^1.0.1 + queue-microtask: ^1.2.3 + checksum: 70d61a3924526ebc257b138992052f9ff571a6cee5a7660836e37a1cc7081273c3acf465dd2f5e1897b38dc743a6fd9dba14a5d8a2a9d39e5787cd3da99f301d + languageName: node + linkType: hard + +"acorn-walk@npm:^8.1.1": + version: 8.2.0 + resolution: "acorn-walk@npm:8.2.0" + checksum: 1715e76c01dd7b2d4ca472f9c58968516a4899378a63ad5b6c2d668bba8da21a71976c14ec5f5b75f887b6317c4ae0b897ab141c831d741dc76024d8745f1ad1 + languageName: node + linkType: hard + +"acorn@npm:^8.4.1": + version: 8.10.0 + resolution: "acorn@npm:8.10.0" + bin: + acorn: bin/acorn + checksum: 538ba38af0cc9e5ef983aee196c4b8b4d87c0c94532334fa7e065b2c8a1f85863467bb774231aae91613fcda5e68740c15d97b1967ae3394d20faddddd8af61d + languageName: node + linkType: hard + +"adm-zip@npm:^0.4.16": + version: 0.4.16 + resolution: "adm-zip@npm:0.4.16" + checksum: 5ea46664d8b3b073fffeb7f934705fea288708745e708cffc1dd732ce3d2672cecd476b243f9d051892fd12952db2b6bd061975e1ff40057246f6d0cb6534a50 + languageName: node + linkType: hard + +"aes-js@npm:3.0.0": + version: 3.0.0 + resolution: "aes-js@npm:3.0.0" + checksum: 251e26d533cd1a915b44896b17d5ed68c24a02484cfdd2e74ec700a309267db96651ea4eb657bf20aac32a3baa61f6e34edf8e2fec2de440a655da9942d334b8 + languageName: node + linkType: hard + +"agent-base@npm:6, agent-base@npm:^6.0.2": + version: 6.0.2 + resolution: "agent-base@npm:6.0.2" + dependencies: + debug: 4 + checksum: f52b6872cc96fd5f622071b71ef200e01c7c4c454ee68bc9accca90c98cfb39f2810e3e9aa330435835eedc8c23f4f8a15267f67c6e245d2b33757575bdac49d + languageName: node + linkType: hard + +"agentkeepalive@npm:^4.2.1": + version: 4.5.0 + resolution: "agentkeepalive@npm:4.5.0" + dependencies: + humanize-ms: ^1.2.1 + checksum: 13278cd5b125e51eddd5079f04d6fe0914ac1b8b91c1f3db2c1822f99ac1a7457869068997784342fe455d59daaff22e14fb7b8c3da4e741896e7e31faf92481 + languageName: node + linkType: hard + +"aggregate-error@npm:^3.0.0": + version: 3.1.0 + resolution: "aggregate-error@npm:3.1.0" + dependencies: + clean-stack: ^2.0.0 + indent-string: ^4.0.0 + checksum: 1101a33f21baa27a2fa8e04b698271e64616b886795fd43c31068c07533c7b3facfcaf4e9e0cab3624bd88f729a592f1c901a1a229c9e490eafce411a8644b79 + languageName: node + linkType: hard + +"ajv@npm:^6.12.3, ajv@npm:^6.12.6": + version: 6.12.6 + resolution: "ajv@npm:6.12.6" + dependencies: + fast-deep-equal: ^3.1.1 + fast-json-stable-stringify: ^2.0.0 + json-schema-traverse: ^0.4.1 + uri-js: ^4.2.2 + checksum: 874972efe5c4202ab0a68379481fbd3d1b5d0a7bd6d3cc21d40d3536ebff3352a2a1fabb632d4fd2cc7fe4cbdcd5ed6782084c9bbf7f32a1536d18f9da5007d4 + languageName: node + linkType: hard + +"ajv@npm:^8.0.1": + version: 8.12.0 + resolution: "ajv@npm:8.12.0" + dependencies: + fast-deep-equal: ^3.1.1 + json-schema-traverse: ^1.0.0 + require-from-string: ^2.0.2 + uri-js: ^4.2.2 + checksum: 4dc13714e316e67537c8b31bc063f99a1d9d9a497eb4bbd55191ac0dcd5e4985bbb71570352ad6f1e76684fb6d790928f96ba3b2d4fd6e10024be9612fe3f001 + languageName: node + linkType: hard + +"ansi-colors@npm:3.2.3": + version: 3.2.3 + resolution: "ansi-colors@npm:3.2.3" + checksum: 018a92fbf8b143feb9e00559655072598902ff2cdfa07dbe24b933c70ae04845e3dda2c091ab128920fc50b3db06c3f09947f49fcb287d53beb6c5869b8bb32b + languageName: node + linkType: hard + +"ansi-colors@npm:4.1.1": + version: 4.1.1 + resolution: "ansi-colors@npm:4.1.1" + checksum: 138d04a51076cb085da0a7e2d000c5c0bb09f6e772ed5c65c53cb118d37f6c5f1637506d7155fb5f330f0abcf6f12fa2e489ac3f8cdab9da393bf1bb4f9a32b0 + languageName: node + linkType: hard + +"ansi-colors@npm:^4.1.1": + version: 4.1.3 + resolution: "ansi-colors@npm:4.1.3" + checksum: a9c2ec842038a1fabc7db9ece7d3177e2fe1c5dc6f0c51ecfbf5f39911427b89c00b5dc6b8bd95f82a26e9b16aaae2e83d45f060e98070ce4d1333038edceb0e + languageName: node + linkType: hard + +"ansi-escapes@npm:^4.3.0": + version: 4.3.2 + resolution: "ansi-escapes@npm:4.3.2" + dependencies: + type-fest: ^0.21.3 + checksum: 93111c42189c0a6bed9cdb4d7f2829548e943827ee8479c74d6e0b22ee127b2a21d3f8b5ca57723b8ef78ce011fbfc2784350eb2bde3ccfccf2f575fa8489815 + languageName: node + linkType: hard + +"ansi-regex@npm:^3.0.0": + version: 3.0.1 + resolution: "ansi-regex@npm:3.0.1" + checksum: 09daf180c5f59af9850c7ac1bd7fda85ba596cc8cbeb210826e90755f06c818af86d9fa1e6e8322fab2c3b9e9b03f56c537b42241139f824dd75066a1e7257cc + languageName: node + linkType: hard + +"ansi-regex@npm:^4.1.0": + version: 4.1.1 + resolution: "ansi-regex@npm:4.1.1" + checksum: b1a6ee44cb6ecdabaa770b2ed500542714d4395d71c7e5c25baa631f680fb2ad322eb9ba697548d498a6fd366949fc8b5bfcf48d49a32803611f648005b01888 + languageName: node + linkType: hard + +"ansi-regex@npm:^5.0.1": + version: 5.0.1 + resolution: "ansi-regex@npm:5.0.1" + checksum: 2aa4bb54caf2d622f1afdad09441695af2a83aa3fe8b8afa581d205e57ed4261c183c4d3877cee25794443fde5876417d859c108078ab788d6af7e4fe52eb66b + languageName: node + linkType: hard + +"ansi-regex@npm:^6.0.1": + version: 6.0.1 + resolution: "ansi-regex@npm:6.0.1" + checksum: 1ff8b7667cded1de4fa2c9ae283e979fc87036864317da86a2e546725f96406746411d0d85e87a2d12fa5abd715d90006de7fa4fa0477c92321ad3b4c7d4e169 + languageName: node + linkType: hard + +"ansi-styles@npm:^3.2.0, ansi-styles@npm:^3.2.1": + version: 3.2.1 + resolution: "ansi-styles@npm:3.2.1" + dependencies: + color-convert: ^1.9.0 + checksum: d85ade01c10e5dd77b6c89f34ed7531da5830d2cb5882c645f330079975b716438cd7ebb81d0d6e6b4f9c577f19ae41ab55f07f19786b02f9dfd9e0377395665 + languageName: node + linkType: hard + +"ansi-styles@npm:^4.0.0, ansi-styles@npm:^4.1.0": + version: 4.3.0 + resolution: "ansi-styles@npm:4.3.0" + dependencies: + color-convert: ^2.0.1 + checksum: 513b44c3b2105dd14cc42a19271e80f386466c4be574bccf60b627432f9198571ebf4ab1e4c3ba17347658f4ee1711c163d574248c0c1cdc2d5917a0ad582ec4 + languageName: node + linkType: hard + +"ansi-styles@npm:^6.0.0, ansi-styles@npm:^6.1.0": + version: 6.2.1 + resolution: "ansi-styles@npm:6.2.1" + checksum: ef940f2f0ced1a6347398da88a91da7930c33ecac3c77b72c5905f8b8fe402c52e6fde304ff5347f616e27a742da3f1dc76de98f6866c69251ad0b07a66776d9 + languageName: node + linkType: hard + +"antlr4@npm:^4.11.0": + version: 4.13.0 + resolution: "antlr4@npm:4.13.0" + checksum: 9fc5d8bf2d3be7e35e372ef70acd015e9e593ff7482dafd9780185eb63e156958b137a6e4af1792eda71adc7c3b09f9087d2d7794b903c1a65f58800907e7beb + languageName: node + linkType: hard + +"antlr4ts@npm:^0.5.0-alpha.4": + version: 0.5.0-alpha.4 + resolution: "antlr4ts@npm:0.5.0-alpha.4" + checksum: 37948499d59477f5b5a8ea71dfb8b5330e71d5a7cee60f57351dd744219b8619fa6aac1a5b6ec1a9991846e8ddc9ca47680eb166c59b44333369b3115e7aa358 + languageName: node + linkType: hard + +"anymatch@npm:~3.1.1, anymatch@npm:~3.1.2": + version: 3.1.3 + resolution: "anymatch@npm:3.1.3" + dependencies: + normalize-path: ^3.0.0 + picomatch: ^2.0.4 + checksum: 3e044fd6d1d26545f235a9fe4d7a534e2029d8e59fa7fd9f2a6eb21230f6b5380ea1eaf55136e60cbf8e613544b3b766e7a6fa2102e2a3a117505466e3025dc2 + languageName: node + linkType: hard + +"aproba@npm:^1.0.3 || ^2.0.0": + version: 2.0.0 + resolution: "aproba@npm:2.0.0" + checksum: 5615cadcfb45289eea63f8afd064ab656006361020e1735112e346593856f87435e02d8dcc7ff0d11928bc7d425f27bc7c2a84f6c0b35ab0ff659c814c138a24 + languageName: node + linkType: hard + +"are-we-there-yet@npm:^3.0.0": + version: 3.0.1 + resolution: "are-we-there-yet@npm:3.0.1" + dependencies: + delegates: ^1.0.0 + readable-stream: ^3.6.0 + checksum: 52590c24860fa7173bedeb69a4c05fb573473e860197f618b9a28432ee4379049336727ae3a1f9c4cb083114601c1140cee578376164d0e651217a9843f9fe83 + languageName: node + linkType: hard + +"arg@npm:^4.1.0": + version: 4.1.3 + resolution: "arg@npm:4.1.3" + checksum: 544af8dd3f60546d3e4aff084d451b96961d2267d668670199692f8d054f0415d86fc5497d0e641e91546f0aa920e7c29e5250e99fc89f5552a34b5d93b77f43 + languageName: node + linkType: hard + +"argparse@npm:^1.0.7": + version: 1.0.10 + resolution: "argparse@npm:1.0.10" + dependencies: + sprintf-js: ~1.0.2 + checksum: 7ca6e45583a28de7258e39e13d81e925cfa25d7d4aacbf806a382d3c02fcb13403a07fb8aeef949f10a7cfe4a62da0e2e807b348a5980554cc28ee573ef95945 + languageName: node + linkType: hard + +"argparse@npm:^2.0.1": + version: 2.0.1 + resolution: "argparse@npm:2.0.1" + checksum: 83644b56493e89a254bae05702abf3a1101b4fa4d0ca31df1c9985275a5a5bd47b3c27b7fa0b71098d41114d8ca000e6ed90cad764b306f8a503665e4d517ced + languageName: node + linkType: hard + +"array-back@npm:^3.0.1, array-back@npm:^3.1.0": + version: 3.1.0 + resolution: "array-back@npm:3.1.0" + checksum: 7205004fcd0f9edd926db921af901b083094608d5b265738d0290092f9822f73accb468e677db74c7c94ef432d39e5ed75a7b1786701e182efb25bbba9734209 + languageName: node + linkType: hard + +"array-back@npm:^4.0.1, array-back@npm:^4.0.2": + version: 4.0.2 + resolution: "array-back@npm:4.0.2" + checksum: f30603270771eeb54e5aad5f54604c62b3577a18b6db212a7272b2b6c32049121b49431f656654790ed1469411e45f387e7627c0de8fd0515995cc40df9b9294 + languageName: node + linkType: hard + +"array-buffer-byte-length@npm:^1.0.0": + version: 1.0.0 + resolution: "array-buffer-byte-length@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + is-array-buffer: ^3.0.1 + checksum: 044e101ce150f4804ad19c51d6c4d4cfa505c5b2577bd179256e4aa3f3f6a0a5e9874c78cd428ee566ac574c8a04d7ce21af9fe52e844abfdccb82b33035a7c3 + languageName: node + linkType: hard + +"array-union@npm:^2.1.0": + version: 2.1.0 + resolution: "array-union@npm:2.1.0" + checksum: 5bee12395cba82da674931df6d0fea23c4aa4660cb3b338ced9f828782a65caa232573e6bf3968f23e0c5eb301764a382cef2f128b170a9dc59de0e36c39f98d + languageName: node + linkType: hard + +"array-uniq@npm:1.0.3": + version: 1.0.3 + resolution: "array-uniq@npm:1.0.3" + checksum: 1625f06b093d8bf279b81adfec6e72951c0857d65b5e3f65f053fffe9f9dd61c2fc52cff57e38a4700817e7e3f01a4faa433d505ea9e33cdae4514c334e0bf9e + languageName: node + linkType: hard + +"array.prototype.reduce@npm:^1.0.5": + version: 1.0.5 + resolution: "array.prototype.reduce@npm:1.0.5" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.4 + es-abstract: ^1.20.4 + es-array-method-boxes-properly: ^1.0.0 + is-string: ^1.0.7 + checksum: f44691395f9202aba5ec2446468d4c27209bfa81464f342ae024b7157dbf05b164e47cca01250b8c7c2a8219953fb57651cca16aab3d16f43b85c0d92c26eef3 + languageName: node + linkType: hard + +"arraybuffer.prototype.slice@npm:^1.0.1": + version: 1.0.1 + resolution: "arraybuffer.prototype.slice@npm:1.0.1" + dependencies: + array-buffer-byte-length: ^1.0.0 + call-bind: ^1.0.2 + define-properties: ^1.2.0 + get-intrinsic: ^1.2.1 + is-array-buffer: ^3.0.2 + is-shared-array-buffer: ^1.0.2 + checksum: e3e9b2a3e988ebfeddce4c7e8f69df730c9e48cb04b0d40ff0874ce3d86b3d1339dd520ffde5e39c02610bc172ecfbd4bc93324b1cabd9554c44a56b131ce0ce + languageName: node + linkType: hard + +"asap@npm:~2.0.6": + version: 2.0.6 + resolution: "asap@npm:2.0.6" + checksum: b296c92c4b969e973260e47523207cd5769abd27c245a68c26dc7a0fe8053c55bb04360237cb51cab1df52be939da77150ace99ad331fb7fb13b3423ed73ff3d + languageName: node + linkType: hard + +"asn1@npm:~0.2.3": + version: 0.2.6 + resolution: "asn1@npm:0.2.6" + dependencies: + safer-buffer: ~2.1.0 + checksum: 39f2ae343b03c15ad4f238ba561e626602a3de8d94ae536c46a4a93e69578826305366dc09fbb9b56aec39b4982a463682f259c38e59f6fa380cd72cd61e493d + languageName: node + linkType: hard + +"assert-plus@npm:1.0.0, assert-plus@npm:^1.0.0": + version: 1.0.0 + resolution: "assert-plus@npm:1.0.0" + checksum: 19b4340cb8f0e6a981c07225eacac0e9d52c2644c080198765d63398f0075f83bbc0c8e95474d54224e297555ad0d631c1dcd058adb1ddc2437b41a6b424ac64 + languageName: node + linkType: hard + +"assertion-error@npm:^1.1.0": + version: 1.1.0 + resolution: "assertion-error@npm:1.1.0" + checksum: fd9429d3a3d4fd61782eb3962ae76b6d08aa7383123fca0596020013b3ebd6647891a85b05ce821c47d1471ed1271f00b0545cf6a4326cf2fc91efcc3b0fbecf + languageName: node + linkType: hard + +"ast-parents@npm:^0.0.1": + version: 0.0.1 + resolution: "ast-parents@npm:0.0.1" + checksum: 51360afb9f7b939eb0330fdd0d5d855d0242f273f63478d30d9053069120492173719fb3c03ba372bccf1a7c1a9041c3c6bf2ab700de8c0f8c14792b045c3b23 + languageName: node + linkType: hard + +"astral-regex@npm:^2.0.0": + version: 2.0.0 + resolution: "astral-regex@npm:2.0.0" + checksum: 876231688c66400473ba505731df37ea436e574dd524520294cc3bbc54ea40334865e01fa0d074d74d036ee874ee7e62f486ea38bc421ee8e6a871c06f011766 + languageName: node + linkType: hard + +"asynckit@npm:^0.4.0": + version: 0.4.0 + resolution: "asynckit@npm:0.4.0" + checksum: 7b78c451df768adba04e2d02e63e2d0bf3b07adcd6e42b4cf665cb7ce899bedd344c69a1dcbce355b5f972d597b25aaa1c1742b52cffd9caccb22f348114f6be + languageName: node + linkType: hard + +"at-least-node@npm:^1.0.0": + version: 1.0.0 + resolution: "at-least-node@npm:1.0.0" + checksum: 463e2f8e43384f1afb54bc68485c436d7622acec08b6fad269b421cb1d29cebb5af751426793d0961ed243146fe4dc983402f6d5a51b720b277818dbf6f2e49e + languageName: node + linkType: hard + +"available-typed-arrays@npm:^1.0.5": + version: 1.0.5 + resolution: "available-typed-arrays@npm:1.0.5" + checksum: 20eb47b3cefd7db027b9bbb993c658abd36d4edd3fe1060e83699a03ee275b0c9b216cc076ff3f2db29073225fb70e7613987af14269ac1fe2a19803ccc97f1a + languageName: node + linkType: hard + +"aws-sign2@npm:~0.7.0": + version: 0.7.0 + resolution: "aws-sign2@npm:0.7.0" + checksum: b148b0bb0778098ad8cf7e5fc619768bcb51236707ca1d3e5b49e41b171166d8be9fdc2ea2ae43d7decf02989d0aaa3a9c4caa6f320af95d684de9b548a71525 + languageName: node + linkType: hard + +"aws4@npm:^1.8.0": + version: 1.12.0 + resolution: "aws4@npm:1.12.0" + checksum: 68f79708ac7c335992730bf638286a3ee0a645cf12575d557860100767c500c08b30e24726b9f03265d74116417f628af78509e1333575e9f8d52a80edfe8cbc + languageName: node + linkType: hard + +"axios@npm:^0.21.1": + version: 0.21.4 + resolution: "axios@npm:0.21.4" + dependencies: + follow-redirects: ^1.14.0 + checksum: 44245f24ac971e7458f3120c92f9d66d1fc695e8b97019139de5b0cc65d9b8104647db01e5f46917728edfc0cfd88eb30fc4c55e6053eef4ace76768ce95ff3c + languageName: node + linkType: hard + +"axios@npm:^0.24.0": + version: 0.24.0 + resolution: "axios@npm:0.24.0" + dependencies: + follow-redirects: ^1.14.4 + checksum: 468cf496c08a6aadfb7e699bebdac02851e3043d4e7d282350804ea8900e30d368daa6e3cd4ab83b8ddb5a3b1e17a5a21ada13fc9cebd27b74828f47a4236316 + languageName: node + linkType: hard + +"balanced-match@npm:^1.0.0": + version: 1.0.2 + resolution: "balanced-match@npm:1.0.2" + checksum: 9706c088a283058a8a99e0bf91b0a2f75497f185980d9ffa8b304de1d9e58ebda7c72c07ebf01dadedaac5b2907b2c6f566f660d62bd336c3468e960403b9d65 + languageName: node + linkType: hard + +"base-x@npm:^3.0.2": + version: 3.0.9 + resolution: "base-x@npm:3.0.9" + dependencies: + safe-buffer: ^5.0.1 + checksum: 957101d6fd09e1903e846fd8f69fd7e5e3e50254383e61ab667c725866bec54e5ece5ba49ce385128ae48f9ec93a26567d1d5ebb91f4d56ef4a9cc0d5a5481e8 + languageName: node + linkType: hard + +"base64-js@npm:^1.3.1": + version: 1.5.1 + resolution: "base64-js@npm:1.5.1" + checksum: 669632eb3745404c2f822a18fc3a0122d2f9a7a13f7fb8b5823ee19d1d2ff9ee5b52c53367176ea4ad093c332fd5ab4bd0ebae5a8e27917a4105a4cfc86b1005 + languageName: node + linkType: hard + +"bcrypt-pbkdf@npm:^1.0.0": + version: 1.0.2 + resolution: "bcrypt-pbkdf@npm:1.0.2" + dependencies: + tweetnacl: ^0.14.3 + checksum: 4edfc9fe7d07019609ccf797a2af28351736e9d012c8402a07120c4453a3b789a15f2ee1530dc49eee8f7eb9379331a8dd4b3766042b9e502f74a68e7f662291 + languageName: node + linkType: hard + +"bech32@npm:1.1.4": + version: 1.1.4 + resolution: "bech32@npm:1.1.4" + checksum: 0e98db619191548390d6f09ff68b0253ba7ae6a55db93dfdbb070ba234c1fd3308c0606fbcc95fad50437227b10011e2698b89f0181f6e7f845c499bd14d0f4b + languageName: node + linkType: hard + +"bigint-crypto-utils@npm:^3.0.23": + version: 3.3.0 + resolution: "bigint-crypto-utils@npm:3.3.0" + checksum: 9598ce57b23f776c8936d44114c9f051e62b5fa654915b664784cbcbacc5aa0485f4479571c51ff58008abb1210c0d6a234853742f07cf84bda890f2a1e01000 + languageName: node + linkType: hard + +"binary-extensions@npm:^2.0.0": + version: 2.2.0 + resolution: "binary-extensions@npm:2.2.0" + checksum: ccd267956c58d2315f5d3ea6757cf09863c5fc703e50fbeb13a7dc849b812ef76e3cf9ca8f35a0c48498776a7478d7b4a0418e1e2b8cb9cb9731f2922aaad7f8 + languageName: node + linkType: hard + +"blakejs@npm:^1.1.0": + version: 1.2.1 + resolution: "blakejs@npm:1.2.1" + checksum: d699ba116cfa21d0b01d12014a03e484dd76d483133e6dc9eb415aa70a119f08beb3bcefb8c71840106a00b542cba77383f8be60cd1f0d4589cb8afb922eefbe + languageName: node + linkType: hard + +"bn.js@npm:^4.11.0, bn.js@npm:^4.11.8, bn.js@npm:^4.11.9": + version: 4.12.0 + resolution: "bn.js@npm:4.12.0" + checksum: 39afb4f15f4ea537b55eaf1446c896af28ac948fdcf47171961475724d1bb65118cca49fa6e3d67706e4790955ec0e74de584e45c8f1ef89f46c812bee5b5a12 + languageName: node + linkType: hard + +"bn.js@npm:^5.2.0, bn.js@npm:^5.2.1": + version: 5.2.1 + resolution: "bn.js@npm:5.2.1" + checksum: 3dd8c8d38055fedfa95c1d5fc3c99f8dd547b36287b37768db0abab3c239711f88ff58d18d155dd8ad902b0b0cee973747b7ae20ea12a09473272b0201c9edd3 + languageName: node + linkType: hard + +"brace-expansion@npm:^1.1.7": + version: 1.1.11 + resolution: "brace-expansion@npm:1.1.11" + dependencies: + balanced-match: ^1.0.0 + concat-map: 0.0.1 + checksum: faf34a7bb0c3fcf4b59c7808bc5d2a96a40988addf2e7e09dfbb67a2251800e0d14cd2bfc1aa79174f2f5095c54ff27f46fb1289fe2d77dac755b5eb3434cc07 + languageName: node + linkType: hard + +"brace-expansion@npm:^2.0.1": + version: 2.0.1 + resolution: "brace-expansion@npm:2.0.1" + dependencies: + balanced-match: ^1.0.0 + checksum: a61e7cd2e8a8505e9f0036b3b6108ba5e926b4b55089eeb5550cd04a471fe216c96d4fe7e4c7f995c728c554ae20ddfc4244cad10aef255e72b62930afd233d1 + languageName: node + linkType: hard + +"braces@npm:^3.0.2, braces@npm:~3.0.2": + version: 3.0.2 + resolution: "braces@npm:3.0.2" + dependencies: + fill-range: ^7.0.1 + checksum: e2a8e769a863f3d4ee887b5fe21f63193a891c68b612ddb4b68d82d1b5f3ff9073af066c343e9867a393fe4c2555dcb33e89b937195feb9c1613d259edfcd459 + languageName: node + linkType: hard + +"brorand@npm:^1.1.0": + version: 1.1.0 + resolution: "brorand@npm:1.1.0" + checksum: 8a05c9f3c4b46572dec6ef71012b1946db6cae8c7bb60ccd4b7dd5a84655db49fe043ecc6272e7ef1f69dc53d6730b9e2a3a03a8310509a3d797a618cbee52be + languageName: node + linkType: hard + +"browser-level@npm:^1.0.1": + version: 1.0.1 + resolution: "browser-level@npm:1.0.1" + dependencies: + abstract-level: ^1.0.2 + catering: ^2.1.1 + module-error: ^1.0.2 + run-parallel-limit: ^1.1.0 + checksum: 67fbc77ce832940bfa25073eccff279f512ad56f545deb996a5b23b02316f5e76f4a79d381acc27eda983f5c9a2566aaf9c97e4fdd0748288c4407307537a29b + languageName: node + linkType: hard + +"browser-stdout@npm:1.3.1": + version: 1.3.1 + resolution: "browser-stdout@npm:1.3.1" + checksum: b717b19b25952dd6af483e368f9bcd6b14b87740c3d226c2977a65e84666ffd67000bddea7d911f111a9b6ddc822b234de42d52ab6507bce4119a4cc003ef7b3 + languageName: node + linkType: hard + +"browserify-aes@npm:^1.2.0": + version: 1.2.0 + resolution: "browserify-aes@npm:1.2.0" + dependencies: + buffer-xor: ^1.0.3 + cipher-base: ^1.0.0 + create-hash: ^1.1.0 + evp_bytestokey: ^1.0.3 + inherits: ^2.0.1 + safe-buffer: ^5.0.1 + checksum: 4a17c3eb55a2aa61c934c286f34921933086bf6d67f02d4adb09fcc6f2fc93977b47d9d884c25619144fccd47b3b3a399e1ad8b3ff5a346be47270114bcf7104 + languageName: node + linkType: hard + +"bs58@npm:^4.0.0": + version: 4.0.1 + resolution: "bs58@npm:4.0.1" + dependencies: + base-x: ^3.0.2 + checksum: b3c5365bb9e0c561e1a82f1a2d809a1a692059fae016be233a6127ad2f50a6b986467c3a50669ce4c18929dcccb297c5909314dd347a25a68c21b68eb3e95ac2 + languageName: node + linkType: hard + +"bs58check@npm:^2.1.2": + version: 2.1.2 + resolution: "bs58check@npm:2.1.2" + dependencies: + bs58: ^4.0.0 + create-hash: ^1.1.0 + safe-buffer: ^5.1.2 + checksum: 43bdf08a5dd04581b78f040bc4169480e17008da482ffe2a6507327bbc4fc5c28de0501f7faf22901cfe57fbca79cbb202ca529003fedb4cb8dccd265b38e54d + languageName: node + linkType: hard + +"buffer-from@npm:^1.0.0": + version: 1.1.2 + resolution: "buffer-from@npm:1.1.2" + checksum: 0448524a562b37d4d7ed9efd91685a5b77a50672c556ea254ac9a6d30e3403a517d8981f10e565db24e8339413b43c97ca2951f10e399c6125a0d8911f5679bb + languageName: node + linkType: hard + +"buffer-xor@npm:^1.0.3": + version: 1.0.3 + resolution: "buffer-xor@npm:1.0.3" + checksum: 10c520df29d62fa6e785e2800e586a20fc4f6dfad84bcdbd12e1e8a83856de1cb75c7ebd7abe6d036bbfab738a6cf18a3ae9c8e5a2e2eb3167ca7399ce65373a + languageName: node + linkType: hard + +"buffer@npm:^6.0.3": + version: 6.0.3 + resolution: "buffer@npm:6.0.3" + dependencies: + base64-js: ^1.3.1 + ieee754: ^1.2.1 + checksum: 5ad23293d9a731e4318e420025800b42bf0d264004c0286c8cc010af7a270c7a0f6522e84f54b9ad65cbd6db20b8badbfd8d2ebf4f80fa03dab093b89e68c3f9 + languageName: node + linkType: hard + +"busboy@npm:^1.6.0": + version: 1.6.0 + resolution: "busboy@npm:1.6.0" + dependencies: + streamsearch: ^1.1.0 + checksum: 32801e2c0164e12106bf236291a00795c3c4e4b709ae02132883fe8478ba2ae23743b11c5735a0aae8afe65ac4b6ca4568b91f0d9fed1fdbc32ede824a73746e + languageName: node + linkType: hard + +"bytes@npm:3.1.2": + version: 3.1.2 + resolution: "bytes@npm:3.1.2" + checksum: e4bcd3948d289c5127591fbedf10c0b639ccbf00243504e4e127374a15c3bc8eed0d28d4aaab08ff6f1cf2abc0cce6ba3085ed32f4f90e82a5683ce0014e1b6e + languageName: node + linkType: hard + +"cacache@npm:^17.0.0": + version: 17.1.4 + resolution: "cacache@npm:17.1.4" + dependencies: + "@npmcli/fs": ^3.1.0 + fs-minipass: ^3.0.0 + glob: ^10.2.2 + lru-cache: ^7.7.1 + minipass: ^7.0.3 + minipass-collect: ^1.0.2 + minipass-flush: ^1.0.5 + minipass-pipeline: ^1.2.4 + p-map: ^4.0.0 + ssri: ^10.0.0 + tar: ^6.1.11 + unique-filename: ^3.0.0 + checksum: b7751df756656954a51201335addced8f63fc53266fa56392c9f5ae83c8d27debffb4458ac2d168a744a4517ec3f2163af05c20097f93d17bdc2dc8a385e14a6 + languageName: node + linkType: hard + +"call-bind@npm:^1.0.0, call-bind@npm:^1.0.2": + version: 1.0.2 + resolution: "call-bind@npm:1.0.2" + dependencies: + function-bind: ^1.1.1 + get-intrinsic: ^1.0.2 + checksum: f8e31de9d19988a4b80f3e704788c4a2d6b6f3d17cfec4f57dc29ced450c53a49270dc66bf0fbd693329ee948dd33e6c90a329519aef17474a4d961e8d6426b0 + languageName: node + linkType: hard + +"callsites@npm:^3.0.0": + version: 3.1.0 + resolution: "callsites@npm:3.1.0" + checksum: 072d17b6abb459c2ba96598918b55868af677154bec7e73d222ef95a8fdb9bbf7dae96a8421085cdad8cd190d86653b5b6dc55a4484f2e5b2e27d5e0c3fc15b3 + languageName: node + linkType: hard + +"camelcase@npm:^5.0.0": + version: 5.3.1 + resolution: "camelcase@npm:5.3.1" + checksum: e6effce26b9404e3c0f301498184f243811c30dfe6d0b9051863bd8e4034d09c8c2923794f280d6827e5aa055f6c434115ff97864a16a963366fb35fd673024b + languageName: node + linkType: hard + +"camelcase@npm:^6.0.0": + version: 6.3.0 + resolution: "camelcase@npm:6.3.0" + checksum: 8c96818a9076434998511251dcb2761a94817ea17dbdc37f47ac080bd088fc62c7369429a19e2178b993497132c8cbcf5cc1f44ba963e76782ba469c0474938d + languageName: node + linkType: hard + +"case@npm:^1.6.3": + version: 1.6.3 + resolution: "case@npm:1.6.3" + checksum: febe73278f910b0d28aab7efd6f51c235f9aa9e296148edb56dfb83fd58faa88308c30ce9a0122b6e53e0362c44f4407105bd5ef89c46860fc2b184e540fd68d + languageName: node + linkType: hard + +"caseless@npm:^0.12.0, caseless@npm:~0.12.0": + version: 0.12.0 + resolution: "caseless@npm:0.12.0" + checksum: b43bd4c440aa1e8ee6baefee8063b4850fd0d7b378f6aabc796c9ec8cb26d27fb30b46885350777d9bd079c5256c0e1329ad0dc7c2817e0bb466810ebb353751 + languageName: node + linkType: hard + +"catering@npm:^2.1.0, catering@npm:^2.1.1": + version: 2.1.1 + resolution: "catering@npm:2.1.1" + checksum: 205daefa69c935b0c19f3d8f2e0a520dd69aebe9bda55902958003f7c9cff8f967dfb90071b421bd6eb618576f657a89d2bc0986872c9bc04bbd66655e9d4bd6 + languageName: node + linkType: hard + +"chai-as-promised@npm:^7.1.1": + version: 7.1.1 + resolution: "chai-as-promised@npm:7.1.1" + dependencies: + check-error: ^1.0.2 + peerDependencies: + chai: ">= 2.1.2 < 5" + checksum: 7262868a5b51a12af4e432838ddf97a893109266a505808e1868ba63a12de7ee1166e9d43b5c501a190c377c1b11ecb9ff8e093c89f097ad96c397e8ec0f8d6a + languageName: node + linkType: hard + +"chai@npm:^4.3.4": + version: 4.3.7 + resolution: "chai@npm:4.3.7" + dependencies: + assertion-error: ^1.1.0 + check-error: ^1.0.2 + deep-eql: ^4.1.2 + get-func-name: ^2.0.0 + loupe: ^2.3.1 + pathval: ^1.1.1 + type-detect: ^4.0.5 + checksum: 0bba7d267848015246a66995f044ce3f0ebc35e530da3cbdf171db744e14cbe301ab913a8d07caf7952b430257ccbb1a4a983c570a7c5748dc537897e5131f7c + languageName: node + linkType: hard + +"chalk@npm:5.2.0": + version: 5.2.0 + resolution: "chalk@npm:5.2.0" + checksum: 03d8060277de6cf2fd567dc25fcf770593eb5bb85f460ce443e49255a30ff1242edd0c90a06a03803b0466ff0687a939b41db1757bec987113e83de89a003caa + languageName: node + linkType: hard + +"chalk@npm:^2.0.0, chalk@npm:^2.4.2": + version: 2.4.2 + resolution: "chalk@npm:2.4.2" + dependencies: + ansi-styles: ^3.2.1 + escape-string-regexp: ^1.0.5 + supports-color: ^5.3.0 + checksum: ec3661d38fe77f681200f878edbd9448821924e0f93a9cefc0e26a33b145f1027a2084bf19967160d11e1f03bfe4eaffcabf5493b89098b2782c3fe0b03d80c2 + languageName: node + linkType: hard + +"chalk@npm:^4.0.0, chalk@npm:^4.1.0, chalk@npm:^4.1.2": + version: 4.1.2 + resolution: "chalk@npm:4.1.2" + dependencies: + ansi-styles: ^4.1.0 + supports-color: ^7.1.0 + checksum: fe75c9d5c76a7a98d45495b91b2172fa3b7a09e0cc9370e5c8feb1c567b85c4288e2b3fded7cfdd7359ac28d6b3844feb8b82b8686842e93d23c827c417e83fc + languageName: node + linkType: hard + +"charenc@npm:>= 0.0.1": + version: 0.0.2 + resolution: "charenc@npm:0.0.2" + checksum: 81dcadbe57e861d527faf6dd3855dc857395a1c4d6781f4847288ab23cffb7b3ee80d57c15bba7252ffe3e5e8019db767757ee7975663ad2ca0939bb8fcaf2e5 + languageName: node + linkType: hard + +"check-error@npm:^1.0.2": + version: 1.0.2 + resolution: "check-error@npm:1.0.2" + checksum: d9d106504404b8addd1ee3f63f8c0eaa7cd962a1a28eb9c519b1c4a1dc7098be38007fc0060f045ee00f075fbb7a2a4f42abcf61d68323677e11ab98dc16042e + languageName: node + linkType: hard + +"chokidar@npm:3.3.0": + version: 3.3.0 + resolution: "chokidar@npm:3.3.0" + dependencies: + anymatch: ~3.1.1 + braces: ~3.0.2 + fsevents: ~2.1.1 + glob-parent: ~5.1.0 + is-binary-path: ~2.1.0 + is-glob: ~4.0.1 + normalize-path: ~3.0.0 + readdirp: ~3.2.0 + dependenciesMeta: + fsevents: + optional: true + checksum: e9863256ebb29dbc5e58a7e2637439814beb63b772686cb9e94478312c24dcaf3d0570220c5e75ea29029f43b664f9956d87b716120d38cf755f32124f047e8e + languageName: node + linkType: hard + +"chokidar@npm:3.5.3, chokidar@npm:^3.4.0, chokidar@npm:^3.5.2": + version: 3.5.3 + resolution: "chokidar@npm:3.5.3" + dependencies: + anymatch: ~3.1.2 + braces: ~3.0.2 + fsevents: ~2.3.2 + glob-parent: ~5.1.2 + is-binary-path: ~2.1.0 + is-glob: ~4.0.1 + normalize-path: ~3.0.0 + readdirp: ~3.6.0 + dependenciesMeta: + fsevents: + optional: true + checksum: b49fcde40176ba007ff361b198a2d35df60d9bb2a5aab228279eb810feae9294a6b4649ab15981304447afe1e6ffbf4788ad5db77235dc770ab777c6e771980c + languageName: node + linkType: hard + +"chownr@npm:^2.0.0": + version: 2.0.0 + resolution: "chownr@npm:2.0.0" + checksum: c57cf9dd0791e2f18a5ee9c1a299ae6e801ff58fee96dc8bfd0dcb4738a6ce58dd252a3605b1c93c6418fe4f9d5093b28ffbf4d66648cb2a9c67eaef9679be2f + languageName: node + linkType: hard + +"ci-info@npm:^2.0.0": + version: 2.0.0 + resolution: "ci-info@npm:2.0.0" + checksum: 3b374666a85ea3ca43fa49aa3a048d21c9b475c96eb13c133505d2324e7ae5efd6a454f41efe46a152269e9b6a00c9edbe63ec7fa1921957165aae16625acd67 + languageName: node + linkType: hard + +"cipher-base@npm:^1.0.0, cipher-base@npm:^1.0.1, cipher-base@npm:^1.0.3": + version: 1.0.4 + resolution: "cipher-base@npm:1.0.4" + dependencies: + inherits: ^2.0.1 + safe-buffer: ^5.0.1 + checksum: 47d3568dbc17431a339bad1fe7dff83ac0891be8206911ace3d3b818fc695f376df809bea406e759cdea07fff4b454fa25f1013e648851bec790c1d75763032e + languageName: node + linkType: hard + +"classic-level@npm:^1.2.0": + version: 1.3.0 + resolution: "classic-level@npm:1.3.0" + dependencies: + abstract-level: ^1.0.2 + catering: ^2.1.0 + module-error: ^1.0.1 + napi-macros: ^2.2.2 + node-gyp: latest + node-gyp-build: ^4.3.0 + checksum: 773da48aef52a041115d413fee8340b357a4da2eb505764f327183b155edd7cc9d24819eb4f707c83dbdae8588024f5dddeb322125567c59d5d1f6f16334cdb9 + languageName: node + linkType: hard + +"clean-stack@npm:^2.0.0": + version: 2.2.0 + resolution: "clean-stack@npm:2.2.0" + checksum: 2ac8cd2b2f5ec986a3c743935ec85b07bc174d5421a5efc8017e1f146a1cf5f781ae962618f416352103b32c9cd7e203276e8c28241bbe946160cab16149fb68 + languageName: node + linkType: hard + +"clean-stack@npm:^3.0.0": + version: 3.0.1 + resolution: "clean-stack@npm:3.0.1" + dependencies: + escape-string-regexp: 4.0.0 + checksum: dc18c842d7792dd72d463936b1b0a5b2621f0fc11588ee48b602e1a29b6c010c606d89f3de1f95d15d72de74aea93c0fbac8246593a31d95f8462cac36148e05 + languageName: node + linkType: hard + +"cli-cursor@npm:^3.1.0": + version: 3.1.0 + resolution: "cli-cursor@npm:3.1.0" + dependencies: + restore-cursor: ^3.1.0 + checksum: 2692784c6cd2fd85cfdbd11f53aea73a463a6d64a77c3e098b2b4697a20443f430c220629e1ca3b195ea5ac4a97a74c2ee411f3807abf6df2b66211fec0c0a29 + languageName: node + linkType: hard + +"cli-table3@npm:^0.5.0": + version: 0.5.1 + resolution: "cli-table3@npm:0.5.1" + dependencies: + colors: ^1.1.2 + object-assign: ^4.1.0 + string-width: ^2.1.1 + dependenciesMeta: + colors: + optional: true + checksum: 3ff8c821440a2a0e655a01f04e5b54a0365b3814676cd93cec2b2b0b9952a08311797ad242a181733fcff714fa7d776f8bb45ad812f296390bfa5ef584fb231d + languageName: node + linkType: hard + +"cli-table3@npm:^0.6.0": + version: 0.6.3 + resolution: "cli-table3@npm:0.6.3" + dependencies: + "@colors/colors": 1.5.0 + string-width: ^4.2.0 + dependenciesMeta: + "@colors/colors": + optional: true + checksum: 09897f68467973f827c04e7eaadf13b55f8aec49ecd6647cc276386ea660059322e2dd8020a8b6b84d422dbdd619597046fa89cbbbdc95b2cea149a2df7c096c + languageName: node + linkType: hard + +"cli-truncate@npm:^2.1.0": + version: 2.1.0 + resolution: "cli-truncate@npm:2.1.0" + dependencies: + slice-ansi: ^3.0.0 + string-width: ^4.2.0 + checksum: bf1e4e6195392dc718bf9cd71f317b6300dc4a9191d052f31046b8773230ece4fa09458813bf0e3455a5e68c0690d2ea2c197d14a8b85a7b5e01c97f4b5feb5d + languageName: node + linkType: hard + +"cli-truncate@npm:^3.1.0": + version: 3.1.0 + resolution: "cli-truncate@npm:3.1.0" + dependencies: + slice-ansi: ^5.0.0 + string-width: ^5.0.0 + checksum: c3243e41974445691c63f8b405df1d5a24049dc33d324fe448dc572e561a7b772ae982692900b1a5960901cc4fc7def25a629b9c69a4208ee89d12ab3332617a + languageName: node + linkType: hard + +"cliui@npm:^5.0.0": + version: 5.0.0 + resolution: "cliui@npm:5.0.0" + dependencies: + string-width: ^3.1.0 + strip-ansi: ^5.2.0 + wrap-ansi: ^5.1.0 + checksum: 0bb8779efe299b8f3002a73619eaa8add4081eb8d1c17bc4fedc6240557fb4eacdc08fe87c39b002eacb6cfc117ce736b362dbfd8bf28d90da800e010ee97df4 + languageName: node + linkType: hard + +"cliui@npm:^7.0.2": + version: 7.0.4 + resolution: "cliui@npm:7.0.4" + dependencies: + string-width: ^4.2.0 + strip-ansi: ^6.0.0 + wrap-ansi: ^7.0.0 + checksum: ce2e8f578a4813806788ac399b9e866297740eecd4ad1823c27fd344d78b22c5f8597d548adbcc46f0573e43e21e751f39446c5a5e804a12aace402b7a315d7f + languageName: node + linkType: hard + +"color-convert@npm:^1.9.0": + version: 1.9.3 + resolution: "color-convert@npm:1.9.3" + dependencies: + color-name: 1.1.3 + checksum: fd7a64a17cde98fb923b1dd05c5f2e6f7aefda1b60d67e8d449f9328b4e53b228a428fd38bfeaeb2db2ff6b6503a776a996150b80cdf224062af08a5c8a3a203 + languageName: node + linkType: hard + +"color-convert@npm:^2.0.1": + version: 2.0.1 + resolution: "color-convert@npm:2.0.1" + dependencies: + color-name: ~1.1.4 + checksum: 79e6bdb9fd479a205c71d89574fccfb22bd9053bd98c6c4d870d65c132e5e904e6034978e55b43d69fcaa7433af2016ee203ce76eeba9cfa554b373e7f7db336 + languageName: node + linkType: hard + +"color-name@npm:1.1.3": + version: 1.1.3 + resolution: "color-name@npm:1.1.3" + checksum: 09c5d3e33d2105850153b14466501f2bfb30324a2f76568a408763a3b7433b0e50e5b4ab1947868e65cb101bb7cb75029553f2c333b6d4b8138a73fcc133d69d + languageName: node + linkType: hard + +"color-name@npm:~1.1.4": + version: 1.1.4 + resolution: "color-name@npm:1.1.4" + checksum: b0445859521eb4021cd0fb0cc1a75cecf67fceecae89b63f62b201cca8d345baf8b952c966862a9d9a2632987d4f6581f0ec8d957dfacece86f0a7919316f610 + languageName: node + linkType: hard + +"color-support@npm:^1.1.3": + version: 1.1.3 + resolution: "color-support@npm:1.1.3" + bin: + color-support: bin.js + checksum: 9b7356817670b9a13a26ca5af1c21615463b500783b739b7634a0c2047c16cef4b2865d7576875c31c3cddf9dd621fa19285e628f20198b233a5cfdda6d0793b + languageName: node + linkType: hard + +"colorette@npm:^2.0.19": + version: 2.0.20 + resolution: "colorette@npm:2.0.20" + checksum: 0c016fea2b91b733eb9f4bcdb580018f52c0bc0979443dad930e5037a968237ac53d9beb98e218d2e9235834f8eebce7f8e080422d6194e957454255bde71d3d + languageName: node + linkType: hard + +"colors@npm:1.4.0, colors@npm:^1.1.2": + version: 1.4.0 + resolution: "colors@npm:1.4.0" + checksum: 98aa2c2418ad87dedf25d781be69dc5fc5908e279d9d30c34d8b702e586a0474605b3a189511482b9d5ed0d20c867515d22749537f7bc546256c6014f3ebdcec + languageName: node + linkType: hard + +"combined-stream@npm:^1.0.6, combined-stream@npm:^1.0.8, combined-stream@npm:~1.0.6": + version: 1.0.8 + resolution: "combined-stream@npm:1.0.8" + dependencies: + delayed-stream: ~1.0.0 + checksum: 49fa4aeb4916567e33ea81d088f6584749fc90c7abec76fd516bf1c5aa5c79f3584b5ba3de6b86d26ddd64bae5329c4c7479343250cfe71c75bb366eae53bb7c + languageName: node + linkType: hard + +"command-exists@npm:^1.2.8": + version: 1.2.9 + resolution: "command-exists@npm:1.2.9" + checksum: 729ae3d88a2058c93c58840f30341b7f82688a573019535d198b57a4d8cb0135ced0ad7f52b591e5b28a90feb2c675080ce916e56254a0f7c15cb2395277cac3 + languageName: node + linkType: hard + +"command-line-args@npm:^5.1.1": + version: 5.2.1 + resolution: "command-line-args@npm:5.2.1" + dependencies: + array-back: ^3.1.0 + find-replace: ^3.0.0 + lodash.camelcase: ^4.3.0 + typical: ^4.0.0 + checksum: e759519087be3cf2e86af8b9a97d3058b4910cd11ee852495be881a067b72891f6a32718fb685ee6d41531ab76b2b7bfb6602f79f882cd4b7587ff1e827982c7 + languageName: node + linkType: hard + +"command-line-usage@npm:^6.1.0": + version: 6.1.3 + resolution: "command-line-usage@npm:6.1.3" + dependencies: + array-back: ^4.0.2 + chalk: ^2.4.2 + table-layout: ^1.0.2 + typical: ^5.2.0 + checksum: 8261d4e5536eb0bcddee0ec5e89c05bb2abd18e5760785c8078ede5020bc1c612cbe28eb6586f5ed4a3660689748e5aaad4a72f21566f4ef39393694e2fa1a0b + languageName: node + linkType: hard + +"commander@npm:3.0.2": + version: 3.0.2 + resolution: "commander@npm:3.0.2" + checksum: 6d14ad030d1904428139487ed31febcb04c1604db2b8d9fae711f60ee6718828dc0e11602249e91c8a97b0e721e9c6d53edbc166bad3cde1596851d59a8f824d + languageName: node + linkType: hard + +"commander@npm:^10.0.0": + version: 10.0.1 + resolution: "commander@npm:10.0.1" + checksum: 436901d64a818295803c1996cd856621a74f30b9f9e28a588e726b2b1670665bccd7c1a77007ebf328729f0139838a88a19265858a0fa7a8728c4656796db948 + languageName: node + linkType: hard + +"commander@npm:^8.1.0": + version: 8.3.0 + resolution: "commander@npm:8.3.0" + checksum: 0f82321821fc27b83bd409510bb9deeebcfa799ff0bf5d102128b500b7af22872c0c92cb6a0ebc5a4cf19c6b550fba9cedfa7329d18c6442a625f851377bacf0 + languageName: node + linkType: hard + +"concat-map@npm:0.0.1": + version: 0.0.1 + resolution: "concat-map@npm:0.0.1" + checksum: 902a9f5d8967a3e2faf138d5cb784b9979bad2e6db5357c5b21c568df4ebe62bcb15108af1b2253744844eb964fc023fbd9afbbbb6ddd0bcc204c6fb5b7bf3af + languageName: node + linkType: hard + +"concat-stream@npm:^1.6.0, concat-stream@npm:^1.6.2": + version: 1.6.2 + resolution: "concat-stream@npm:1.6.2" + dependencies: + buffer-from: ^1.0.0 + inherits: ^2.0.3 + readable-stream: ^2.2.2 + typedarray: ^0.0.6 + checksum: 1ef77032cb4459dcd5187bd710d6fc962b067b64ec6a505810de3d2b8cc0605638551b42f8ec91edf6fcd26141b32ef19ad749239b58fae3aba99187adc32285 + languageName: node + linkType: hard + +"console-control-strings@npm:^1.1.0": + version: 1.1.0 + resolution: "console-control-strings@npm:1.1.0" + checksum: 8755d76787f94e6cf79ce4666f0c5519906d7f5b02d4b884cf41e11dcd759ed69c57da0670afd9236d229a46e0f9cf519db0cd829c6dca820bb5a5c3def584ed + languageName: node + linkType: hard + +"console-table-printer@npm:^2.9.0": + version: 2.11.2 + resolution: "console-table-printer@npm:2.11.2" + dependencies: + simple-wcswidth: ^1.0.1 + checksum: 90bb40ef39f52356859067e39d0bf11e17f11ac920cd848ac373fa69dce9a2431505e61a174948eb8d6bbd820f19a013c8187034a15b6e744ddc79538de8bb4b + languageName: node + linkType: hard + +"cookie@npm:^0.4.1": + version: 0.4.2 + resolution: "cookie@npm:0.4.2" + checksum: a00833c998bedf8e787b4c342defe5fa419abd96b32f4464f718b91022586b8f1bafbddd499288e75c037642493c83083da426c6a9080d309e3bd90fd11baa9b + languageName: node + linkType: hard + +"core-util-is@npm:1.0.2": + version: 1.0.2 + resolution: "core-util-is@npm:1.0.2" + checksum: 7a4c925b497a2c91421e25bf76d6d8190f0b2359a9200dbeed136e63b2931d6294d3b1893eda378883ed363cd950f44a12a401384c609839ea616befb7927dab + languageName: node + linkType: hard + +"core-util-is@npm:~1.0.0": + version: 1.0.3 + resolution: "core-util-is@npm:1.0.3" + checksum: 9de8597363a8e9b9952491ebe18167e3b36e7707569eed0ebf14f8bba773611376466ae34575bca8cfe3c767890c859c74056084738f09d4e4a6f902b2ad7d99 + languageName: node + linkType: hard + +"cosmiconfig@npm:^8.0.0": + version: 8.2.0 + resolution: "cosmiconfig@npm:8.2.0" + dependencies: + import-fresh: ^3.2.1 + js-yaml: ^4.1.0 + parse-json: ^5.0.0 + path-type: ^4.0.0 + checksum: 836d5d8efa750f3fb17b03d6ca74cd3154ed025dffd045304b3ef59637f662bde1e5dc88f8830080d180ec60841719cf4ea2ce73fb21ec694b16865c478ff297 + languageName: node + linkType: hard + +"crc-32@npm:^1.2.0": + version: 1.2.2 + resolution: "crc-32@npm:1.2.2" + bin: + crc32: bin/crc32.njs + checksum: ad2d0ad0cbd465b75dcaeeff0600f8195b686816ab5f3ba4c6e052a07f728c3e70df2e3ca9fd3d4484dc4ba70586e161ca5a2334ec8bf5a41bf022a6103ff243 + languageName: node + linkType: hard + +"create-hash@npm:^1.1.0, create-hash@npm:^1.1.2, create-hash@npm:^1.2.0": + version: 1.2.0 + resolution: "create-hash@npm:1.2.0" + dependencies: + cipher-base: ^1.0.1 + inherits: ^2.0.1 + md5.js: ^1.3.4 + ripemd160: ^2.0.1 + sha.js: ^2.4.0 + checksum: 02a6ae3bb9cd4afee3fabd846c1d8426a0e6b495560a977ba46120c473cb283be6aa1cace76b5f927cf4e499c6146fb798253e48e83d522feba807d6b722eaa9 + languageName: node + linkType: hard + +"create-hmac@npm:^1.1.4, create-hmac@npm:^1.1.7": + version: 1.1.7 + resolution: "create-hmac@npm:1.1.7" + dependencies: + cipher-base: ^1.0.3 + create-hash: ^1.1.0 + inherits: ^2.0.1 + ripemd160: ^2.0.0 + safe-buffer: ^5.0.1 + sha.js: ^2.4.8 + checksum: ba12bb2257b585a0396108c72830e85f882ab659c3320c83584b1037f8ab72415095167ced80dc4ce8e446a8ecc4b2acf36d87befe0707d73b26cf9dc77440ed + languageName: node + linkType: hard + +"create-require@npm:^1.1.0": + version: 1.1.1 + resolution: "create-require@npm:1.1.1" + checksum: a9a1503d4390d8b59ad86f4607de7870b39cad43d929813599a23714831e81c520bddf61bcdd1f8e30f05fd3a2b71ae8538e946eb2786dc65c2bbc520f692eff + languageName: node + linkType: hard + +"cross-spawn@npm:^7.0.0, cross-spawn@npm:^7.0.3": + version: 7.0.3 + resolution: "cross-spawn@npm:7.0.3" + dependencies: + path-key: ^3.1.0 + shebang-command: ^2.0.0 + which: ^2.0.1 + checksum: 671cc7c7288c3a8406f3c69a3ae2fc85555c04169e9d611def9a675635472614f1c0ed0ef80955d5b6d4e724f6ced67f0ad1bb006c2ea643488fcfef994d7f52 + languageName: node + linkType: hard + +"crypt@npm:>= 0.0.1": + version: 0.0.2 + resolution: "crypt@npm:0.0.2" + checksum: baf4c7bbe05df656ec230018af8cf7dbe8c14b36b98726939cef008d473f6fe7a4fad906cfea4062c93af516f1550a3f43ceb4d6615329612c6511378ed9fe34 + languageName: node + linkType: hard + +"dashdash@npm:^1.12.0": + version: 1.14.1 + resolution: "dashdash@npm:1.14.1" + dependencies: + assert-plus: ^1.0.0 + checksum: 3634c249570f7f34e3d34f866c93f866c5b417f0dd616275decae08147dcdf8fccfaa5947380ccfb0473998ea3a8057c0b4cd90c875740ee685d0624b2983598 + languageName: node + linkType: hard + +"debug@npm:3.2.6": + version: 3.2.6 + resolution: "debug@npm:3.2.6" + dependencies: + ms: ^2.1.1 + checksum: 07bc8b3a13ef3cfa6c06baf7871dfb174c291e5f85dbf566f086620c16b9c1a0e93bb8f1935ebbd07a683249e7e30286f2966e2ef461e8fd17b1b60732062d6b + languageName: node + linkType: hard + +"debug@npm:4, debug@npm:4.3.4, debug@npm:^4.1.1, debug@npm:^4.3.2, debug@npm:^4.3.3, debug@npm:^4.3.4": + version: 4.3.4 + resolution: "debug@npm:4.3.4" + dependencies: + ms: 2.1.2 + peerDependenciesMeta: + supports-color: + optional: true + checksum: 3dbad3f94ea64f34431a9cbf0bafb61853eda57bff2880036153438f50fb5a84f27683ba0d8e5426bf41a8c6ff03879488120cf5b3a761e77953169c0600a708 + languageName: node + linkType: hard + +"decamelize@npm:^1.2.0": + version: 1.2.0 + resolution: "decamelize@npm:1.2.0" + checksum: ad8c51a7e7e0720c70ec2eeb1163b66da03e7616d7b98c9ef43cce2416395e84c1e9548dd94f5f6ffecfee9f8b94251fc57121a8b021f2ff2469b2bae247b8aa + languageName: node + linkType: hard + +"decamelize@npm:^4.0.0": + version: 4.0.0 + resolution: "decamelize@npm:4.0.0" + checksum: b7d09b82652c39eead4d6678bb578e3bebd848add894b76d0f6b395bc45b2d692fb88d977e7cfb93c4ed6c119b05a1347cef261174916c2e75c0a8ca57da1809 + languageName: node + linkType: hard + +"deep-eql@npm:^4.0.1, deep-eql@npm:^4.1.2": + version: 4.1.3 + resolution: "deep-eql@npm:4.1.3" + dependencies: + type-detect: ^4.0.0 + checksum: 7f6d30cb41c713973dc07eaadded848b2ab0b835e518a88b91bea72f34e08c4c71d167a722a6f302d3a6108f05afd8e6d7650689a84d5d29ec7fe6220420397f + languageName: node + linkType: hard + +"deep-extend@npm:~0.6.0": + version: 0.6.0 + resolution: "deep-extend@npm:0.6.0" + checksum: 7be7e5a8d468d6b10e6a67c3de828f55001b6eb515d014f7aeb9066ce36bd5717161eb47d6a0f7bed8a9083935b465bc163ee2581c8b128d29bf61092fdf57a7 + languageName: node + linkType: hard + +"define-properties@npm:^1.1.2, define-properties@npm:^1.1.3, define-properties@npm:^1.1.4, define-properties@npm:^1.2.0": + version: 1.2.0 + resolution: "define-properties@npm:1.2.0" + dependencies: + has-property-descriptors: ^1.0.0 + object-keys: ^1.1.1 + checksum: e60aee6a19b102df4e2b1f301816804e81ab48bb91f00d0d935f269bf4b3f79c88b39e4f89eaa132890d23267335fd1140dfcd8d5ccd61031a0a2c41a54e33a6 + languageName: node + linkType: hard + +"delayed-stream@npm:~1.0.0": + version: 1.0.0 + resolution: "delayed-stream@npm:1.0.0" + checksum: 46fe6e83e2cb1d85ba50bd52803c68be9bd953282fa7096f51fc29edd5d67ff84ff753c51966061e5ba7cb5e47ef6d36a91924eddb7f3f3483b1c560f77a0020 + languageName: node + linkType: hard + +"delegates@npm:^1.0.0": + version: 1.0.0 + resolution: "delegates@npm:1.0.0" + checksum: a51744d9b53c164ba9c0492471a1a2ffa0b6727451bdc89e31627fdf4adda9d51277cfcbfb20f0a6f08ccb3c436f341df3e92631a3440226d93a8971724771fd + languageName: node + linkType: hard + +"depd@npm:2.0.0": + version: 2.0.0 + resolution: "depd@npm:2.0.0" + checksum: abbe19c768c97ee2eed6282d8ce3031126662252c58d711f646921c9623f9052e3e1906443066beec1095832f534e57c523b7333f8e7e0d93051ab6baef5ab3a + languageName: node + linkType: hard + +"diff@npm:3.5.0": + version: 3.5.0 + resolution: "diff@npm:3.5.0" + checksum: 00842950a6551e26ce495bdbce11047e31667deea546527902661f25cc2e73358967ebc78cf86b1a9736ec3e14286433225f9970678155753a6291c3bca5227b + languageName: node + linkType: hard + +"diff@npm:5.0.0": + version: 5.0.0 + resolution: "diff@npm:5.0.0" + checksum: f19fe29284b633afdb2725c2a8bb7d25761ea54d321d8e67987ac851c5294be4afeab532bd84531e02583a3fe7f4014aa314a3eda84f5590e7a9e6b371ef3b46 + languageName: node + linkType: hard + +"diff@npm:^4.0.1": + version: 4.0.2 + resolution: "diff@npm:4.0.2" + checksum: f2c09b0ce4e6b301c221addd83bf3f454c0bc00caa3dd837cf6c127d6edf7223aa2bbe3b688feea110b7f262adbfc845b757c44c8a9f8c0c5b15d8fa9ce9d20d + languageName: node + linkType: hard + +"dir-glob@npm:^3.0.1": + version: 3.0.1 + resolution: "dir-glob@npm:3.0.1" + dependencies: + path-type: ^4.0.0 + checksum: fa05e18324510d7283f55862f3161c6759a3f2f8dbce491a2fc14c8324c498286c54282c1f0e933cb930da8419b30679389499b919122952a4f8592362ef4615 + languageName: node + linkType: hard + +"dotenv@npm:^10.0.0": + version: 10.0.0 + resolution: "dotenv@npm:10.0.0" + checksum: f412c5fe8c24fbe313d302d2500e247ba8a1946492db405a4de4d30dd0eb186a88a43f13c958c5a7de303938949c4231c56994f97d05c4bc1f22478d631b4005 + languageName: node + linkType: hard + +"eastasianwidth@npm:^0.2.0": + version: 0.2.0 + resolution: "eastasianwidth@npm:0.2.0" + checksum: 7d00d7cd8e49b9afa762a813faac332dee781932d6f2c848dc348939c4253f1d4564341b7af1d041853bc3f32c2ef141b58e0a4d9862c17a7f08f68df1e0f1ed + languageName: node + linkType: hard + +"ecc-jsbn@npm:~0.1.1": + version: 0.1.2 + resolution: "ecc-jsbn@npm:0.1.2" + dependencies: + jsbn: ~0.1.0 + safer-buffer: ^2.1.0 + checksum: 22fef4b6203e5f31d425f5b711eb389e4c6c2723402e389af394f8411b76a488fa414d309d866e2b577ce3e8462d344205545c88a8143cc21752a5172818888a + languageName: node + linkType: hard + +"elliptic@npm:6.5.4, elliptic@npm:^6.5.2, elliptic@npm:^6.5.4": + version: 6.5.4 + resolution: "elliptic@npm:6.5.4" + dependencies: + bn.js: ^4.11.9 + brorand: ^1.1.0 + hash.js: ^1.0.0 + hmac-drbg: ^1.0.1 + inherits: ^2.0.4 + minimalistic-assert: ^1.0.1 + minimalistic-crypto-utils: ^1.0.1 + checksum: d56d21fd04e97869f7ffcc92e18903b9f67f2d4637a23c860492fbbff5a3155fd9ca0184ce0c865dd6eb2487d234ce9551335c021c376cd2d3b7cb749c7d10f4 + languageName: node + linkType: hard + +"emoji-regex@npm:^7.0.1": + version: 7.0.3 + resolution: "emoji-regex@npm:7.0.3" + checksum: 9159b2228b1511f2870ac5920f394c7e041715429a68459ebe531601555f11ea782a8e1718f969df2711d38c66268174407cbca57ce36485544f695c2dfdc96e + languageName: node + linkType: hard + +"emoji-regex@npm:^8.0.0": + version: 8.0.0 + resolution: "emoji-regex@npm:8.0.0" + checksum: d4c5c39d5a9868b5fa152f00cada8a936868fd3367f33f71be515ecee4c803132d11b31a6222b2571b1e5f7e13890156a94880345594d0ce7e3c9895f560f192 + languageName: node + linkType: hard + +"emoji-regex@npm:^9.2.2": + version: 9.2.2 + resolution: "emoji-regex@npm:9.2.2" + checksum: 8487182da74aabd810ac6d6f1994111dfc0e331b01271ae01ec1eb0ad7b5ecc2bbbbd2f053c05cb55a1ac30449527d819bbfbf0e3de1023db308cbcb47f86601 + languageName: node + linkType: hard + +"encode-utf8@npm:^1.0.2": + version: 1.0.3 + resolution: "encode-utf8@npm:1.0.3" + checksum: 550224bf2a104b1d355458c8a82e9b4ea07f9fc78387bc3a49c151b940ad26473de8dc9e121eefc4e84561cb0b46de1e4cd2bc766f72ee145e9ea9541482817f + languageName: node + linkType: hard + +"encoding@npm:^0.1.13": + version: 0.1.13 + resolution: "encoding@npm:0.1.13" + dependencies: + iconv-lite: ^0.6.2 + checksum: bb98632f8ffa823996e508ce6a58ffcf5856330fde839ae42c9e1f436cc3b5cc651d4aeae72222916545428e54fd0f6aa8862fd8d25bdbcc4589f1e3f3715e7f + languageName: node + linkType: hard + +"enquirer@npm:^2.3.0, enquirer@npm:^2.3.6": + version: 2.4.1 + resolution: "enquirer@npm:2.4.1" + dependencies: + ansi-colors: ^4.1.1 + strip-ansi: ^6.0.1 + checksum: f080f11a74209647dbf347a7c6a83c8a47ae1ebf1e75073a808bc1088eb780aa54075bfecd1bcdb3e3c724520edb8e6ee05da031529436b421b71066fcc48cb5 + languageName: node + linkType: hard + +"env-paths@npm:^2.2.0": + version: 2.2.1 + resolution: "env-paths@npm:2.2.1" + checksum: 65b5df55a8bab92229ab2b40dad3b387fad24613263d103a97f91c9fe43ceb21965cd3392b1ccb5d77088021e525c4e0481adb309625d0cb94ade1d1fb8dc17e + languageName: node + linkType: hard + +"err-code@npm:^2.0.2": + version: 2.0.3 + resolution: "err-code@npm:2.0.3" + checksum: 8b7b1be20d2de12d2255c0bc2ca638b7af5171142693299416e6a9339bd7d88fc8d7707d913d78e0993176005405a236b066b45666b27b797252c771156ace54 + languageName: node + linkType: hard + +"error-ex@npm:^1.3.1": + version: 1.3.2 + resolution: "error-ex@npm:1.3.2" + dependencies: + is-arrayish: ^0.2.1 + checksum: c1c2b8b65f9c91b0f9d75f0debaa7ec5b35c266c2cac5de412c1a6de86d4cbae04ae44e510378cb14d032d0645a36925d0186f8bb7367bcc629db256b743a001 + languageName: node + linkType: hard + +"es-abstract@npm:^1.19.0, es-abstract@npm:^1.20.4, es-abstract@npm:^1.21.2": + version: 1.22.1 + resolution: "es-abstract@npm:1.22.1" + dependencies: + array-buffer-byte-length: ^1.0.0 + arraybuffer.prototype.slice: ^1.0.1 + available-typed-arrays: ^1.0.5 + call-bind: ^1.0.2 + es-set-tostringtag: ^2.0.1 + es-to-primitive: ^1.2.1 + function.prototype.name: ^1.1.5 + get-intrinsic: ^1.2.1 + get-symbol-description: ^1.0.0 + globalthis: ^1.0.3 + gopd: ^1.0.1 + has: ^1.0.3 + has-property-descriptors: ^1.0.0 + has-proto: ^1.0.1 + has-symbols: ^1.0.3 + internal-slot: ^1.0.5 + is-array-buffer: ^3.0.2 + is-callable: ^1.2.7 + is-negative-zero: ^2.0.2 + is-regex: ^1.1.4 + is-shared-array-buffer: ^1.0.2 + is-string: ^1.0.7 + is-typed-array: ^1.1.10 + is-weakref: ^1.0.2 + object-inspect: ^1.12.3 + object-keys: ^1.1.1 + object.assign: ^4.1.4 + regexp.prototype.flags: ^1.5.0 + safe-array-concat: ^1.0.0 + safe-regex-test: ^1.0.0 + string.prototype.trim: ^1.2.7 + string.prototype.trimend: ^1.0.6 + string.prototype.trimstart: ^1.0.6 + typed-array-buffer: ^1.0.0 + typed-array-byte-length: ^1.0.0 + typed-array-byte-offset: ^1.0.0 + typed-array-length: ^1.0.4 + unbox-primitive: ^1.0.2 + which-typed-array: ^1.1.10 + checksum: 614e2c1c3717cb8d30b6128ef12ea110e06fd7d75ad77091ca1c5dbfb00da130e62e4bbbbbdda190eada098a22b27fe0f99ae5a1171dac2c8663b1e8be8a3a9b + languageName: node + linkType: hard + +"es-array-method-boxes-properly@npm:^1.0.0": + version: 1.0.0 + resolution: "es-array-method-boxes-properly@npm:1.0.0" + checksum: 2537fcd1cecf187083890bc6f5236d3a26bf39237433587e5bf63392e88faae929dbba78ff0120681a3f6f81c23fe3816122982c160d63b38c95c830b633b826 + languageName: node + linkType: hard + +"es-set-tostringtag@npm:^2.0.1": + version: 2.0.1 + resolution: "es-set-tostringtag@npm:2.0.1" + dependencies: + get-intrinsic: ^1.1.3 + has: ^1.0.3 + has-tostringtag: ^1.0.0 + checksum: ec416a12948cefb4b2a5932e62093a7cf36ddc3efd58d6c58ca7ae7064475ace556434b869b0bbeb0c365f1032a8ccd577211101234b69837ad83ad204fff884 + languageName: node + linkType: hard + +"es-to-primitive@npm:^1.2.1": + version: 1.2.1 + resolution: "es-to-primitive@npm:1.2.1" + dependencies: + is-callable: ^1.1.4 + is-date-object: ^1.0.1 + is-symbol: ^1.0.2 + checksum: 4ead6671a2c1402619bdd77f3503991232ca15e17e46222b0a41a5d81aebc8740a77822f5b3c965008e631153e9ef0580540007744521e72de8e33599fca2eed + languageName: node + linkType: hard + +"escalade@npm:^3.1.1": + version: 3.1.1 + resolution: "escalade@npm:3.1.1" + checksum: a3e2a99f07acb74b3ad4989c48ca0c3140f69f923e56d0cba0526240ee470b91010f9d39001f2a4a313841d237ede70a729e92125191ba5d21e74b106800b133 + languageName: node + linkType: hard + +"escape-string-regexp@npm:1.0.5, escape-string-regexp@npm:^1.0.5": + version: 1.0.5 + resolution: "escape-string-regexp@npm:1.0.5" + checksum: 6092fda75c63b110c706b6a9bfde8a612ad595b628f0bd2147eea1d3406723020810e591effc7db1da91d80a71a737a313567c5abb3813e8d9c71f4aa595b410 + languageName: node + linkType: hard + +"escape-string-regexp@npm:4.0.0": + version: 4.0.0 + resolution: "escape-string-regexp@npm:4.0.0" + checksum: 98b48897d93060f2322108bf29db0feba7dd774be96cd069458d1453347b25ce8682ecc39859d4bca2203cc0ab19c237bcc71755eff49a0f8d90beadeeba5cc5 + languageName: node + linkType: hard + +"esprima@npm:^4.0.0": + version: 4.0.1 + resolution: "esprima@npm:4.0.1" + bin: + esparse: ./bin/esparse.js + esvalidate: ./bin/esvalidate.js + checksum: b45bc805a613dbea2835278c306b91aff6173c8d034223fa81498c77dcbce3b2931bf6006db816f62eacd9fd4ea975dfd85a5b7f3c6402cfd050d4ca3c13a628 + languageName: node + linkType: hard + +"eth-gas-reporter@npm:^0.2.25": + version: 0.2.25 + resolution: "eth-gas-reporter@npm:0.2.25" + dependencies: + "@ethersproject/abi": ^5.0.0-beta.146 + "@solidity-parser/parser": ^0.14.0 + cli-table3: ^0.5.0 + colors: 1.4.0 + ethereum-cryptography: ^1.0.3 + ethers: ^4.0.40 + fs-readdir-recursive: ^1.1.0 + lodash: ^4.17.14 + markdown-table: ^1.1.3 + mocha: ^7.1.1 + req-cwd: ^2.0.0 + request: ^2.88.0 + request-promise-native: ^1.0.5 + sha1: ^1.1.1 + sync-request: ^6.0.0 + peerDependencies: + "@codechecks/client": ^0.1.0 + peerDependenciesMeta: + "@codechecks/client": + optional: true + checksum: 3bfa81e554b069bb817f2a073a601a0429e6b582c56ad99db0727dc2a102ab00fc27888820b8a042a194a8fb7d40954d10cd7b011ede6b8170285d2d5a88666c + languageName: node + linkType: hard + +"ethereum-cryptography@npm:0.1.3, ethereum-cryptography@npm:^0.1.3": + version: 0.1.3 + resolution: "ethereum-cryptography@npm:0.1.3" + dependencies: + "@types/pbkdf2": ^3.0.0 + "@types/secp256k1": ^4.0.1 + blakejs: ^1.1.0 + browserify-aes: ^1.2.0 + bs58check: ^2.1.2 + create-hash: ^1.2.0 + create-hmac: ^1.1.7 + hash.js: ^1.1.7 + keccak: ^3.0.0 + pbkdf2: ^3.0.17 + randombytes: ^2.1.0 + safe-buffer: ^5.1.2 + scrypt-js: ^3.0.0 + secp256k1: ^4.0.1 + setimmediate: ^1.0.5 + checksum: 54bae7a4a96bd81398cdc35c91cfcc74339f71a95ed1b5b694663782e69e8e3afd21357de3b8bac9ff4877fd6f043601e200a7ad9133d94be6fd7d898ee0a449 + languageName: node + linkType: hard + +"ethereum-cryptography@npm:^1.0.3": + version: 1.2.0 + resolution: "ethereum-cryptography@npm:1.2.0" + dependencies: + "@noble/hashes": 1.2.0 + "@noble/secp256k1": 1.7.1 + "@scure/bip32": 1.1.5 + "@scure/bip39": 1.1.1 + checksum: 97e8e8253cb9f5a9271bd0201c37609c451c890eb85883b9c564f14743c3d7c673287406c93bf5604307593ee298ad9a03983388b85c11ca61461b9fc1a4f2c7 + languageName: node + linkType: hard + +"ethereumjs-abi@npm:^0.6.8": + version: 0.6.8 + resolution: "ethereumjs-abi@npm:0.6.8" + dependencies: + bn.js: ^4.11.8 + ethereumjs-util: ^6.0.0 + checksum: cede2a8ae7c7e04eeaec079c2f925601a25b2ef75cf9230e7c5da63b4ea27883b35447365a47e35c1e831af520973a2252af89022c292c18a09a4607821a366b + languageName: node + linkType: hard + +"ethereumjs-util@npm:^6.0.0, ethereumjs-util@npm:^6.2.1": + version: 6.2.1 + resolution: "ethereumjs-util@npm:6.2.1" + dependencies: + "@types/bn.js": ^4.11.3 + bn.js: ^4.11.0 + create-hash: ^1.1.2 + elliptic: ^6.5.2 + ethereum-cryptography: ^0.1.3 + ethjs-util: 0.1.6 + rlp: ^2.2.3 + checksum: e3cb4a2c034a2529281fdfc21a2126fe032fdc3038863f5720352daa65ddcc50fc8c67dbedf381a882dc3802e05d979287126d7ecf781504bde1fd8218693bde + languageName: node + linkType: hard + +"ethers@npm:^4.0.40": + version: 4.0.49 + resolution: "ethers@npm:4.0.49" + dependencies: + aes-js: 3.0.0 + bn.js: ^4.11.9 + elliptic: 6.5.4 + hash.js: 1.1.3 + js-sha3: 0.5.7 + scrypt-js: 2.0.4 + setimmediate: 1.0.4 + uuid: 2.0.1 + xmlhttprequest: 1.8.0 + checksum: 357115348a5f1484c7745fae1d852876788216c7d94c072c80132192f1800c4d388433ea2456750856641d6d4eed8a3b41847eb44f5e1c42139963864e3bcc38 + languageName: node + linkType: hard + +"ethers@npm:^5.5.2, ethers@npm:^5.5.3, ethers@npm:^5.7.1": + version: 5.7.2 + resolution: "ethers@npm:5.7.2" + dependencies: + "@ethersproject/abi": 5.7.0 + "@ethersproject/abstract-provider": 5.7.0 + "@ethersproject/abstract-signer": 5.7.0 + "@ethersproject/address": 5.7.0 + "@ethersproject/base64": 5.7.0 + "@ethersproject/basex": 5.7.0 + "@ethersproject/bignumber": 5.7.0 + "@ethersproject/bytes": 5.7.0 + "@ethersproject/constants": 5.7.0 + "@ethersproject/contracts": 5.7.0 + "@ethersproject/hash": 5.7.0 + "@ethersproject/hdnode": 5.7.0 + "@ethersproject/json-wallets": 5.7.0 + "@ethersproject/keccak256": 5.7.0 + "@ethersproject/logger": 5.7.0 + "@ethersproject/networks": 5.7.1 + "@ethersproject/pbkdf2": 5.7.0 + "@ethersproject/properties": 5.7.0 + "@ethersproject/providers": 5.7.2 + "@ethersproject/random": 5.7.0 + "@ethersproject/rlp": 5.7.0 + "@ethersproject/sha2": 5.7.0 + "@ethersproject/signing-key": 5.7.0 + "@ethersproject/solidity": 5.7.0 + "@ethersproject/strings": 5.7.0 + "@ethersproject/transactions": 5.7.0 + "@ethersproject/units": 5.7.0 + "@ethersproject/wallet": 5.7.0 + "@ethersproject/web": 5.7.1 + "@ethersproject/wordlists": 5.7.0 + checksum: b7c08cf3e257185a7946117dbbf764433b7ba0e77c27298dec6088b3bc871aff711462b0621930c56880ff0a7ceb8b1d3a361ffa259f93377b48e34107f62553 + languageName: node + linkType: hard + +"ethjs-util@npm:0.1.6, ethjs-util@npm:^0.1.6": + version: 0.1.6 + resolution: "ethjs-util@npm:0.1.6" + dependencies: + is-hex-prefixed: 1.0.0 + strip-hex-prefix: 1.0.0 + checksum: 1f42959e78ec6f49889c49c8a98639e06f52a15966387dd39faf2930db48663d026efb7db2702dcffe7f2a99c4a0144b7ce784efdbf733f4077aae95de76d65f + languageName: node + linkType: hard + +"event-target-shim@npm:^5.0.0": + version: 5.0.1 + resolution: "event-target-shim@npm:5.0.1" + checksum: 1ffe3bb22a6d51bdeb6bf6f7cf97d2ff4a74b017ad12284cc9e6a279e727dc30a5de6bb613e5596ff4dc3e517841339ad09a7eec44266eccb1aa201a30448166 + languageName: node + linkType: hard + +"evp_bytestokey@npm:^1.0.3": + version: 1.0.3 + resolution: "evp_bytestokey@npm:1.0.3" + dependencies: + md5.js: ^1.3.4 + node-gyp: latest + safe-buffer: ^5.1.1 + checksum: ad4e1577f1a6b721c7800dcc7c733fe01f6c310732bb5bf2240245c2a5b45a38518b91d8be2c610611623160b9d1c0e91f1ce96d639f8b53e8894625cf20fa45 + languageName: node + linkType: hard + +"execa@npm:^7.0.0": + version: 7.2.0 + resolution: "execa@npm:7.2.0" + dependencies: + cross-spawn: ^7.0.3 + get-stream: ^6.0.1 + human-signals: ^4.3.0 + is-stream: ^3.0.0 + merge-stream: ^2.0.0 + npm-run-path: ^5.1.0 + onetime: ^6.0.0 + signal-exit: ^3.0.7 + strip-final-newline: ^3.0.0 + checksum: 14fd17ba0ca8c87b277584d93b1d9fc24f2a65e5152b31d5eb159a3b814854283eaae5f51efa9525e304447e2f757c691877f7adff8fde5746aae67eb1edd1cc + languageName: node + linkType: hard + +"exponential-backoff@npm:^3.1.1": + version: 3.1.1 + resolution: "exponential-backoff@npm:3.1.1" + checksum: 3d21519a4f8207c99f7457287291316306255a328770d320b401114ec8481986e4e467e854cb9914dd965e0a1ca810a23ccb559c642c88f4c7f55c55778a9b48 + languageName: node + linkType: hard + +"extend@npm:~3.0.2": + version: 3.0.2 + resolution: "extend@npm:3.0.2" + checksum: a50a8309ca65ea5d426382ff09f33586527882cf532931cb08ca786ea3146c0553310bda688710ff61d7668eba9f96b923fe1420cdf56a2c3eaf30fcab87b515 + languageName: node + linkType: hard + +"extsprintf@npm:1.3.0": + version: 1.3.0 + resolution: "extsprintf@npm:1.3.0" + checksum: cee7a4a1e34cffeeec18559109de92c27517e5641991ec6bab849aa64e3081022903dd53084f2080d0d2530803aa5ee84f1e9de642c365452f9e67be8f958ce2 + languageName: node + linkType: hard + +"extsprintf@npm:^1.2.0": + version: 1.4.1 + resolution: "extsprintf@npm:1.4.1" + checksum: a2f29b241914a8d2bad64363de684821b6b1609d06ae68d5b539e4de6b28659715b5bea94a7265201603713b7027d35399d10b0548f09071c5513e65e8323d33 + languageName: node + linkType: hard + +"fast-deep-equal@npm:^3.1.1": + version: 3.1.3 + resolution: "fast-deep-equal@npm:3.1.3" + checksum: e21a9d8d84f53493b6aa15efc9cfd53dd5b714a1f23f67fb5dc8f574af80df889b3bce25dc081887c6d25457cce704e636395333abad896ccdec03abaf1f3f9d + languageName: node + linkType: hard + +"fast-diff@npm:^1.2.0": + version: 1.3.0 + resolution: "fast-diff@npm:1.3.0" + checksum: d22d371b994fdc8cce9ff510d7b8dc4da70ac327bcba20df607dd5b9cae9f908f4d1028f5fe467650f058d1e7270235ae0b8230809a262b4df587a3b3aa216c3 + languageName: node + linkType: hard + +"fast-glob@npm:^3.2.9": + version: 3.3.1 + resolution: "fast-glob@npm:3.3.1" + dependencies: + "@nodelib/fs.stat": ^2.0.2 + "@nodelib/fs.walk": ^1.2.3 + glob-parent: ^5.1.2 + merge2: ^1.3.0 + micromatch: ^4.0.4 + checksum: b6f3add6403e02cf3a798bfbb1183d0f6da2afd368f27456010c0bc1f9640aea308243d4cb2c0ab142f618276e65ecb8be1661d7c62a7b4e5ba774b9ce5432e5 + languageName: node + linkType: hard + +"fast-json-stable-stringify@npm:^2.0.0": + version: 2.1.0 + resolution: "fast-json-stable-stringify@npm:2.1.0" + checksum: b191531e36c607977e5b1c47811158733c34ccb3bfde92c44798929e9b4154884378536d26ad90dfecd32e1ffc09c545d23535ad91b3161a27ddbb8ebe0cbecb + languageName: node + linkType: hard + +"fastq@npm:^1.6.0": + version: 1.15.0 + resolution: "fastq@npm:1.15.0" + dependencies: + reusify: ^1.0.4 + checksum: 0170e6bfcd5d57a70412440b8ef600da6de3b2a6c5966aeaf0a852d542daff506a0ee92d6de7679d1de82e644bce69d7a574a6c93f0b03964b5337eed75ada1a + languageName: node + linkType: hard + +"fill-range@npm:^7.0.1": + version: 7.0.1 + resolution: "fill-range@npm:7.0.1" + dependencies: + to-regex-range: ^5.0.1 + checksum: cc283f4e65b504259e64fd969bcf4def4eb08d85565e906b7d36516e87819db52029a76b6363d0f02d0d532f0033c9603b9e2d943d56ee3b0d4f7ad3328ff917 + languageName: node + linkType: hard + +"find-replace@npm:^3.0.0": + version: 3.0.0 + resolution: "find-replace@npm:3.0.0" + dependencies: + array-back: ^3.0.1 + checksum: 6b04bcfd79027f5b84aa1dfe100e3295da989bdac4b4de6b277f4d063e78f5c9e92ebc8a1fec6dd3b448c924ba404ee051cc759e14a3ee3e825fa1361025df08 + languageName: node + linkType: hard + +"find-up@npm:3.0.0, find-up@npm:^3.0.0": + version: 3.0.0 + resolution: "find-up@npm:3.0.0" + dependencies: + locate-path: ^3.0.0 + checksum: 38eba3fe7a66e4bc7f0f5a1366dc25508b7cfc349f852640e3678d26ad9a6d7e2c43eff0a472287de4a9753ef58f066a0ea892a256fa3636ad51b3fe1e17fae9 + languageName: node + linkType: hard + +"find-up@npm:5.0.0": + version: 5.0.0 + resolution: "find-up@npm:5.0.0" + dependencies: + locate-path: ^6.0.0 + path-exists: ^4.0.0 + checksum: 07955e357348f34660bde7920783204ff5a26ac2cafcaa28bace494027158a97b9f56faaf2d89a6106211a8174db650dd9f503f9c0d526b1202d5554a00b9095 + languageName: node + linkType: hard + +"find-up@npm:^2.1.0": + version: 2.1.0 + resolution: "find-up@npm:2.1.0" + dependencies: + locate-path: ^2.0.0 + checksum: 43284fe4da09f89011f08e3c32cd38401e786b19226ea440b75386c1b12a4cb738c94969808d53a84f564ede22f732c8409e3cfc3f7fb5b5c32378ad0bbf28bd + languageName: node + linkType: hard + +"flat@npm:^4.1.0": + version: 4.1.1 + resolution: "flat@npm:4.1.1" + dependencies: + is-buffer: ~2.0.3 + bin: + flat: cli.js + checksum: 398be12185eb0f3c59797c3670a8c35d07020b673363175676afbaf53d6b213660e060488554cf82c25504986e1a6059bdbcc5d562e87ca3e972e8a33148e3ae + languageName: node + linkType: hard + +"flat@npm:^5.0.2": + version: 5.0.2 + resolution: "flat@npm:5.0.2" + bin: + flat: cli.js + checksum: 12a1536ac746db74881316a181499a78ef953632ddd28050b7a3a43c62ef5462e3357c8c29d76072bb635f147f7a9a1f0c02efef6b4be28f8db62ceb3d5c7f5d + languageName: node + linkType: hard + +"fmix@npm:^0.1.0": + version: 0.1.0 + resolution: "fmix@npm:0.1.0" + dependencies: + imul: ^1.0.0 + checksum: c465344d4f169eaf10d45c33949a1e7a633f09dba2ac7063ce8ae8be743df5979d708f7f24900163589f047f5194ac5fc2476177ce31175e8805adfa7b8fb7a4 + languageName: node + linkType: hard + +"follow-redirects@npm:^1.12.1, follow-redirects@npm:^1.14.0, follow-redirects@npm:^1.14.4": + version: 1.15.2 + resolution: "follow-redirects@npm:1.15.2" + peerDependenciesMeta: + debug: + optional: true + checksum: faa66059b66358ba65c234c2f2a37fcec029dc22775f35d9ad6abac56003268baf41e55f9ee645957b32c7d9f62baf1f0b906e68267276f54ec4b4c597c2b190 + languageName: node + linkType: hard + +"for-each@npm:^0.3.3": + version: 0.3.3 + resolution: "for-each@npm:0.3.3" + dependencies: + is-callable: ^1.1.3 + checksum: 6c48ff2bc63362319c65e2edca4a8e1e3483a2fabc72fbe7feaf8c73db94fc7861bd53bc02c8a66a0c1dd709da6b04eec42e0abdd6b40ce47305ae92a25e5d28 + languageName: node + linkType: hard + +"foreground-child@npm:^3.1.0": + version: 3.1.1 + resolution: "foreground-child@npm:3.1.1" + dependencies: + cross-spawn: ^7.0.0 + signal-exit: ^4.0.1 + checksum: 139d270bc82dc9e6f8bc045fe2aae4001dc2472157044fdfad376d0a3457f77857fa883c1c8b21b491c6caade9a926a4bed3d3d2e8d3c9202b151a4cbbd0bcd5 + languageName: node + linkType: hard + +"forever-agent@npm:~0.6.1": + version: 0.6.1 + resolution: "forever-agent@npm:0.6.1" + checksum: 766ae6e220f5fe23676bb4c6a99387cec5b7b62ceb99e10923376e27bfea72f3c3aeec2ba5f45f3f7ba65d6616965aa7c20b15002b6860833bb6e394dea546a8 + languageName: node + linkType: hard + +"form-data@npm:^2.2.0": + version: 2.5.1 + resolution: "form-data@npm:2.5.1" + dependencies: + asynckit: ^0.4.0 + combined-stream: ^1.0.6 + mime-types: ^2.1.12 + checksum: 5134ada56cc246b293a1ac7678dba6830000603a3979cf83ff7b2f21f2e3725202237cfb89e32bcb38a1d35727efbd3c3a22e65b42321e8ade8eec01ce755d08 + languageName: node + linkType: hard + +"form-data@npm:^4.0.0": + version: 4.0.0 + resolution: "form-data@npm:4.0.0" + dependencies: + asynckit: ^0.4.0 + combined-stream: ^1.0.8 + mime-types: ^2.1.12 + checksum: 01135bf8675f9d5c61ff18e2e2932f719ca4de964e3be90ef4c36aacfc7b9cb2fceb5eca0b7e0190e3383fe51c5b37f4cb80b62ca06a99aaabfcfd6ac7c9328c + languageName: node + linkType: hard + +"form-data@npm:~2.3.2": + version: 2.3.3 + resolution: "form-data@npm:2.3.3" + dependencies: + asynckit: ^0.4.0 + combined-stream: ^1.0.6 + mime-types: ^2.1.12 + checksum: 10c1780fa13dbe1ff3100114c2ce1f9307f8be10b14bf16e103815356ff567b6be39d70fc4a40f8990b9660012dc24b0f5e1dde1b6426166eb23a445ba068ca3 + languageName: node + linkType: hard + +"fp-ts@npm:1.19.3": + version: 1.19.3 + resolution: "fp-ts@npm:1.19.3" + checksum: eb0d4766ad561e9c5c01bfdd3d0ae589af135556921c733d26cf5289aad9f400110defdd93e6ac1d71f626697bb44d9d95ed2879c53dfd868f7cac3cf5c5553c + languageName: node + linkType: hard + +"fp-ts@npm:^1.0.0": + version: 1.19.5 + resolution: "fp-ts@npm:1.19.5" + checksum: 67d2d9c3855d211ca2592b1ef805f98b618157e7681791a776d9d0f7f3e52fcca2122ebf5bc215908c9099fad69756d40e37210cf46cb4075dae1b61efe69e40 + languageName: node + linkType: hard + +"fs-extra@npm:11.1.1": + version: 11.1.1 + resolution: "fs-extra@npm:11.1.1" + dependencies: + graceful-fs: ^4.2.0 + jsonfile: ^6.0.1 + universalify: ^2.0.0 + checksum: fb883c68245b2d777fbc1f2082c9efb084eaa2bbf9fddaa366130d196c03608eebef7fb490541276429ee1ca99f317e2d73e96f5ca0999eefedf5a624ae1edfd + languageName: node + linkType: hard + +"fs-extra@npm:^0.30.0": + version: 0.30.0 + resolution: "fs-extra@npm:0.30.0" + dependencies: + graceful-fs: ^4.1.2 + jsonfile: ^2.1.0 + klaw: ^1.0.0 + path-is-absolute: ^1.0.0 + rimraf: ^2.2.8 + checksum: 6edfd65fc813baa27f1603778c0f5ec11f8c5006a20b920437813ee2023eba18aeec8bef1c89b2e6c84f9fc90fdc7c916f4a700466c8c69d22a35d018f2570f0 + languageName: node + linkType: hard + +"fs-extra@npm:^10.0.0": + version: 10.1.0 + resolution: "fs-extra@npm:10.1.0" + dependencies: + graceful-fs: ^4.2.0 + jsonfile: ^6.0.1 + universalify: ^2.0.0 + checksum: dc94ab37096f813cc3ca12f0f1b5ad6744dfed9ed21e953d72530d103cea193c2f81584a39e9dee1bea36de5ee66805678c0dddc048e8af1427ac19c00fffc50 + languageName: node + linkType: hard + +"fs-extra@npm:^7.0.0, fs-extra@npm:^7.0.1": + version: 7.0.1 + resolution: "fs-extra@npm:7.0.1" + dependencies: + graceful-fs: ^4.1.2 + jsonfile: ^4.0.0 + universalify: ^0.1.0 + checksum: 141b9dccb23b66a66cefdd81f4cda959ff89282b1d721b98cea19ba08db3dcbe6f862f28841f3cf24bb299e0b7e6c42303908f65093cb7e201708e86ea5a8dcf + languageName: node + linkType: hard + +"fs-extra@npm:^8.1": + version: 8.1.0 + resolution: "fs-extra@npm:8.1.0" + dependencies: + graceful-fs: ^4.2.0 + jsonfile: ^4.0.0 + universalify: ^0.1.0 + checksum: bf44f0e6cea59d5ce071bba4c43ca76d216f89e402dc6285c128abc0902e9b8525135aa808adad72c9d5d218e9f4bcc63962815529ff2f684ad532172a284880 + languageName: node + linkType: hard + +"fs-extra@npm:^9.1.0": + version: 9.1.0 + resolution: "fs-extra@npm:9.1.0" + dependencies: + at-least-node: ^1.0.0 + graceful-fs: ^4.2.0 + jsonfile: ^6.0.1 + universalify: ^2.0.0 + checksum: ba71ba32e0faa74ab931b7a0031d1523c66a73e225de7426e275e238e312d07313d2da2d33e34a52aa406c8763ade5712eb3ec9ba4d9edce652bcacdc29e6b20 + languageName: node + linkType: hard + +"fs-minipass@npm:^2.0.0": + version: 2.1.0 + resolution: "fs-minipass@npm:2.1.0" + dependencies: + minipass: ^3.0.0 + checksum: 1b8d128dae2ac6cc94230cc5ead341ba3e0efaef82dab46a33d171c044caaa6ca001364178d42069b2809c35a1c3c35079a32107c770e9ffab3901b59af8c8b1 + languageName: node + linkType: hard + +"fs-minipass@npm:^3.0.0": + version: 3.0.3 + resolution: "fs-minipass@npm:3.0.3" + dependencies: + minipass: ^7.0.3 + checksum: 8722a41109130851d979222d3ec88aabaceeaaf8f57b2a8f744ef8bd2d1ce95453b04a61daa0078822bc5cd21e008814f06fe6586f56fef511e71b8d2394d802 + languageName: node + linkType: hard + +"fs-readdir-recursive@npm:^1.1.0": + version: 1.1.0 + resolution: "fs-readdir-recursive@npm:1.1.0" + checksum: 29d50f3d2128391c7fc9fd051c8b7ea45bcc8aa84daf31ef52b17218e20bfd2bd34d02382742801954cc8d1905832b68227f6b680a666ce525d8b6b75068ad1e + languageName: node + linkType: hard + +"fs.realpath@npm:^1.0.0": + version: 1.0.0 + resolution: "fs.realpath@npm:1.0.0" + checksum: 99ddea01a7e75aa276c250a04eedeffe5662bce66c65c07164ad6264f9de18fb21be9433ead460e54cff20e31721c811f4fb5d70591799df5f85dce6d6746fd0 + languageName: node + linkType: hard + +"fsevents@npm:~2.1.1": + version: 2.1.3 + resolution: "fsevents@npm:2.1.3" + dependencies: + node-gyp: latest + checksum: b5ec0516b44d75b60af5c01ff80a80cd995d175e4640d2a92fbabd02991dd664d76b241b65feef0775c23d531c3c74742c0fbacd6205af812a9c3cef59f04292 + conditions: os=darwin + languageName: node + linkType: hard + +"fsevents@npm:~2.3.2": + version: 2.3.2 + resolution: "fsevents@npm:2.3.2" + dependencies: + node-gyp: latest + checksum: 97ade64e75091afee5265e6956cb72ba34db7819b4c3e94c431d4be2b19b8bb7a2d4116da417950c3425f17c8fe693d25e20212cac583ac1521ad066b77ae31f + conditions: os=darwin + languageName: node + linkType: hard + +"fsevents@patch:fsevents@~2.1.1#~builtin": + version: 2.1.3 + resolution: "fsevents@patch:fsevents@npm%3A2.1.3#~builtin::version=2.1.3&hash=31d12a" + dependencies: + node-gyp: latest + conditions: os=darwin + languageName: node + linkType: hard + +"fsevents@patch:fsevents@~2.3.2#~builtin": + version: 2.3.2 + resolution: "fsevents@patch:fsevents@npm%3A2.3.2#~builtin::version=2.3.2&hash=df0bf1" + dependencies: + node-gyp: latest + conditions: os=darwin + languageName: node + linkType: hard + +"function-bind@npm:^1.1.1": + version: 1.1.1 + resolution: "function-bind@npm:1.1.1" + checksum: b32fbaebb3f8ec4969f033073b43f5c8befbb58f1a79e12f1d7490358150359ebd92f49e72ff0144f65f2c48ea2a605bff2d07965f548f6474fd8efd95bf361a + languageName: node + linkType: hard + +"function.prototype.name@npm:^1.1.5": + version: 1.1.5 + resolution: "function.prototype.name@npm:1.1.5" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.3 + es-abstract: ^1.19.0 + functions-have-names: ^1.2.2 + checksum: acd21d733a9b649c2c442f067567743214af5fa248dbeee69d8278ce7df3329ea5abac572be9f7470b4ec1cd4d8f1040e3c5caccf98ebf2bf861a0deab735c27 + languageName: node + linkType: hard + +"functional-red-black-tree@npm:^1.0.1": + version: 1.0.1 + resolution: "functional-red-black-tree@npm:1.0.1" + checksum: ca6c170f37640e2d94297da8bb4bf27a1d12bea3e00e6a3e007fd7aa32e37e000f5772acf941b4e4f3cf1c95c3752033d0c509af157ad8f526e7f00723b9eb9f + languageName: node + linkType: hard + +"functions-have-names@npm:^1.2.2, functions-have-names@npm:^1.2.3": + version: 1.2.3 + resolution: "functions-have-names@npm:1.2.3" + checksum: c3f1f5ba20f4e962efb71344ce0a40722163e85bee2101ce25f88214e78182d2d2476aa85ef37950c579eb6cf6ee811c17b3101bb84004bb75655f3e33f3fdb5 + languageName: node + linkType: hard + +"gauge@npm:^4.0.3": + version: 4.0.4 + resolution: "gauge@npm:4.0.4" + dependencies: + aproba: ^1.0.3 || ^2.0.0 + color-support: ^1.1.3 + console-control-strings: ^1.1.0 + has-unicode: ^2.0.1 + signal-exit: ^3.0.7 + string-width: ^4.2.3 + strip-ansi: ^6.0.1 + wide-align: ^1.1.5 + checksum: 788b6bfe52f1dd8e263cda800c26ac0ca2ff6de0b6eee2fe0d9e3abf15e149b651bd27bf5226be10e6e3edb5c4e5d5985a5a1a98137e7a892f75eff76467ad2d + languageName: node + linkType: hard + +"get-caller-file@npm:^2.0.1, get-caller-file@npm:^2.0.5": + version: 2.0.5 + resolution: "get-caller-file@npm:2.0.5" + checksum: b9769a836d2a98c3ee734a88ba712e62703f1df31b94b784762c433c27a386dd6029ff55c2a920c392e33657d80191edbf18c61487e198844844516f843496b9 + languageName: node + linkType: hard + +"get-func-name@npm:^2.0.0": + version: 2.0.0 + resolution: "get-func-name@npm:2.0.0" + checksum: 8d82e69f3e7fab9e27c547945dfe5cc0c57fc0adf08ce135dddb01081d75684a03e7a0487466f478872b341d52ac763ae49e660d01ab83741f74932085f693c3 + languageName: node + linkType: hard + +"get-intrinsic@npm:^1.0.2, get-intrinsic@npm:^1.1.1, get-intrinsic@npm:^1.1.3, get-intrinsic@npm:^1.2.0, get-intrinsic@npm:^1.2.1": + version: 1.2.1 + resolution: "get-intrinsic@npm:1.2.1" + dependencies: + function-bind: ^1.1.1 + has: ^1.0.3 + has-proto: ^1.0.1 + has-symbols: ^1.0.3 + checksum: 5b61d88552c24b0cf6fa2d1b3bc5459d7306f699de060d76442cce49a4721f52b8c560a33ab392cf5575b7810277d54ded9d4d39a1ea61855619ebc005aa7e5f + languageName: node + linkType: hard + +"get-port@npm:^3.1.0": + version: 3.2.0 + resolution: "get-port@npm:3.2.0" + checksum: 31f530326569683ac4b7452eb7573c40e9dbe52aec14d80745c35475261e6389160da153d5b8ae911150b4ce99003472b30c69ba5be0cedeaa7865b95542d168 + languageName: node + linkType: hard + +"get-stream@npm:^6.0.1": + version: 6.0.1 + resolution: "get-stream@npm:6.0.1" + checksum: e04ecece32c92eebf5b8c940f51468cd53554dcbb0ea725b2748be583c9523d00128137966afce410b9b051eb2ef16d657cd2b120ca8edafcf5a65e81af63cad + languageName: node + linkType: hard + +"get-symbol-description@npm:^1.0.0": + version: 1.0.0 + resolution: "get-symbol-description@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + get-intrinsic: ^1.1.1 + checksum: 9ceff8fe968f9270a37a1f73bf3f1f7bda69ca80f4f80850670e0e7b9444ff99323f7ac52f96567f8b5f5fbe7ac717a0d81d3407c7313e82810c6199446a5247 + languageName: node + linkType: hard + +"getpass@npm:^0.1.1": + version: 0.1.7 + resolution: "getpass@npm:0.1.7" + dependencies: + assert-plus: ^1.0.0 + checksum: ab18d55661db264e3eac6012c2d3daeafaab7a501c035ae0ccb193c3c23e9849c6e29b6ac762b9c2adae460266f925d55a3a2a3a3c8b94be2f222df94d70c046 + languageName: node + linkType: hard + +"glob-parent@npm:^5.1.2, glob-parent@npm:~5.1.0, glob-parent@npm:~5.1.2": + version: 5.1.2 + resolution: "glob-parent@npm:5.1.2" + dependencies: + is-glob: ^4.0.1 + checksum: f4f2bfe2425296e8a47e36864e4f42be38a996db40420fe434565e4480e3322f18eb37589617a98640c5dc8fdec1a387007ee18dbb1f3f5553409c34d17f425e + languageName: node + linkType: hard + +"glob@npm:7.1.3": + version: 7.1.3 + resolution: "glob@npm:7.1.3" + dependencies: + fs.realpath: ^1.0.0 + inflight: ^1.0.4 + inherits: 2 + minimatch: ^3.0.4 + once: ^1.3.0 + path-is-absolute: ^1.0.0 + checksum: d72a834a393948d6c4a5cacc6a29fe5fe190e1cd134e55dfba09aee0be6fe15be343e96d8ec43558ab67ff8af28e4420c7f63a4d4db1c779e515015e9c318616 + languageName: node + linkType: hard + +"glob@npm:7.2.0": + version: 7.2.0 + resolution: "glob@npm:7.2.0" + dependencies: + fs.realpath: ^1.0.0 + inflight: ^1.0.4 + inherits: 2 + minimatch: ^3.0.4 + once: ^1.3.0 + path-is-absolute: ^1.0.0 + checksum: 78a8ea942331f08ed2e055cb5b9e40fe6f46f579d7fd3d694f3412fe5db23223d29b7fee1575440202e9a7ff9a72ab106a39fee39934c7bedafe5e5f8ae20134 + languageName: node + linkType: hard + +"glob@npm:^10.2.2": + version: 10.3.10 + resolution: "glob@npm:10.3.10" + dependencies: + foreground-child: ^3.1.0 + jackspeak: ^2.3.5 + minimatch: ^9.0.1 + minipass: ^5.0.0 || ^6.0.2 || ^7.0.0 + path-scurry: ^1.10.1 + bin: + glob: dist/esm/bin.mjs + checksum: 4f2fe2511e157b5a3f525a54092169a5f92405f24d2aed3142f4411df328baca13059f4182f1db1bf933e2c69c0bd89e57ae87edd8950cba8c7ccbe84f721cf3 + languageName: node + linkType: hard + +"glob@npm:^7.1.3, glob@npm:^7.1.4, glob@npm:^7.1.6": + version: 7.2.3 + resolution: "glob@npm:7.2.3" + dependencies: + fs.realpath: ^1.0.0 + inflight: ^1.0.4 + inherits: 2 + minimatch: ^3.1.1 + once: ^1.3.0 + path-is-absolute: ^1.0.0 + checksum: 29452e97b38fa704dabb1d1045350fb2467cf0277e155aa9ff7077e90ad81d1ea9d53d3ee63bd37c05b09a065e90f16aec4a65f5b8de401d1dac40bc5605d133 + languageName: node + linkType: hard + +"glob@npm:^8.0.3": + version: 8.1.0 + resolution: "glob@npm:8.1.0" + dependencies: + fs.realpath: ^1.0.0 + inflight: ^1.0.4 + inherits: 2 + minimatch: ^5.0.1 + once: ^1.3.0 + checksum: 92fbea3221a7d12075f26f0227abac435de868dd0736a17170663783296d0dd8d3d532a5672b4488a439bf5d7fb85cdd07c11185d6cd39184f0385cbdfb86a47 + languageName: node + linkType: hard + +"globalthis@npm:^1.0.3": + version: 1.0.3 + resolution: "globalthis@npm:1.0.3" + dependencies: + define-properties: ^1.1.3 + checksum: fbd7d760dc464c886d0196166d92e5ffb4c84d0730846d6621a39fbbc068aeeb9c8d1421ad330e94b7bca4bb4ea092f5f21f3d36077812af5d098b4dc006c998 + languageName: node + linkType: hard + +"globby@npm:^11.0.0, globby@npm:^11.0.1, globby@npm:^11.1.0": + version: 11.1.0 + resolution: "globby@npm:11.1.0" + dependencies: + array-union: ^2.1.0 + dir-glob: ^3.0.1 + fast-glob: ^3.2.9 + ignore: ^5.2.0 + merge2: ^1.4.1 + slash: ^3.0.0 + checksum: b4be8885e0cfa018fc783792942d53926c35c50b3aefd3fdcfb9d22c627639dc26bd2327a40a0b74b074100ce95bb7187bfeae2f236856aa3de183af7a02aea6 + languageName: node + linkType: hard + +"gopd@npm:^1.0.1": + version: 1.0.1 + resolution: "gopd@npm:1.0.1" + dependencies: + get-intrinsic: ^1.1.3 + checksum: a5ccfb8806e0917a94e0b3de2af2ea4979c1da920bc381667c260e00e7cafdbe844e2cb9c5bcfef4e5412e8bf73bab837285bc35c7ba73aaaf0134d4583393a6 + languageName: node + linkType: hard + +"graceful-fs@npm:^4.1.2, graceful-fs@npm:^4.1.6, graceful-fs@npm:^4.1.9, graceful-fs@npm:^4.2.0, graceful-fs@npm:^4.2.6": + version: 4.2.11 + resolution: "graceful-fs@npm:4.2.11" + checksum: ac85f94da92d8eb6b7f5a8b20ce65e43d66761c55ce85ac96df6865308390da45a8d3f0296dd3a663de65d30ba497bd46c696cc1e248c72b13d6d567138a4fc7 + languageName: node + linkType: hard + +"growl@npm:1.10.5": + version: 1.10.5 + resolution: "growl@npm:1.10.5" + checksum: 4b86685de6831cebcbb19f93870bea624afee61124b0a20c49017013987cd129e73a8c4baeca295728f41d21265e1f859d25ef36731b142ca59c655fea94bb1a + languageName: node + linkType: hard + +"handlebars@npm:^4.7.6": + version: 4.7.8 + resolution: "handlebars@npm:4.7.8" + dependencies: + minimist: ^1.2.5 + neo-async: ^2.6.2 + source-map: ^0.6.1 + uglify-js: ^3.1.4 + wordwrap: ^1.0.0 + dependenciesMeta: + uglify-js: + optional: true + bin: + handlebars: bin/handlebars + checksum: 00e68bb5c183fd7b8b63322e6234b5ac8fbb960d712cb3f25587d559c2951d9642df83c04a1172c918c41bcfc81bfbd7a7718bbce93b893e0135fc99edea93ff + languageName: node + linkType: hard + +"har-schema@npm:^2.0.0": + version: 2.0.0 + resolution: "har-schema@npm:2.0.0" + checksum: d8946348f333fb09e2bf24cc4c67eabb47c8e1d1aa1c14184c7ffec1140a49ec8aa78aa93677ae452d71d5fc0fdeec20f0c8c1237291fc2bcb3f502a5d204f9b + languageName: node + linkType: hard + +"har-validator@npm:~5.1.3": + version: 5.1.5 + resolution: "har-validator@npm:5.1.5" + dependencies: + ajv: ^6.12.3 + har-schema: ^2.0.0 + checksum: b998a7269ca560d7f219eedc53e2c664cd87d487e428ae854a6af4573fc94f182fe9d2e3b92ab968249baec7ebaf9ead69cf975c931dc2ab282ec182ee988280 + languageName: node + linkType: hard + +"hardhat-contract-sizer@npm:2.8.0": + version: 2.8.0 + resolution: "hardhat-contract-sizer@npm:2.8.0" + dependencies: + chalk: ^4.0.0 + cli-table3: ^0.6.0 + strip-ansi: ^6.0.0 + peerDependencies: + hardhat: ^2.0.0 + checksum: 6f1f4aca16a8ceeb9b3ce8ec89075c2fb292a3c82941ae826a9d503e077fda58e1d62b5c561252385c320a978d65399a2e829cec7c643250eaca163546831cbb + languageName: node + linkType: hard + +"hardhat-deploy@npm:0.11.29": + version: 0.11.29 + resolution: "hardhat-deploy@npm:0.11.29" + dependencies: + "@ethersproject/abi": ^5.7.0 + "@ethersproject/abstract-signer": ^5.7.0 + "@ethersproject/address": ^5.7.0 + "@ethersproject/bignumber": ^5.7.0 + "@ethersproject/bytes": ^5.7.0 + "@ethersproject/constants": ^5.7.0 + "@ethersproject/contracts": ^5.7.0 + "@ethersproject/providers": ^5.7.2 + "@ethersproject/solidity": ^5.7.0 + "@ethersproject/transactions": ^5.7.0 + "@ethersproject/wallet": ^5.7.0 + "@types/qs": ^6.9.7 + axios: ^0.21.1 + chalk: ^4.1.2 + chokidar: ^3.5.2 + debug: ^4.3.2 + enquirer: ^2.3.6 + ethers: ^5.5.3 + form-data: ^4.0.0 + fs-extra: ^10.0.0 + match-all: ^1.2.6 + murmur-128: ^0.2.1 + qs: ^6.9.4 + zksync-web3: ^0.14.3 + checksum: 4a963e202271189566921fb7ab73bde4ed45204fddeeacdc9993883772b7349b513ba3dd17dee4bc178581724ab20d537f0b69c7ddf227710e7f070ec65c70d2 + languageName: node + linkType: hard + +"hardhat-gas-reporter@npm:^1.0.8": + version: 1.0.9 + resolution: "hardhat-gas-reporter@npm:1.0.9" + dependencies: + array-uniq: 1.0.3 + eth-gas-reporter: ^0.2.25 + sha1: ^1.1.1 + peerDependencies: + hardhat: ^2.0.2 + checksum: 77f8f8d085ff3d9d7787f0227e5355e1800f7d6707bc70171e0567bf69706703ae7f6f53dce1be1d409e7e71e3629a434c94b546bdbbc1e4c1af47cd5d0c6776 + languageName: node + linkType: hard + +"hardhat-storage-layout@npm:^0.1.7": + version: 0.1.7 + resolution: "hardhat-storage-layout@npm:0.1.7" + dependencies: + console-table-printer: ^2.9.0 + peerDependencies: + hardhat: ^2.0.3 + checksum: 8d27d6b16c1ebdffa032ba6b99c61996df4601dcbaf7d770c474806b492a56de9d21b4190086ab40f50a3a1f2e9851cc81034a9cfd2e21368941977324f96fd4 + languageName: node + linkType: hard + +"hardhat@npm:2.14.0": + version: 2.14.0 + resolution: "hardhat@npm:2.14.0" + dependencies: + "@ethersproject/abi": ^5.1.2 + "@metamask/eth-sig-util": ^4.0.0 + "@nomicfoundation/ethereumjs-block": 5.0.1 + "@nomicfoundation/ethereumjs-blockchain": 7.0.1 + "@nomicfoundation/ethereumjs-common": 4.0.1 + "@nomicfoundation/ethereumjs-evm": 2.0.1 + "@nomicfoundation/ethereumjs-rlp": 5.0.1 + "@nomicfoundation/ethereumjs-statemanager": 2.0.1 + "@nomicfoundation/ethereumjs-trie": 6.0.1 + "@nomicfoundation/ethereumjs-tx": 5.0.1 + "@nomicfoundation/ethereumjs-util": 9.0.1 + "@nomicfoundation/ethereumjs-vm": 7.0.1 + "@nomicfoundation/solidity-analyzer": ^0.1.0 + "@sentry/node": ^5.18.1 + "@types/bn.js": ^5.1.0 + "@types/lru-cache": ^5.1.0 + abort-controller: ^3.0.0 + adm-zip: ^0.4.16 + aggregate-error: ^3.0.0 + ansi-escapes: ^4.3.0 + chalk: ^2.4.2 + chokidar: ^3.4.0 + ci-info: ^2.0.0 + debug: ^4.1.1 + enquirer: ^2.3.0 + env-paths: ^2.2.0 + ethereum-cryptography: ^1.0.3 + ethereumjs-abi: ^0.6.8 + find-up: ^2.1.0 + fp-ts: 1.19.3 + fs-extra: ^7.0.1 + glob: 7.2.0 + immutable: ^4.0.0-rc.12 + io-ts: 1.10.4 + keccak: ^3.0.2 + lodash: ^4.17.11 + mnemonist: ^0.38.0 + mocha: ^10.0.0 + p-map: ^4.0.0 + qs: ^6.7.0 + raw-body: ^2.4.1 + resolve: 1.17.0 + semver: ^6.3.0 + solc: 0.7.3 + source-map-support: ^0.5.13 + stacktrace-parser: ^0.1.10 + tsort: 0.0.1 + undici: ^5.14.0 + uuid: ^8.3.2 + ws: ^7.4.6 + peerDependencies: + ts-node: "*" + typescript: "*" + peerDependenciesMeta: + ts-node: + optional: true + typescript: + optional: true + bin: + hardhat: internal/cli/bootstrap.js + checksum: 7a11ad4650759851306d65c30252ccffa2aca9cb461c66f3fcef5f29d38fe66402d6bc295d293670fa0a72bf3572cc95029c5cd0b0fd45f45edd99d6eb5b7586 + languageName: node + linkType: hard + +"has-bigints@npm:^1.0.1, has-bigints@npm:^1.0.2": + version: 1.0.2 + resolution: "has-bigints@npm:1.0.2" + checksum: 390e31e7be7e5c6fe68b81babb73dfc35d413604d7ee5f56da101417027a4b4ce6a27e46eff97ad040c835b5d228676eae99a9b5c3bc0e23c8e81a49241ff45b + languageName: node + linkType: hard + +"has-flag@npm:^3.0.0": + version: 3.0.0 + resolution: "has-flag@npm:3.0.0" + checksum: 4a15638b454bf086c8148979aae044dd6e39d63904cd452d970374fa6a87623423da485dfb814e7be882e05c096a7ccf1ebd48e7e7501d0208d8384ff4dea73b + languageName: node + linkType: hard + +"has-flag@npm:^4.0.0": + version: 4.0.0 + resolution: "has-flag@npm:4.0.0" + checksum: 261a1357037ead75e338156b1f9452c016a37dcd3283a972a30d9e4a87441ba372c8b81f818cd0fbcd9c0354b4ae7e18b9e1afa1971164aef6d18c2b6095a8ad + languageName: node + linkType: hard + +"has-property-descriptors@npm:^1.0.0": + version: 1.0.0 + resolution: "has-property-descriptors@npm:1.0.0" + dependencies: + get-intrinsic: ^1.1.1 + checksum: a6d3f0a266d0294d972e354782e872e2fe1b6495b321e6ef678c9b7a06a40408a6891817350c62e752adced73a94ac903c54734fee05bf65b1905ee1368194bb + languageName: node + linkType: hard + +"has-proto@npm:^1.0.1": + version: 1.0.1 + resolution: "has-proto@npm:1.0.1" + checksum: febc5b5b531de8022806ad7407935e2135f1cc9e64636c3916c6842bd7995994ca3b29871ecd7954bd35f9e2986c17b3b227880484d22259e2f8e6ce63fd383e + languageName: node + linkType: hard + +"has-symbols@npm:^1.0.0, has-symbols@npm:^1.0.2, has-symbols@npm:^1.0.3": + version: 1.0.3 + resolution: "has-symbols@npm:1.0.3" + checksum: a054c40c631c0d5741a8285010a0777ea0c068f99ed43e5d6eb12972da223f8af553a455132fdb0801bdcfa0e0f443c0c03a68d8555aa529b3144b446c3f2410 + languageName: node + linkType: hard + +"has-tostringtag@npm:^1.0.0": + version: 1.0.0 + resolution: "has-tostringtag@npm:1.0.0" + dependencies: + has-symbols: ^1.0.2 + checksum: cc12eb28cb6ae22369ebaad3a8ab0799ed61270991be88f208d508076a1e99abe4198c965935ce85ea90b60c94ddda73693b0920b58e7ead048b4a391b502c1c + languageName: node + linkType: hard + +"has-unicode@npm:^2.0.1": + version: 2.0.1 + resolution: "has-unicode@npm:2.0.1" + checksum: 1eab07a7436512db0be40a710b29b5dc21fa04880b7f63c9980b706683127e3c1b57cb80ea96d47991bdae2dfe479604f6a1ba410106ee1046a41d1bd0814400 + languageName: node + linkType: hard + +"has@npm:^1.0.3": + version: 1.0.3 + resolution: "has@npm:1.0.3" + dependencies: + function-bind: ^1.1.1 + checksum: b9ad53d53be4af90ce5d1c38331e712522417d017d5ef1ebd0507e07c2fbad8686fffb8e12ddecd4c39ca9b9b47431afbb975b8abf7f3c3b82c98e9aad052792 + languageName: node + linkType: hard + +"hash-base@npm:^3.0.0": + version: 3.1.0 + resolution: "hash-base@npm:3.1.0" + dependencies: + inherits: ^2.0.4 + readable-stream: ^3.6.0 + safe-buffer: ^5.2.0 + checksum: 26b7e97ac3de13cb23fc3145e7e3450b0530274a9562144fc2bf5c1e2983afd0e09ed7cc3b20974ba66039fad316db463da80eb452e7373e780cbee9a0d2f2dc + languageName: node + linkType: hard + +"hash.js@npm:1.1.3": + version: 1.1.3 + resolution: "hash.js@npm:1.1.3" + dependencies: + inherits: ^2.0.3 + minimalistic-assert: ^1.0.0 + checksum: 93de6f178bf71feee38f66868a57ecb5602d937c1ccd69951b0bfec1488813b6afdbb4a81ddb2c62488c419b4a35af352298b006f14c9cfbf5b872c4191b657f + languageName: node + linkType: hard + +"hash.js@npm:1.1.7, hash.js@npm:^1.0.0, hash.js@npm:^1.0.3, hash.js@npm:^1.1.7": + version: 1.1.7 + resolution: "hash.js@npm:1.1.7" + dependencies: + inherits: ^2.0.3 + minimalistic-assert: ^1.0.1 + checksum: e350096e659c62422b85fa508e4b3669017311aa4c49b74f19f8e1bc7f3a54a584fdfd45326d4964d6011f2b2d882e38bea775a96046f2a61b7779a979629d8f + languageName: node + linkType: hard + +"he@npm:1.2.0": + version: 1.2.0 + resolution: "he@npm:1.2.0" + bin: + he: bin/he + checksum: 3d4d6babccccd79c5c5a3f929a68af33360d6445587d628087f39a965079d84f18ce9c3d3f917ee1e3978916fc833bb8b29377c3b403f919426f91bc6965e7a7 + languageName: node + linkType: hard + +"hmac-drbg@npm:^1.0.1": + version: 1.0.1 + resolution: "hmac-drbg@npm:1.0.1" + dependencies: + hash.js: ^1.0.3 + minimalistic-assert: ^1.0.0 + minimalistic-crypto-utils: ^1.0.1 + checksum: bd30b6a68d7f22d63f10e1888aee497d7c2c5c0bb469e66bbdac99f143904d1dfe95f8131f95b3e86c86dd239963c9d972fcbe147e7cffa00e55d18585c43fe0 + languageName: node + linkType: hard + +"http-basic@npm:^8.1.1": + version: 8.1.3 + resolution: "http-basic@npm:8.1.3" + dependencies: + caseless: ^0.12.0 + concat-stream: ^1.6.2 + http-response-object: ^3.0.1 + parse-cache-control: ^1.0.1 + checksum: 7df5dc4d4b6eb8cc3beaa77f8e5c3074288ec3835abd83c85e5bb66d8a95a0ef97664d862caf5e225698cb795f78f9a5abd0d39404e5356ccd3e5e10c87936a5 + languageName: node + linkType: hard + +"http-cache-semantics@npm:^4.1.1": + version: 4.1.1 + resolution: "http-cache-semantics@npm:4.1.1" + checksum: 83ac0bc60b17a3a36f9953e7be55e5c8f41acc61b22583060e8dedc9dd5e3607c823a88d0926f9150e571f90946835c7fe150732801010845c72cd8bbff1a236 + languageName: node + linkType: hard + +"http-errors@npm:2.0.0": + version: 2.0.0 + resolution: "http-errors@npm:2.0.0" + dependencies: + depd: 2.0.0 + inherits: 2.0.4 + setprototypeof: 1.2.0 + statuses: 2.0.1 + toidentifier: 1.0.1 + checksum: 9b0a3782665c52ce9dc658a0d1560bcb0214ba5699e4ea15aefb2a496e2ca83db03ebc42e1cce4ac1f413e4e0d2d736a3fd755772c556a9a06853ba2a0b7d920 + languageName: node + linkType: hard + +"http-proxy-agent@npm:^5.0.0": + version: 5.0.0 + resolution: "http-proxy-agent@npm:5.0.0" + dependencies: + "@tootallnate/once": 2 + agent-base: 6 + debug: 4 + checksum: e2ee1ff1656a131953839b2a19cd1f3a52d97c25ba87bd2559af6ae87114abf60971e498021f9b73f9fd78aea8876d1fb0d4656aac8a03c6caa9fc175f22b786 + languageName: node + linkType: hard + +"http-response-object@npm:^3.0.1": + version: 3.0.2 + resolution: "http-response-object@npm:3.0.2" + dependencies: + "@types/node": ^10.0.3 + checksum: 6cbdcb4ce7b27c9158a131b772c903ed54add2ba831e29cc165e91c3969fa6f8105ddf924aac5b954b534ad15a1ae697b693331b2be5281ee24d79aae20c3264 + languageName: node + linkType: hard + +"http-signature@npm:~1.2.0": + version: 1.2.0 + resolution: "http-signature@npm:1.2.0" + dependencies: + assert-plus: ^1.0.0 + jsprim: ^1.2.2 + sshpk: ^1.7.0 + checksum: 3324598712266a9683585bb84a75dec4fd550567d5e0dd4a0fff6ff3f74348793404d3eeac4918fa0902c810eeee1a86419e4a2e92a164132dfe6b26743fb47c + languageName: node + linkType: hard + +"https-proxy-agent@npm:^5.0.0": + version: 5.0.1 + resolution: "https-proxy-agent@npm:5.0.1" + dependencies: + agent-base: 6 + debug: 4 + checksum: 571fccdf38184f05943e12d37d6ce38197becdd69e58d03f43637f7fa1269cf303a7d228aa27e5b27bbd3af8f09fd938e1c91dcfefff2df7ba77c20ed8dfc765 + languageName: node + linkType: hard + +"human-signals@npm:^4.3.0": + version: 4.3.1 + resolution: "human-signals@npm:4.3.1" + checksum: 6f12958df3f21b6fdaf02d90896c271df00636a31e2bbea05bddf817a35c66b38a6fdac5863e2df85bd52f34958997f1f50350ff97249e1dff8452865d5235d1 + languageName: node + linkType: hard + +"humanize-ms@npm:^1.2.1": + version: 1.2.1 + resolution: "humanize-ms@npm:1.2.1" + dependencies: + ms: ^2.0.0 + checksum: 9c7a74a2827f9294c009266c82031030eae811ca87b0da3dceb8d6071b9bde22c9f3daef0469c3c533cc67a97d8a167cd9fc0389350e5f415f61a79b171ded16 + languageName: node + linkType: hard + +"husky@npm:^7.0.4": + version: 7.0.4 + resolution: "husky@npm:7.0.4" + bin: + husky: lib/bin.js + checksum: c6ec4af63da2c9522da8674a20ad9b48362cc92704896cc8a58c6a2a39d797feb2b806f93fbd83a6d653fbdceb2c3b6e0b602c6b2e8565206ffc2882ef7db9e9 + languageName: node + linkType: hard + +"iconv-lite@npm:0.4.24": + version: 0.4.24 + resolution: "iconv-lite@npm:0.4.24" + dependencies: + safer-buffer: ">= 2.1.2 < 3" + checksum: bd9f120f5a5b306f0bc0b9ae1edeb1577161503f5f8252a20f1a9e56ef8775c9959fd01c55f2d3a39d9a8abaf3e30c1abeb1895f367dcbbe0a8fd1c9ca01c4f6 + languageName: node + linkType: hard + +"iconv-lite@npm:^0.6.2": + version: 0.6.3 + resolution: "iconv-lite@npm:0.6.3" + dependencies: + safer-buffer: ">= 2.1.2 < 3.0.0" + checksum: 3f60d47a5c8fc3313317edfd29a00a692cc87a19cac0159e2ce711d0ebc9019064108323b5e493625e25594f11c6236647d8e256fbe7a58f4a3b33b89e6d30bf + languageName: node + linkType: hard + +"ieee754@npm:^1.2.1": + version: 1.2.1 + resolution: "ieee754@npm:1.2.1" + checksum: 5144c0c9815e54ada181d80a0b810221a253562422e7c6c3a60b1901154184f49326ec239d618c416c1c5945a2e197107aee8d986a3dd836b53dffefd99b5e7e + languageName: node + linkType: hard + +"ignore@npm:^5.2.0, ignore@npm:^5.2.4": + version: 5.2.4 + resolution: "ignore@npm:5.2.4" + checksum: 3d4c309c6006e2621659311783eaea7ebcd41fe4ca1d78c91c473157ad6666a57a2df790fe0d07a12300d9aac2888204d7be8d59f9aaf665b1c7fcdb432517ef + languageName: node + linkType: hard + +"immutable@npm:^4.0.0-rc.12": + version: 4.3.1 + resolution: "immutable@npm:4.3.1" + checksum: a3a5ba29bd43f3f9a2e4d599763d7455d11a0ea57e50bf43f2836672fc80003e90d69f2a4f5b589f1f3d6986faf97f08ce1e253583740dd33c00adebab88b217 + languageName: node + linkType: hard + +"import-fresh@npm:^3.2.1": + version: 3.3.0 + resolution: "import-fresh@npm:3.3.0" + dependencies: + parent-module: ^1.0.0 + resolve-from: ^4.0.0 + checksum: 2cacfad06e652b1edc50be650f7ec3be08c5e5a6f6d12d035c440a42a8cc028e60a5b99ca08a77ab4d6b1346da7d971915828f33cdab730d3d42f08242d09baa + languageName: node + linkType: hard + +"imul@npm:^1.0.0": + version: 1.0.1 + resolution: "imul@npm:1.0.1" + checksum: 6c2af3d5f09e2135e14d565a2c108412b825b221eb2c881f9130467f2adccf7ae201773ae8bcf1be169e2d090567a1fdfa9cf20d3b7da7b9cecb95b920ff3e52 + languageName: node + linkType: hard + +"imurmurhash@npm:^0.1.4": + version: 0.1.4 + resolution: "imurmurhash@npm:0.1.4" + checksum: 7cae75c8cd9a50f57dadd77482359f659eaebac0319dd9368bcd1714f55e65badd6929ca58569da2b6494ef13fdd5598cd700b1eba23f8b79c5f19d195a3ecf7 + languageName: node + linkType: hard + +"indent-string@npm:^4.0.0": + version: 4.0.0 + resolution: "indent-string@npm:4.0.0" + checksum: 824cfb9929d031dabf059bebfe08cf3137365e112019086ed3dcff6a0a7b698cb80cf67ccccde0e25b9e2d7527aa6cc1fed1ac490c752162496caba3e6699612 + languageName: node + linkType: hard + +"inflight@npm:^1.0.4": + version: 1.0.6 + resolution: "inflight@npm:1.0.6" + dependencies: + once: ^1.3.0 + wrappy: 1 + checksum: f4f76aa072ce19fae87ce1ef7d221e709afb59d445e05d47fba710e85470923a75de35bfae47da6de1b18afc3ce83d70facf44cfb0aff89f0a3f45c0a0244dfd + languageName: node + linkType: hard + +"inherits@npm:2, inherits@npm:2.0.4, inherits@npm:^2.0.1, inherits@npm:^2.0.3, inherits@npm:^2.0.4, inherits@npm:~2.0.3": + version: 2.0.4 + resolution: "inherits@npm:2.0.4" + checksum: 4a48a733847879d6cf6691860a6b1e3f0f4754176e4d71494c41f3475553768b10f84b5ce1d40fbd0e34e6bfbb864ee35858ad4dd2cf31e02fc4a154b724d7f1 + languageName: node + linkType: hard + +"internal-slot@npm:^1.0.5": + version: 1.0.5 + resolution: "internal-slot@npm:1.0.5" + dependencies: + get-intrinsic: ^1.2.0 + has: ^1.0.3 + side-channel: ^1.0.4 + checksum: 97e84046bf9e7574d0956bd98d7162313ce7057883b6db6c5c7b5e5f05688864b0978ba07610c726d15d66544ffe4b1050107d93f8a39ebc59b15d8b429b497a + languageName: node + linkType: hard + +"io-ts@npm:1.10.4": + version: 1.10.4 + resolution: "io-ts@npm:1.10.4" + dependencies: + fp-ts: ^1.0.0 + checksum: 619134006778f7ca42693716ade7fc1a383079e7848bbeabc67a0e4ac9139cda6b2a88a052d539ab7d554033ee2ffe4dab5cb96b958c83fee2dff73d23f03e88 + languageName: node + linkType: hard + +"ip@npm:^2.0.0": + version: 2.0.0 + resolution: "ip@npm:2.0.0" + checksum: cfcfac6b873b701996d71ec82a7dd27ba92450afdb421e356f44044ed688df04567344c36cbacea7d01b1c39a4c732dc012570ebe9bebfb06f27314bca625349 + languageName: node + linkType: hard + +"is-array-buffer@npm:^3.0.1, is-array-buffer@npm:^3.0.2": + version: 3.0.2 + resolution: "is-array-buffer@npm:3.0.2" + dependencies: + call-bind: ^1.0.2 + get-intrinsic: ^1.2.0 + is-typed-array: ^1.1.10 + checksum: dcac9dda66ff17df9cabdc58214172bf41082f956eab30bb0d86bc0fab1e44b690fc8e1f855cf2481245caf4e8a5a006a982a71ddccec84032ed41f9d8da8c14 + languageName: node + linkType: hard + +"is-arrayish@npm:^0.2.1": + version: 0.2.1 + resolution: "is-arrayish@npm:0.2.1" + checksum: eef4417e3c10e60e2c810b6084942b3ead455af16c4509959a27e490e7aee87cfb3f38e01bbde92220b528a0ee1a18d52b787e1458ee86174d8c7f0e58cd488f + languageName: node + linkType: hard + +"is-bigint@npm:^1.0.1": + version: 1.0.4 + resolution: "is-bigint@npm:1.0.4" + dependencies: + has-bigints: ^1.0.1 + checksum: c56edfe09b1154f8668e53ebe8252b6f185ee852a50f9b41e8d921cb2bed425652049fbe438723f6cb48a63ca1aa051e948e7e401e093477c99c84eba244f666 + languageName: node + linkType: hard + +"is-binary-path@npm:~2.1.0": + version: 2.1.0 + resolution: "is-binary-path@npm:2.1.0" + dependencies: + binary-extensions: ^2.0.0 + checksum: 84192eb88cff70d320426f35ecd63c3d6d495da9d805b19bc65b518984b7c0760280e57dbf119b7e9be6b161784a5a673ab2c6abe83abb5198a432232ad5b35c + languageName: node + linkType: hard + +"is-boolean-object@npm:^1.1.0": + version: 1.1.2 + resolution: "is-boolean-object@npm:1.1.2" + dependencies: + call-bind: ^1.0.2 + has-tostringtag: ^1.0.0 + checksum: c03b23dbaacadc18940defb12c1c0e3aaece7553ef58b162a0f6bba0c2a7e1551b59f365b91e00d2dbac0522392d576ef322628cb1d036a0fe51eb466db67222 + languageName: node + linkType: hard + +"is-buffer@npm:^2.0.5, is-buffer@npm:~2.0.3": + version: 2.0.5 + resolution: "is-buffer@npm:2.0.5" + checksum: 764c9ad8b523a9f5a32af29bdf772b08eb48c04d2ad0a7240916ac2688c983bf5f8504bf25b35e66240edeb9d9085461f9b5dae1f3d2861c6b06a65fe983de42 + languageName: node + linkType: hard + +"is-callable@npm:^1.1.3, is-callable@npm:^1.1.4, is-callable@npm:^1.2.7": + version: 1.2.7 + resolution: "is-callable@npm:1.2.7" + checksum: 61fd57d03b0d984e2ed3720fb1c7a897827ea174bd44402878e059542ea8c4aeedee0ea0985998aa5cc2736b2fa6e271c08587addb5b3959ac52cf665173d1ac + languageName: node + linkType: hard + +"is-date-object@npm:^1.0.1": + version: 1.0.5 + resolution: "is-date-object@npm:1.0.5" + dependencies: + has-tostringtag: ^1.0.0 + checksum: baa9077cdf15eb7b58c79398604ca57379b2fc4cf9aa7a9b9e295278648f628c9b201400c01c5e0f7afae56507d741185730307cbe7cad3b9f90a77e5ee342fc + languageName: node + linkType: hard + +"is-docker@npm:^2.0.0": + version: 2.2.1 + resolution: "is-docker@npm:2.2.1" + bin: + is-docker: cli.js + checksum: 3fef7ddbf0be25958e8991ad941901bf5922ab2753c46980b60b05c1bf9c9c2402d35e6dc32e4380b980ef5e1970a5d9d5e5aa2e02d77727c3b6b5e918474c56 + languageName: node + linkType: hard + +"is-extglob@npm:^2.1.1": + version: 2.1.1 + resolution: "is-extglob@npm:2.1.1" + checksum: df033653d06d0eb567461e58a7a8c9f940bd8c22274b94bf7671ab36df5719791aae15eef6d83bbb5e23283967f2f984b8914559d4449efda578c775c4be6f85 + languageName: node + linkType: hard + +"is-fullwidth-code-point@npm:^2.0.0": + version: 2.0.0 + resolution: "is-fullwidth-code-point@npm:2.0.0" + checksum: eef9c6e15f68085fec19ff6a978a6f1b8f48018fd1265035552078ee945573594933b09bbd6f562553e2a241561439f1ef5339276eba68d272001343084cfab8 + languageName: node + linkType: hard + +"is-fullwidth-code-point@npm:^3.0.0": + version: 3.0.0 + resolution: "is-fullwidth-code-point@npm:3.0.0" + checksum: 44a30c29457c7fb8f00297bce733f0a64cd22eca270f83e58c105e0d015e45c019491a4ab2faef91ab51d4738c670daff901c799f6a700e27f7314029e99e348 + languageName: node + linkType: hard + +"is-fullwidth-code-point@npm:^4.0.0": + version: 4.0.0 + resolution: "is-fullwidth-code-point@npm:4.0.0" + checksum: 8ae89bf5057bdf4f57b346fb6c55e9c3dd2549983d54191d722d5c739397a903012cc41a04ee3403fd872e811243ef91a7c5196da7b5841dc6b6aae31a264a8d + languageName: node + linkType: hard + +"is-glob@npm:^4.0.1, is-glob@npm:~4.0.1": + version: 4.0.3 + resolution: "is-glob@npm:4.0.3" + dependencies: + is-extglob: ^2.1.1 + checksum: d381c1319fcb69d341cc6e6c7cd588e17cd94722d9a32dbd60660b993c4fb7d0f19438674e68dfec686d09b7c73139c9166b47597f846af387450224a8101ab4 + languageName: node + linkType: hard + +"is-hex-prefixed@npm:1.0.0": + version: 1.0.0 + resolution: "is-hex-prefixed@npm:1.0.0" + checksum: 5ac58e6e528fb029cc43140f6eeb380fad23d0041cc23154b87f7c9a1b728bcf05909974e47248fd0b7fcc11ba33cf7e58d64804883056fabd23e2b898be41de + languageName: node + linkType: hard + +"is-lambda@npm:^1.0.1": + version: 1.0.1 + resolution: "is-lambda@npm:1.0.1" + checksum: 93a32f01940220532e5948538699ad610d5924ac86093fcee83022252b363eb0cc99ba53ab084a04e4fb62bf7b5731f55496257a4c38adf87af9c4d352c71c35 + languageName: node + linkType: hard + +"is-negative-zero@npm:^2.0.2": + version: 2.0.2 + resolution: "is-negative-zero@npm:2.0.2" + checksum: f3232194c47a549da60c3d509c9a09be442507616b69454716692e37ae9f37c4dea264fb208ad0c9f3efd15a796a46b79df07c7e53c6227c32170608b809149a + languageName: node + linkType: hard + +"is-number-object@npm:^1.0.4": + version: 1.0.7 + resolution: "is-number-object@npm:1.0.7" + dependencies: + has-tostringtag: ^1.0.0 + checksum: d1e8d01bb0a7134c74649c4e62da0c6118a0bfc6771ea3c560914d52a627873e6920dd0fd0ebc0e12ad2ff4687eac4c308f7e80320b973b2c8a2c8f97a7524f7 + languageName: node + linkType: hard + +"is-number@npm:^7.0.0": + version: 7.0.0 + resolution: "is-number@npm:7.0.0" + checksum: 456ac6f8e0f3111ed34668a624e45315201dff921e5ac181f8ec24923b99e9f32ca1a194912dc79d539c97d33dba17dc635202ff0b2cf98326f608323276d27a + languageName: node + linkType: hard + +"is-plain-obj@npm:^2.1.0": + version: 2.1.0 + resolution: "is-plain-obj@npm:2.1.0" + checksum: cec9100678b0a9fe0248a81743041ed990c2d4c99f893d935545cfbc42876cbe86d207f3b895700c690ad2fa520e568c44afc1605044b535a7820c1d40e38daa + languageName: node + linkType: hard + +"is-regex@npm:^1.1.4": + version: 1.1.4 + resolution: "is-regex@npm:1.1.4" + dependencies: + call-bind: ^1.0.2 + has-tostringtag: ^1.0.0 + checksum: 362399b33535bc8f386d96c45c9feb04cf7f8b41c182f54174c1a45c9abbbe5e31290bbad09a458583ff6bf3b2048672cdb1881b13289569a7c548370856a652 + languageName: node + linkType: hard + +"is-shared-array-buffer@npm:^1.0.2": + version: 1.0.2 + resolution: "is-shared-array-buffer@npm:1.0.2" + dependencies: + call-bind: ^1.0.2 + checksum: 9508929cf14fdc1afc9d61d723c6e8d34f5e117f0bffda4d97e7a5d88c3a8681f633a74f8e3ad1fe92d5113f9b921dc5ca44356492079612f9a247efbce7032a + languageName: node + linkType: hard + +"is-stream@npm:^3.0.0": + version: 3.0.0 + resolution: "is-stream@npm:3.0.0" + checksum: 172093fe99119ffd07611ab6d1bcccfe8bc4aa80d864b15f43e63e54b7abc71e779acd69afdb854c4e2a67fdc16ae710e370eda40088d1cfc956a50ed82d8f16 + languageName: node + linkType: hard + +"is-string@npm:^1.0.5, is-string@npm:^1.0.7": + version: 1.0.7 + resolution: "is-string@npm:1.0.7" + dependencies: + has-tostringtag: ^1.0.0 + checksum: 323b3d04622f78d45077cf89aab783b2f49d24dc641aa89b5ad1a72114cfeff2585efc8c12ef42466dff32bde93d839ad321b26884cf75e5a7892a938b089989 + languageName: node + linkType: hard + +"is-symbol@npm:^1.0.2, is-symbol@npm:^1.0.3": + version: 1.0.4 + resolution: "is-symbol@npm:1.0.4" + dependencies: + has-symbols: ^1.0.2 + checksum: 92805812ef590738d9de49d677cd17dfd486794773fb6fa0032d16452af46e9b91bb43ffe82c983570f015b37136f4b53b28b8523bfb10b0ece7a66c31a54510 + languageName: node + linkType: hard + +"is-typed-array@npm:^1.1.10, is-typed-array@npm:^1.1.9": + version: 1.1.12 + resolution: "is-typed-array@npm:1.1.12" + dependencies: + which-typed-array: ^1.1.11 + checksum: 4c89c4a3be07186caddadf92197b17fda663a9d259ea0d44a85f171558270d36059d1c386d34a12cba22dfade5aba497ce22778e866adc9406098c8fc4771796 + languageName: node + linkType: hard + +"is-typedarray@npm:~1.0.0": + version: 1.0.0 + resolution: "is-typedarray@npm:1.0.0" + checksum: 3508c6cd0a9ee2e0df2fa2e9baabcdc89e911c7bd5cf64604586697212feec525aa21050e48affb5ffc3df20f0f5d2e2cf79b08caa64e1ccc9578e251763aef7 + languageName: node + linkType: hard + +"is-unicode-supported@npm:^0.1.0": + version: 0.1.0 + resolution: "is-unicode-supported@npm:0.1.0" + checksum: a2aab86ee7712f5c2f999180daaba5f361bdad1efadc9610ff5b8ab5495b86e4f627839d085c6530363c6d6d4ecbde340fb8e54bdb83da4ba8e0865ed5513c52 + languageName: node + linkType: hard + +"is-weakref@npm:^1.0.2": + version: 1.0.2 + resolution: "is-weakref@npm:1.0.2" + dependencies: + call-bind: ^1.0.2 + checksum: 95bd9a57cdcb58c63b1c401c60a474b0f45b94719c30f548c891860f051bc2231575c290a6b420c6bc6e7ed99459d424c652bd5bf9a1d5259505dc35b4bf83de + languageName: node + linkType: hard + +"is-wsl@npm:^2.1.1": + version: 2.2.0 + resolution: "is-wsl@npm:2.2.0" + dependencies: + is-docker: ^2.0.0 + checksum: 20849846ae414997d290b75e16868e5261e86ff5047f104027026fd61d8b5a9b0b3ade16239f35e1a067b3c7cc02f70183cb661010ed16f4b6c7c93dad1b19d8 + languageName: node + linkType: hard + +"isarray@npm:^2.0.5": + version: 2.0.5 + resolution: "isarray@npm:2.0.5" + checksum: bd5bbe4104438c4196ba58a54650116007fa0262eccef13a4c55b2e09a5b36b59f1e75b9fcc49883dd9d4953892e6fc007eef9e9155648ceea036e184b0f930a + languageName: node + linkType: hard + +"isarray@npm:~1.0.0": + version: 1.0.0 + resolution: "isarray@npm:1.0.0" + checksum: f032df8e02dce8ec565cf2eb605ea939bdccea528dbcf565cdf92bfa2da9110461159d86a537388ef1acef8815a330642d7885b29010e8f7eac967c9993b65ab + languageName: node + linkType: hard + +"isexe@npm:^2.0.0": + version: 2.0.0 + resolution: "isexe@npm:2.0.0" + checksum: 26bf6c5480dda5161c820c5b5c751ae1e766c587b1f951ea3fcfc973bafb7831ae5b54a31a69bd670220e42e99ec154475025a468eae58ea262f813fdc8d1c62 + languageName: node + linkType: hard + +"isstream@npm:~0.1.2": + version: 0.1.2 + resolution: "isstream@npm:0.1.2" + checksum: 1eb2fe63a729f7bdd8a559ab552c69055f4f48eb5c2f03724430587c6f450783c8f1cd936c1c952d0a927925180fcc892ebd5b174236cf1065d4bd5bdb37e963 + languageName: node + linkType: hard + +"jackspeak@npm:^2.3.5": + version: 2.3.6 + resolution: "jackspeak@npm:2.3.6" + dependencies: + "@isaacs/cliui": ^8.0.2 + "@pkgjs/parseargs": ^0.11.0 + dependenciesMeta: + "@pkgjs/parseargs": + optional: true + checksum: 57d43ad11eadc98cdfe7496612f6bbb5255ea69fe51ea431162db302c2a11011642f50cfad57288bd0aea78384a0612b16e131944ad8ecd09d619041c8531b54 + languageName: node + linkType: hard + +"js-sdsl@npm:^4.1.4": + version: 4.4.2 + resolution: "js-sdsl@npm:4.4.2" + checksum: ba705adc1788bf3c6f6c8e5077824f2bb4f0acab5a984420ce5cc492c7fff3daddc26335ad2c9a67d4f5e3241ec790f9e5b72a625adcf20cf321d2fd85e62b8b + languageName: node + linkType: hard + +"js-sha3@npm:0.5.7": + version: 0.5.7 + resolution: "js-sha3@npm:0.5.7" + checksum: 973a28ea4b26cc7f12d2ab24f796e24ee4a71eef45a6634a052f6eb38cf8b2333db798e896e6e094ea6fa4dfe8e42a2a7942b425cf40da3f866623fd05bb91ea + languageName: node + linkType: hard + +"js-sha3@npm:0.8.0, js-sha3@npm:^0.8.0": + version: 0.8.0 + resolution: "js-sha3@npm:0.8.0" + checksum: 75df77c1fc266973f06cce8309ce010e9e9f07ec35ab12022ed29b7f0d9c8757f5a73e1b35aa24840dced0dea7059085aa143d817aea9e188e2a80d569d9adce + languageName: node + linkType: hard + +"js-tokens@npm:^4.0.0": + version: 4.0.0 + resolution: "js-tokens@npm:4.0.0" + checksum: 8a95213a5a77deb6cbe94d86340e8d9ace2b93bc367790b260101d2f36a2eaf4e4e22d9fa9cf459b38af3a32fb4190e638024cf82ec95ef708680e405ea7cc78 + languageName: node + linkType: hard + +"js-yaml@npm:3.13.1": + version: 3.13.1 + resolution: "js-yaml@npm:3.13.1" + dependencies: + argparse: ^1.0.7 + esprima: ^4.0.0 + bin: + js-yaml: bin/js-yaml.js + checksum: 7511b764abb66d8aa963379f7d2a404f078457d106552d05a7b556d204f7932384e8477513c124749fa2de52eb328961834562bd09924902c6432e40daa408bc + languageName: node + linkType: hard + +"js-yaml@npm:4.1.0, js-yaml@npm:^4.1.0": + version: 4.1.0 + resolution: "js-yaml@npm:4.1.0" + dependencies: + argparse: ^2.0.1 + bin: + js-yaml: bin/js-yaml.js + checksum: c7830dfd456c3ef2c6e355cc5a92e6700ceafa1d14bba54497b34a99f0376cecbb3e9ac14d3e5849b426d5a5140709a66237a8c991c675431271c4ce5504151a + languageName: node + linkType: hard + +"jsbn@npm:~0.1.0": + version: 0.1.1 + resolution: "jsbn@npm:0.1.1" + checksum: e5ff29c1b8d965017ef3f9c219dacd6e40ad355c664e277d31246c90545a02e6047018c16c60a00f36d561b3647215c41894f5d869ada6908a2e0ce4200c88f2 + languageName: node + linkType: hard + +"json-parse-even-better-errors@npm:^2.3.0": + version: 2.3.1 + resolution: "json-parse-even-better-errors@npm:2.3.1" + checksum: 798ed4cf3354a2d9ccd78e86d2169515a0097a5c133337807cdf7f1fc32e1391d207ccfc276518cc1d7d8d4db93288b8a50ba4293d212ad1336e52a8ec0a941f + languageName: node + linkType: hard + +"json-schema-traverse@npm:^0.4.1": + version: 0.4.1 + resolution: "json-schema-traverse@npm:0.4.1" + checksum: 7486074d3ba247769fda17d5181b345c9fb7d12e0da98b22d1d71a5db9698d8b4bd900a3ec1a4ffdd60846fc2556274a5c894d0c48795f14cb03aeae7b55260b + languageName: node + linkType: hard + +"json-schema-traverse@npm:^1.0.0": + version: 1.0.0 + resolution: "json-schema-traverse@npm:1.0.0" + checksum: 02f2f466cdb0362558b2f1fd5e15cce82ef55d60cd7f8fa828cf35ba74330f8d767fcae5c5c2adb7851fa811766c694b9405810879bc4e1ddd78a7c0e03658ad + languageName: node + linkType: hard + +"json-schema@npm:0.4.0": + version: 0.4.0 + resolution: "json-schema@npm:0.4.0" + checksum: 66389434c3469e698da0df2e7ac5a3281bcff75e797a5c127db7c5b56270e01ae13d9afa3c03344f76e32e81678337a8c912bdbb75101c62e487dc3778461d72 + languageName: node + linkType: hard + +"json-stringify-safe@npm:~5.0.1": + version: 5.0.1 + resolution: "json-stringify-safe@npm:5.0.1" + checksum: 48ec0adad5280b8a96bb93f4563aa1667fd7a36334f79149abd42446d0989f2ddc58274b479f4819f1f00617957e6344c886c55d05a4e15ebb4ab931e4a6a8ee + languageName: node + linkType: hard + +"json5@npm:^2.1.3": + version: 2.2.3 + resolution: "json5@npm:2.2.3" + bin: + json5: lib/cli.js + checksum: 2a7436a93393830bce797d4626275152e37e877b265e94ca69c99e3d20c2b9dab021279146a39cdb700e71b2dd32a4cebd1514cd57cee102b1af906ce5040349 + languageName: node + linkType: hard + +"jsonfile@npm:^2.1.0": + version: 2.4.0 + resolution: "jsonfile@npm:2.4.0" + dependencies: + graceful-fs: ^4.1.6 + dependenciesMeta: + graceful-fs: + optional: true + checksum: f5064aabbc9e35530dc471d8b203ae1f40dbe949ddde4391c6f6a6d310619a15f0efdae5587df594d1d70c555193aaeee9d2ed4aec9ffd5767bd5e4e62d49c3d + languageName: node + linkType: hard + +"jsonfile@npm:^4.0.0": + version: 4.0.0 + resolution: "jsonfile@npm:4.0.0" + dependencies: + graceful-fs: ^4.1.6 + dependenciesMeta: + graceful-fs: + optional: true + checksum: 6447d6224f0d31623eef9b51185af03ac328a7553efcee30fa423d98a9e276ca08db87d71e17f2310b0263fd3ffa6c2a90a6308367f661dc21580f9469897c9e + languageName: node + linkType: hard + +"jsonfile@npm:^6.0.1": + version: 6.1.0 + resolution: "jsonfile@npm:6.1.0" + dependencies: + graceful-fs: ^4.1.6 + universalify: ^2.0.0 + dependenciesMeta: + graceful-fs: + optional: true + checksum: 7af3b8e1ac8fe7f1eccc6263c6ca14e1966fcbc74b618d3c78a0a2075579487547b94f72b7a1114e844a1e15bb00d440e5d1720bfc4612d790a6f285d5ea8354 + languageName: node + linkType: hard + +"jsprim@npm:^1.2.2": + version: 1.4.2 + resolution: "jsprim@npm:1.4.2" + dependencies: + assert-plus: 1.0.0 + extsprintf: 1.3.0 + json-schema: 0.4.0 + verror: 1.10.0 + checksum: 2ad1b9fdcccae8b3d580fa6ced25de930eaa1ad154db21bbf8478a4d30bbbec7925b5f5ff29b933fba9412b16a17bd484a8da4fdb3663b5e27af95dd693bab2a + languageName: node + linkType: hard + +"keccak@npm:^3.0.0, keccak@npm:^3.0.2": + version: 3.0.3 + resolution: "keccak@npm:3.0.3" + dependencies: + node-addon-api: ^2.0.0 + node-gyp: latest + node-gyp-build: ^4.2.0 + readable-stream: ^3.6.0 + checksum: f08f04f5cc87013a3fc9e87262f761daff38945c86dd09c01a7f7930a15ae3e14f93b310ef821dcc83675a7b814eb1c983222399a2f263ad980251201d1b9a99 + languageName: node + linkType: hard + +"klaw@npm:^1.0.0": + version: 1.3.1 + resolution: "klaw@npm:1.3.1" + dependencies: + graceful-fs: ^4.1.9 + dependenciesMeta: + graceful-fs: + optional: true + checksum: 8f69e4797c26e7c3f2426bfa85f38a3da3c2cb1b4c6bd850d2377aed440d41ce9d806f2885c2e2e224372c56af4b1d43b8a499adecf9a05e7373dc6b8b7c52e4 + languageName: node + linkType: hard + +"level-supports@npm:^4.0.0": + version: 4.0.1 + resolution: "level-supports@npm:4.0.1" + checksum: d4552b42bb8cdeada07b0f6356c7a90fefe76279147331f291aceae26e3e56d5f927b09ce921647c0230bfe03ddfbdcef332be921e5c2194421ae2bfa3cf6368 + languageName: node + linkType: hard + +"level-transcoder@npm:^1.0.1": + version: 1.0.1 + resolution: "level-transcoder@npm:1.0.1" + dependencies: + buffer: ^6.0.3 + module-error: ^1.0.1 + checksum: 304f08d802faf3491a533b6d87ad8be3cabfd27f2713bbe9d4c633bf50fcb9460eab5a6776bf015e101ead7ba1c1853e05e7f341112f17a9d0cb37ee5a421a25 + languageName: node + linkType: hard + +"level@npm:^8.0.0": + version: 8.0.0 + resolution: "level@npm:8.0.0" + dependencies: + browser-level: ^1.0.1 + classic-level: ^1.2.0 + checksum: 13eb25bd71bfdca6cd714d1233adf9da97de9a8a4bf9f28d62a390b5c96d0250abaf983eb90eb8c4e89c7a985bb330750683d106f12670e5ea8fba1d7e608a1f + languageName: node + linkType: hard + +"lilconfig@npm:2.1.0": + version: 2.1.0 + resolution: "lilconfig@npm:2.1.0" + checksum: 8549bb352b8192375fed4a74694cd61ad293904eee33f9d4866c2192865c44c4eb35d10782966242634e0cbc1e91fe62b1247f148dc5514918e3a966da7ea117 + languageName: node + linkType: hard + +"lines-and-columns@npm:^1.1.6": + version: 1.2.4 + resolution: "lines-and-columns@npm:1.2.4" + checksum: 0c37f9f7fa212b38912b7145e1cd16a5f3cd34d782441c3e6ca653485d326f58b3caccda66efce1c5812bde4961bbde3374fae4b0d11bf1226152337f3894aa5 + languageName: node + linkType: hard + +"lint-staged@npm:>=10": + version: 13.2.3 + resolution: "lint-staged@npm:13.2.3" + dependencies: + chalk: 5.2.0 + cli-truncate: ^3.1.0 + commander: ^10.0.0 + debug: ^4.3.4 + execa: ^7.0.0 + lilconfig: 2.1.0 + listr2: ^5.0.7 + micromatch: ^4.0.5 + normalize-path: ^3.0.0 + object-inspect: ^1.12.3 + pidtree: ^0.6.0 + string-argv: ^0.3.1 + yaml: ^2.2.2 + bin: + lint-staged: bin/lint-staged.js + checksum: ff51a1e33072f488b28b938ed47323816a1ff278ef6d0e5cbe1704b292773a6c8ce945b504eae3a9b5702917a979523a741f17023e16077bd5fa35be687cc067 + languageName: node + linkType: hard + +"listr2@npm:^5.0.7": + version: 5.0.8 + resolution: "listr2@npm:5.0.8" + dependencies: + cli-truncate: ^2.1.0 + colorette: ^2.0.19 + log-update: ^4.0.0 + p-map: ^4.0.0 + rfdc: ^1.3.0 + rxjs: ^7.8.0 + through: ^2.3.8 + wrap-ansi: ^7.0.0 + peerDependencies: + enquirer: ">= 2.3.0 < 3" + peerDependenciesMeta: + enquirer: + optional: true + checksum: 8be9f5632627c4df0dc33f452c98d415a49e5f1614650d3cab1b103c33e95f2a7a0e9f3e1e5de00d51bf0b4179acd8ff11b25be77dbe097cf3773c05e728d46c + languageName: node + linkType: hard + +"locate-path@npm:^2.0.0": + version: 2.0.0 + resolution: "locate-path@npm:2.0.0" + dependencies: + p-locate: ^2.0.0 + path-exists: ^3.0.0 + checksum: 02d581edbbbb0fa292e28d96b7de36b5b62c2fa8b5a7e82638ebb33afa74284acf022d3b1e9ae10e3ffb7658fbc49163fcd5e76e7d1baaa7801c3e05a81da755 + languageName: node + linkType: hard + +"locate-path@npm:^3.0.0": + version: 3.0.0 + resolution: "locate-path@npm:3.0.0" + dependencies: + p-locate: ^3.0.0 + path-exists: ^3.0.0 + checksum: 53db3996672f21f8b0bf2a2c645ae2c13ffdae1eeecfcd399a583bce8516c0b88dcb4222ca6efbbbeb6949df7e46860895be2c02e8d3219abd373ace3bfb4e11 + languageName: node + linkType: hard + +"locate-path@npm:^6.0.0": + version: 6.0.0 + resolution: "locate-path@npm:6.0.0" + dependencies: + p-locate: ^5.0.0 + checksum: 72eb661788a0368c099a184c59d2fee760b3831c9c1c33955e8a19ae4a21b4116e53fa736dc086cdeb9fce9f7cc508f2f92d2d3aae516f133e16a2bb59a39f5a + languageName: node + linkType: hard + +"lodash.camelcase@npm:^4.3.0": + version: 4.3.0 + resolution: "lodash.camelcase@npm:4.3.0" + checksum: cb9227612f71b83e42de93eccf1232feeb25e705bdb19ba26c04f91e885bfd3dd5c517c4a97137658190581d3493ea3973072ca010aab7e301046d90740393d1 + languageName: node + linkType: hard + +"lodash.truncate@npm:^4.4.2": + version: 4.4.2 + resolution: "lodash.truncate@npm:4.4.2" + checksum: b463d8a382cfb5f0e71c504dcb6f807a7bd379ff1ea216669aa42c52fc28c54e404bfbd96791aa09e6df0de2c1d7b8f1b7f4b1a61f324d38fe98bc535aeee4f5 + languageName: node + linkType: hard + +"lodash@npm:^4.17.11, lodash@npm:^4.17.14, lodash@npm:^4.17.15, lodash@npm:^4.17.19, lodash@npm:^4.17.21": + version: 4.17.21 + resolution: "lodash@npm:4.17.21" + checksum: eb835a2e51d381e561e508ce932ea50a8e5a68f4ebdd771ea240d3048244a8d13658acbd502cd4829768c56f2e16bdd4340b9ea141297d472517b83868e677f7 + languageName: node + linkType: hard + +"log-symbols@npm:3.0.0": + version: 3.0.0 + resolution: "log-symbols@npm:3.0.0" + dependencies: + chalk: ^2.4.2 + checksum: f2322e1452d819050b11aad247660e1494f8b2219d40a964af91d5f9af1a90636f1b3d93f2952090e42af07cc5550aecabf6c1d8ec1181207e95cb66ba112361 + languageName: node + linkType: hard + +"log-symbols@npm:4.1.0": + version: 4.1.0 + resolution: "log-symbols@npm:4.1.0" + dependencies: + chalk: ^4.1.0 + is-unicode-supported: ^0.1.0 + checksum: fce1497b3135a0198803f9f07464165e9eb83ed02ceb2273930a6f8a508951178d8cf4f0378e9d28300a2ed2bc49050995d2bd5f53ab716bb15ac84d58c6ef74 + languageName: node + linkType: hard + +"log-update@npm:^4.0.0": + version: 4.0.0 + resolution: "log-update@npm:4.0.0" + dependencies: + ansi-escapes: ^4.3.0 + cli-cursor: ^3.1.0 + slice-ansi: ^4.0.0 + wrap-ansi: ^6.2.0 + checksum: ae2f85bbabc1906034154fb7d4c4477c79b3e703d22d78adee8b3862fa913942772e7fa11713e3d96fb46de4e3cabefbf5d0a544344f03b58d3c4bff52aa9eb2 + languageName: node + linkType: hard + +"loupe@npm:^2.3.1": + version: 2.3.6 + resolution: "loupe@npm:2.3.6" + dependencies: + get-func-name: ^2.0.0 + checksum: cc83f1b124a1df7384601d72d8d1f5fe95fd7a8185469fec48bb2e4027e45243949e7a013e8d91051a138451ff0552310c32aa9786e60b6a30d1e801bdc2163f + languageName: node + linkType: hard + +"lru-cache@npm:^5.1.1": + version: 5.1.1 + resolution: "lru-cache@npm:5.1.1" + dependencies: + yallist: ^3.0.2 + checksum: c154ae1cbb0c2206d1501a0e94df349653c92c8cbb25236d7e85190bcaf4567a03ac6eb43166fabfa36fd35623694da7233e88d9601fbf411a9a481d85dbd2cb + languageName: node + linkType: hard + +"lru-cache@npm:^6.0.0": + version: 6.0.0 + resolution: "lru-cache@npm:6.0.0" + dependencies: + yallist: ^4.0.0 + checksum: f97f499f898f23e4585742138a22f22526254fdba6d75d41a1c2526b3b6cc5747ef59c5612ba7375f42aca4f8461950e925ba08c991ead0651b4918b7c978297 + languageName: node + linkType: hard + +"lru-cache@npm:^7.7.1": + version: 7.18.3 + resolution: "lru-cache@npm:7.18.3" + checksum: e550d772384709deea3f141af34b6d4fa392e2e418c1498c078de0ee63670f1f46f5eee746e8ef7e69e1c895af0d4224e62ee33e66a543a14763b0f2e74c1356 + languageName: node + linkType: hard + +"lru-cache@npm:^9.1.1 || ^10.0.0": + version: 10.0.1 + resolution: "lru-cache@npm:10.0.1" + checksum: 06f8d0e1ceabd76bb6f644a26dbb0b4c471b79c7b514c13c6856113879b3bf369eb7b497dad4ff2b7e2636db202412394865b33c332100876d838ad1372f0181 + languageName: node + linkType: hard + +"lru_map@npm:^0.3.3": + version: 0.3.3 + resolution: "lru_map@npm:0.3.3" + checksum: ca9dd43c65ed7a4f117c548028101c5b6855e10923ea9d1f635af53ad20c5868ff428c364d454a7b57fe391b89c704982275410c3c5099cca5aeee00d76e169a + languageName: node + linkType: hard + +"make-error@npm:^1.1.1": + version: 1.3.6 + resolution: "make-error@npm:1.3.6" + checksum: b86e5e0e25f7f777b77fabd8e2cbf15737972869d852a22b7e73c17623928fccb826d8e46b9951501d3f20e51ad74ba8c59ed584f610526a48f8ccf88aaec402 + languageName: node + linkType: hard + +"make-fetch-happen@npm:^11.0.3": + version: 11.1.1 + resolution: "make-fetch-happen@npm:11.1.1" + dependencies: + agentkeepalive: ^4.2.1 + cacache: ^17.0.0 + http-cache-semantics: ^4.1.1 + http-proxy-agent: ^5.0.0 + https-proxy-agent: ^5.0.0 + is-lambda: ^1.0.1 + lru-cache: ^7.7.1 + minipass: ^5.0.0 + minipass-fetch: ^3.0.0 + minipass-flush: ^1.0.5 + minipass-pipeline: ^1.2.4 + negotiator: ^0.6.3 + promise-retry: ^2.0.1 + socks-proxy-agent: ^7.0.0 + ssri: ^10.0.0 + checksum: 7268bf274a0f6dcf0343829489a4506603ff34bd0649c12058753900b0eb29191dce5dba12680719a5d0a983d3e57810f594a12f3c18494e93a1fbc6348a4540 + languageName: node + linkType: hard + +"markdown-table@npm:^1.1.3": + version: 1.1.3 + resolution: "markdown-table@npm:1.1.3" + checksum: 292e8c956ae833c2ccb0a55cd8d87980cd657ab11cd9ff63c3fcc4d3a518d3b3882ba07410b8f477ba9e30b3f70658677e4e8acf61816dd6cfdd1f6293130664 + languageName: node + linkType: hard + +"match-all@npm:^1.2.6": + version: 1.2.6 + resolution: "match-all@npm:1.2.6" + checksum: 3d4f16b8fd082f2fd10e362f4a8b71c62f8a767591b3db831ca2bdcf726337e9a64e4abc30e2ef053dc2bcfb875a9ed80bd78e006ad5ef11380a7158d0cb00e1 + languageName: node + linkType: hard + +"mcl-wasm@npm:^0.7.1": + version: 0.7.9 + resolution: "mcl-wasm@npm:0.7.9" + checksum: 6b6ed5084156b98b2db70b223e1ba2c01953970b48a2e0c4ea3eeb9296610e6b3bfb2a2cce9e92e2d7ad61778b5f5a630e705e663835e915ba188c174a0a37fa + languageName: node + linkType: hard + +"md5.js@npm:^1.3.4": + version: 1.3.5 + resolution: "md5.js@npm:1.3.5" + dependencies: + hash-base: ^3.0.0 + inherits: ^2.0.1 + safe-buffer: ^5.1.2 + checksum: 098494d885684bcc4f92294b18ba61b7bd353c23147fbc4688c75b45cb8590f5a95fd4584d742415dcc52487f7a1ef6ea611cfa1543b0dc4492fe026357f3f0c + languageName: node + linkType: hard + +"memory-level@npm:^1.0.0": + version: 1.0.0 + resolution: "memory-level@npm:1.0.0" + dependencies: + abstract-level: ^1.0.0 + functional-red-black-tree: ^1.0.1 + module-error: ^1.0.1 + checksum: 80b1b7aedaf936e754adbcd7b9303018c3684fb32f9992fd967c448f145d177f16c724fbba9ed3c3590a9475fd563151eae664d69b83d2ad48714852e9fc5c72 + languageName: node + linkType: hard + +"memorystream@npm:^0.3.1": + version: 0.3.1 + resolution: "memorystream@npm:0.3.1" + checksum: f18b42440d24d09516d01466c06adf797df7873f0d40aa7db02e5fb9ed83074e5e65412d0720901d7069363465f82dc4f8bcb44f0cde271567a61426ce6ca2e9 + languageName: node + linkType: hard + +"merge-stream@npm:^2.0.0": + version: 2.0.0 + resolution: "merge-stream@npm:2.0.0" + checksum: 6fa4dcc8d86629705cea944a4b88ef4cb0e07656ebf223fa287443256414283dd25d91c1cd84c77987f2aec5927af1a9db6085757cb43d90eb170ebf4b47f4f4 + languageName: node + linkType: hard + +"merge2@npm:^1.3.0, merge2@npm:^1.4.1": + version: 1.4.1 + resolution: "merge2@npm:1.4.1" + checksum: 7268db63ed5169466540b6fb947aec313200bcf6d40c5ab722c22e242f651994619bcd85601602972d3c85bd2cc45a358a4c61937e9f11a061919a1da569b0c2 + languageName: node + linkType: hard + +"micromatch@npm:^4.0.2, micromatch@npm:^4.0.4, micromatch@npm:^4.0.5": + version: 4.0.5 + resolution: "micromatch@npm:4.0.5" + dependencies: + braces: ^3.0.2 + picomatch: ^2.3.1 + checksum: 02a17b671c06e8fefeeb6ef996119c1e597c942e632a21ef589154f23898c9c6a9858526246abb14f8bca6e77734aa9dcf65476fca47cedfb80d9577d52843fc + languageName: node + linkType: hard + +"mime-db@npm:1.52.0": + version: 1.52.0 + resolution: "mime-db@npm:1.52.0" + checksum: 0d99a03585f8b39d68182803b12ac601d9c01abfa28ec56204fa330bc9f3d1c5e14beb049bafadb3dbdf646dfb94b87e24d4ec7b31b7279ef906a8ea9b6a513f + languageName: node + linkType: hard + +"mime-types@npm:^2.1.12, mime-types@npm:~2.1.19": + version: 2.1.35 + resolution: "mime-types@npm:2.1.35" + dependencies: + mime-db: 1.52.0 + checksum: 89a5b7f1def9f3af5dad6496c5ed50191ae4331cc5389d7c521c8ad28d5fdad2d06fd81baf38fed813dc4e46bb55c8145bb0ff406330818c9cf712fb2e9b3836 + languageName: node + linkType: hard + +"mimic-fn@npm:^2.1.0": + version: 2.1.0 + resolution: "mimic-fn@npm:2.1.0" + checksum: d2421a3444848ce7f84bd49115ddacff29c15745db73f54041edc906c14b131a38d05298dae3081667627a59b2eb1ca4b436ff2e1b80f69679522410418b478a + languageName: node + linkType: hard + +"mimic-fn@npm:^4.0.0": + version: 4.0.0 + resolution: "mimic-fn@npm:4.0.0" + checksum: 995dcece15ee29aa16e188de6633d43a3db4611bcf93620e7e62109ec41c79c0f34277165b8ce5e361205049766e371851264c21ac64ca35499acb5421c2ba56 + languageName: node + linkType: hard + +"minimalistic-assert@npm:^1.0.0, minimalistic-assert@npm:^1.0.1": + version: 1.0.1 + resolution: "minimalistic-assert@npm:1.0.1" + checksum: cc7974a9268fbf130fb055aff76700d7e2d8be5f761fb5c60318d0ed010d839ab3661a533ad29a5d37653133385204c503bfac995aaa4236f4e847461ea32ba7 + languageName: node + linkType: hard + +"minimalistic-crypto-utils@npm:^1.0.1": + version: 1.0.1 + resolution: "minimalistic-crypto-utils@npm:1.0.1" + checksum: 6e8a0422b30039406efd4c440829ea8f988845db02a3299f372fceba56ffa94994a9c0f2fd70c17f9969eedfbd72f34b5070ead9656a34d3f71c0bd72583a0ed + languageName: node + linkType: hard + +"minimatch@npm:3.0.4": + version: 3.0.4 + resolution: "minimatch@npm:3.0.4" + dependencies: + brace-expansion: ^1.1.7 + checksum: 66ac295f8a7b59788000ea3749938b0970344c841750abd96694f80269b926ebcafad3deeb3f1da2522978b119e6ae3a5869b63b13a7859a456b3408bd18a078 + languageName: node + linkType: hard + +"minimatch@npm:5.0.1": + version: 5.0.1 + resolution: "minimatch@npm:5.0.1" + dependencies: + brace-expansion: ^2.0.1 + checksum: b34b98463da4754bc526b244d680c69d4d6089451ebe512edaf6dd9eeed0279399cfa3edb19233513b8f830bf4bfcad911dddcdf125e75074100d52f724774f0 + languageName: node + linkType: hard + +"minimatch@npm:^3.0.4, minimatch@npm:^3.1.1": + version: 3.1.2 + resolution: "minimatch@npm:3.1.2" + dependencies: + brace-expansion: ^1.1.7 + checksum: c154e566406683e7bcb746e000b84d74465b3a832c45d59912b9b55cd50dee66e5c4b1e5566dba26154040e51672f9aa450a9aef0c97cfc7336b78b7afb9540a + languageName: node + linkType: hard + +"minimatch@npm:^5.0.1": + version: 5.1.6 + resolution: "minimatch@npm:5.1.6" + dependencies: + brace-expansion: ^2.0.1 + checksum: 7564208ef81d7065a370f788d337cd80a689e981042cb9a1d0e6580b6c6a8c9279eba80010516e258835a988363f99f54a6f711a315089b8b42694f5da9d0d77 + languageName: node + linkType: hard + +"minimatch@npm:^9.0.1": + version: 9.0.3 + resolution: "minimatch@npm:9.0.3" + dependencies: + brace-expansion: ^2.0.1 + checksum: 253487976bf485b612f16bf57463520a14f512662e592e95c571afdab1442a6a6864b6c88f248ce6fc4ff0b6de04ac7aa6c8bb51e868e99d1d65eb0658a708b5 + languageName: node + linkType: hard + +"minimist@npm:^1.2.5": + version: 1.2.8 + resolution: "minimist@npm:1.2.8" + checksum: 75a6d645fb122dad29c06a7597bddea977258957ed88d7a6df59b5cd3fe4a527e253e9bbf2e783e4b73657f9098b96a5fe96ab8a113655d4109108577ecf85b0 + languageName: node + linkType: hard + +"minipass-collect@npm:^1.0.2": + version: 1.0.2 + resolution: "minipass-collect@npm:1.0.2" + dependencies: + minipass: ^3.0.0 + checksum: 14df761028f3e47293aee72888f2657695ec66bd7d09cae7ad558da30415fdc4752bbfee66287dcc6fd5e6a2fa3466d6c484dc1cbd986525d9393b9523d97f10 + languageName: node + linkType: hard + +"minipass-fetch@npm:^3.0.0": + version: 3.0.4 + resolution: "minipass-fetch@npm:3.0.4" + dependencies: + encoding: ^0.1.13 + minipass: ^7.0.3 + minipass-sized: ^1.0.3 + minizlib: ^2.1.2 + dependenciesMeta: + encoding: + optional: true + checksum: af7aad15d5c128ab1ebe52e043bdf7d62c3c6f0cecb9285b40d7b395e1375b45dcdfd40e63e93d26a0e8249c9efd5c325c65575aceee192883970ff8cb11364a + languageName: node + linkType: hard + +"minipass-flush@npm:^1.0.5": + version: 1.0.5 + resolution: "minipass-flush@npm:1.0.5" + dependencies: + minipass: ^3.0.0 + checksum: 56269a0b22bad756a08a94b1ffc36b7c9c5de0735a4dd1ab2b06c066d795cfd1f0ac44a0fcae13eece5589b908ecddc867f04c745c7009be0b566421ea0944cf + languageName: node + linkType: hard + +"minipass-pipeline@npm:^1.2.4": + version: 1.2.4 + resolution: "minipass-pipeline@npm:1.2.4" + dependencies: + minipass: ^3.0.0 + checksum: b14240dac0d29823c3d5911c286069e36d0b81173d7bdf07a7e4a91ecdef92cdff4baaf31ea3746f1c61e0957f652e641223970870e2353593f382112257971b + languageName: node + linkType: hard + +"minipass-sized@npm:^1.0.3": + version: 1.0.3 + resolution: "minipass-sized@npm:1.0.3" + dependencies: + minipass: ^3.0.0 + checksum: 79076749fcacf21b5d16dd596d32c3b6bf4d6e62abb43868fac21674078505c8b15eaca4e47ed844985a4514854f917d78f588fcd029693709417d8f98b2bd60 + languageName: node + linkType: hard + +"minipass@npm:^3.0.0": + version: 3.3.6 + resolution: "minipass@npm:3.3.6" + dependencies: + yallist: ^4.0.0 + checksum: a30d083c8054cee83cdcdc97f97e4641a3f58ae743970457b1489ce38ee1167b3aaf7d815cd39ec7a99b9c40397fd4f686e83750e73e652b21cb516f6d845e48 + languageName: node + linkType: hard + +"minipass@npm:^5.0.0": + version: 5.0.0 + resolution: "minipass@npm:5.0.0" + checksum: 425dab288738853fded43da3314a0b5c035844d6f3097a8e3b5b29b328da8f3c1af6fc70618b32c29ff906284cf6406b6841376f21caaadd0793c1d5a6a620ea + languageName: node + linkType: hard + +"minipass@npm:^5.0.0 || ^6.0.2 || ^7.0.0, minipass@npm:^7.0.3": + version: 7.0.4 + resolution: "minipass@npm:7.0.4" + checksum: 87585e258b9488caf2e7acea242fd7856bbe9a2c84a7807643513a338d66f368c7d518200ad7b70a508664d408aa000517647b2930c259a8b1f9f0984f344a21 + languageName: node + linkType: hard + +"minizlib@npm:^2.1.1, minizlib@npm:^2.1.2": + version: 2.1.2 + resolution: "minizlib@npm:2.1.2" + dependencies: + minipass: ^3.0.0 + yallist: ^4.0.0 + checksum: f1fdeac0b07cf8f30fcf12f4b586795b97be856edea22b5e9072707be51fc95d41487faec3f265b42973a304fe3a64acd91a44a3826a963e37b37bafde0212c3 + languageName: node + linkType: hard + +"mkdirp@npm:0.5.5": + version: 0.5.5 + resolution: "mkdirp@npm:0.5.5" + dependencies: + minimist: ^1.2.5 + bin: + mkdirp: bin/cmd.js + checksum: 3bce20ea525f9477befe458ab85284b0b66c8dc3812f94155af07c827175948cdd8114852ac6c6d82009b13c1048c37f6d98743eb019651ee25c39acc8aabe7d + languageName: node + linkType: hard + +"mkdirp@npm:^1.0.3, mkdirp@npm:^1.0.4": + version: 1.0.4 + resolution: "mkdirp@npm:1.0.4" + bin: + mkdirp: bin/cmd.js + checksum: a96865108c6c3b1b8e1d5e9f11843de1e077e57737602de1b82030815f311be11f96f09cce59bd5b903d0b29834733e5313f9301e3ed6d6f6fba2eae0df4298f + languageName: node + linkType: hard + +"mnemonist@npm:^0.38.0": + version: 0.38.5 + resolution: "mnemonist@npm:0.38.5" + dependencies: + obliterator: ^2.0.0 + checksum: 66080afc1616866beb164e230c432964d6eed467cf37ad00e9c10161b8267928124ca8f1d0ecfea86c85568acfa62d54faaf646a86968d1135189a0fdfdd6b78 + languageName: node + linkType: hard + +"mocha@npm:^10.0.0": + version: 10.2.0 + resolution: "mocha@npm:10.2.0" + dependencies: + ansi-colors: 4.1.1 + browser-stdout: 1.3.1 + chokidar: 3.5.3 + debug: 4.3.4 + diff: 5.0.0 + escape-string-regexp: 4.0.0 + find-up: 5.0.0 + glob: 7.2.0 + he: 1.2.0 + js-yaml: 4.1.0 + log-symbols: 4.1.0 + minimatch: 5.0.1 + ms: 2.1.3 + nanoid: 3.3.3 + serialize-javascript: 6.0.0 + strip-json-comments: 3.1.1 + supports-color: 8.1.1 + workerpool: 6.2.1 + yargs: 16.2.0 + yargs-parser: 20.2.4 + yargs-unparser: 2.0.0 + bin: + _mocha: bin/_mocha + mocha: bin/mocha.js + checksum: 406c45eab122ffd6ea2003c2f108b2bc35ba036225eee78e0c784b6fa2c7f34e2b13f1dbacef55a4fdf523255d76e4f22d1b5aacda2394bd11666febec17c719 + languageName: node + linkType: hard + +"mocha@npm:^7.1.1": + version: 7.2.0 + resolution: "mocha@npm:7.2.0" + dependencies: + ansi-colors: 3.2.3 + browser-stdout: 1.3.1 + chokidar: 3.3.0 + debug: 3.2.6 + diff: 3.5.0 + escape-string-regexp: 1.0.5 + find-up: 3.0.0 + glob: 7.1.3 + growl: 1.10.5 + he: 1.2.0 + js-yaml: 3.13.1 + log-symbols: 3.0.0 + minimatch: 3.0.4 + mkdirp: 0.5.5 + ms: 2.1.1 + node-environment-flags: 1.0.6 + object.assign: 4.1.0 + strip-json-comments: 2.0.1 + supports-color: 6.0.0 + which: 1.3.1 + wide-align: 1.1.3 + yargs: 13.3.2 + yargs-parser: 13.1.2 + yargs-unparser: 1.6.0 + bin: + _mocha: bin/_mocha + mocha: bin/mocha + checksum: d098484fe1b165bb964fdbf6b88b256c71fead47575ca7c5bcf8ed07db0dcff41905f6d2f0a05111a0441efaef9d09241a8cc1ddf7961056b28984ec63ba2874 + languageName: node + linkType: hard + +"module-error@npm:^1.0.1, module-error@npm:^1.0.2": + version: 1.0.2 + resolution: "module-error@npm:1.0.2" + checksum: 5d653e35bd55b3e95f8aee2cdac108082ea892e71b8f651be92cde43e4ee86abee4fa8bd7fc3fe5e68b63926d42f63c54cd17b87a560c31f18739295575a3962 + languageName: node + linkType: hard + +"ms@npm:2.1.1": + version: 2.1.1 + resolution: "ms@npm:2.1.1" + checksum: 0078a23cd916a9a7435c413caa14c57d4b4f6e2470e0ab554b6964163c8a4436448ac7ae020e883685475da6b6796cc396b670f579cb275db288a21e3e57721e + languageName: node + linkType: hard + +"ms@npm:2.1.2": + version: 2.1.2 + resolution: "ms@npm:2.1.2" + checksum: 673cdb2c3133eb050c745908d8ce632ed2c02d85640e2edb3ace856a2266a813b30c613569bf3354fdf4ea7d1a1494add3bfa95e2713baa27d0c2c71fc44f58f + languageName: node + linkType: hard + +"ms@npm:2.1.3, ms@npm:^2.0.0, ms@npm:^2.1.1": + version: 2.1.3 + resolution: "ms@npm:2.1.3" + checksum: aa92de608021b242401676e35cfa5aa42dd70cbdc082b916da7fb925c542173e36bce97ea3e804923fe92c0ad991434e4a38327e15a1b5b5f945d66df615ae6d + languageName: node + linkType: hard + +"murmur-128@npm:^0.2.1": + version: 0.2.1 + resolution: "murmur-128@npm:0.2.1" + dependencies: + encode-utf8: ^1.0.2 + fmix: ^0.1.0 + imul: ^1.0.0 + checksum: 94ff8b39bf1a1a7bde83b6d13f656bbe591e0a5b5ffe4384c39470120ab70e9eadf0af38557742a30d24421ddc63aea6bba1028a1d6b66553038ee86a660dd92 + languageName: node + linkType: hard + +"nanoid@npm:3.3.3": + version: 3.3.3 + resolution: "nanoid@npm:3.3.3" + bin: + nanoid: bin/nanoid.cjs + checksum: ada019402a07464a694553c61d2dca8a4353645a7d92f2830f0d487fedff403678a0bee5323a46522752b2eab95a0bc3da98b6cccaa7c0c55cd9975130e6d6f0 + languageName: node + linkType: hard + +"napi-macros@npm:^2.2.2": + version: 2.2.2 + resolution: "napi-macros@npm:2.2.2" + checksum: c6f9bd71cdbbc37ddc3535aa5be481238641d89585b8a3f4d301cb89abf459e2d294810432bb7d12056d1f9350b1a0899a5afcf460237a3da6c398cf0fec7629 + languageName: node + linkType: hard + +"negotiator@npm:^0.6.3": + version: 0.6.3 + resolution: "negotiator@npm:0.6.3" + checksum: b8ffeb1e262eff7968fc90a2b6767b04cfd9842582a9d0ece0af7049537266e7b2506dfb1d107a32f06dd849ab2aea834d5830f7f4d0e5cb7d36e1ae55d021d9 + languageName: node + linkType: hard + +"neo-async@npm:^2.6.2": + version: 2.6.2 + resolution: "neo-async@npm:2.6.2" + checksum: deac9f8d00eda7b2e5cd1b2549e26e10a0faa70adaa6fdadca701cc55f49ee9018e427f424bac0c790b7c7e2d3068db97f3093f1093975f2acb8f8818b936ed9 + languageName: node + linkType: hard + +"node-addon-api@npm:^2.0.0": + version: 2.0.2 + resolution: "node-addon-api@npm:2.0.2" + dependencies: + node-gyp: latest + checksum: 31fb22d674648204f8dd94167eb5aac896c841b84a9210d614bf5d97c74ef059cc6326389cf0c54d2086e35312938401d4cc82e5fcd679202503eb8ac84814f8 + languageName: node + linkType: hard + +"node-environment-flags@npm:1.0.6": + version: 1.0.6 + resolution: "node-environment-flags@npm:1.0.6" + dependencies: + object.getownpropertydescriptors: ^2.0.3 + semver: ^5.7.0 + checksum: 268139ed0f7fabdca346dcb26931300ec7a1dc54a58085a849e5c78a82b94967f55df40177a69d4e819da278d98686d5c4fd49ab0d7bcff16fda25b6fffc4ca3 + languageName: node + linkType: hard + +"node-gyp-build@npm:^4.2.0, node-gyp-build@npm:^4.3.0": + version: 4.6.0 + resolution: "node-gyp-build@npm:4.6.0" + bin: + node-gyp-build: bin.js + node-gyp-build-optional: optional.js + node-gyp-build-test: build-test.js + checksum: 25d78c5ef1f8c24291f4a370c47ba52fcea14f39272041a90a7894cd50d766f7c8cb8fb06c0f42bf6f69b204b49d9be3c8fc344aac09714d5bdb95965499eb15 + languageName: node + linkType: hard + +"node-gyp@npm:latest": + version: 9.4.0 + resolution: "node-gyp@npm:9.4.0" + dependencies: + env-paths: ^2.2.0 + exponential-backoff: ^3.1.1 + glob: ^7.1.4 + graceful-fs: ^4.2.6 + make-fetch-happen: ^11.0.3 + nopt: ^6.0.0 + npmlog: ^6.0.0 + rimraf: ^3.0.2 + semver: ^7.3.5 + tar: ^6.1.2 + which: ^2.0.2 + bin: + node-gyp: bin/node-gyp.js + checksum: 78b404e2e0639d64e145845f7f5a3cb20c0520cdaf6dda2f6e025e9b644077202ea7de1232396ba5bde3fee84cdc79604feebe6ba3ec84d464c85d407bb5da99 + languageName: node + linkType: hard + +"nopt@npm:^6.0.0": + version: 6.0.0 + resolution: "nopt@npm:6.0.0" + dependencies: + abbrev: ^1.0.0 + bin: + nopt: bin/nopt.js + checksum: 82149371f8be0c4b9ec2f863cc6509a7fd0fa729929c009f3a58e4eb0c9e4cae9920e8f1f8eb46e7d032fec8fb01bede7f0f41a67eb3553b7b8e14fa53de1dac + languageName: node + linkType: hard + +"normalize-path@npm:^3.0.0, normalize-path@npm:~3.0.0": + version: 3.0.0 + resolution: "normalize-path@npm:3.0.0" + checksum: 88eeb4da891e10b1318c4b2476b6e2ecbeb5ff97d946815ffea7794c31a89017c70d7f34b3c2ebf23ef4e9fc9fb99f7dffe36da22011b5b5c6ffa34f4873ec20 + languageName: node + linkType: hard + +"npm-run-path@npm:^5.1.0": + version: 5.1.0 + resolution: "npm-run-path@npm:5.1.0" + dependencies: + path-key: ^4.0.0 + checksum: dc184eb5ec239d6a2b990b43236845332ef12f4e0beaa9701de724aa797fe40b6bbd0157fb7639d24d3ab13f5d5cf22d223a19c6300846b8126f335f788bee66 + languageName: node + linkType: hard + +"npmlog@npm:^6.0.0": + version: 6.0.2 + resolution: "npmlog@npm:6.0.2" + dependencies: + are-we-there-yet: ^3.0.0 + console-control-strings: ^1.1.0 + gauge: ^4.0.3 + set-blocking: ^2.0.0 + checksum: ae238cd264a1c3f22091cdd9e2b106f684297d3c184f1146984ecbe18aaa86343953f26b9520dedd1b1372bc0316905b736c1932d778dbeb1fcf5a1001390e2a + languageName: node + linkType: hard + +"oauth-sign@npm:~0.9.0": + version: 0.9.0 + resolution: "oauth-sign@npm:0.9.0" + checksum: 8f5497a127967866a3c67094c21efd295e46013a94e6e828573c62220e9af568cc1d2d04b16865ba583e430510fa168baf821ea78f355146d8ed7e350fc44c64 + languageName: node + linkType: hard + +"object-assign@npm:^4.1.0": + version: 4.1.1 + resolution: "object-assign@npm:4.1.1" + checksum: fcc6e4ea8c7fe48abfbb552578b1c53e0d194086e2e6bbbf59e0a536381a292f39943c6e9628af05b5528aa5e3318bb30d6b2e53cadaf5b8fe9e12c4b69af23f + languageName: node + linkType: hard + +"object-inspect@npm:^1.12.3, object-inspect@npm:^1.9.0": + version: 1.12.3 + resolution: "object-inspect@npm:1.12.3" + checksum: dabfd824d97a5f407e6d5d24810d888859f6be394d8b733a77442b277e0808860555176719c5905e765e3743a7cada6b8b0a3b85e5331c530fd418cc8ae991db + languageName: node + linkType: hard + +"object-keys@npm:^1.0.11, object-keys@npm:^1.1.1": + version: 1.1.1 + resolution: "object-keys@npm:1.1.1" + checksum: b363c5e7644b1e1b04aa507e88dcb8e3a2f52b6ffd0ea801e4c7a62d5aa559affe21c55a07fd4b1fd55fc03a33c610d73426664b20032405d7b92a1414c34d6a + languageName: node + linkType: hard + +"object.assign@npm:4.1.0": + version: 4.1.0 + resolution: "object.assign@npm:4.1.0" + dependencies: + define-properties: ^1.1.2 + function-bind: ^1.1.1 + has-symbols: ^1.0.0 + object-keys: ^1.0.11 + checksum: 648a9a463580bf48332d9a49a76fede2660ab1ee7104d9459b8a240562246da790b4151c3c073f28fda31c1fdc555d25a1d871e72be403e997e4468c91f4801f + languageName: node + linkType: hard + +"object.assign@npm:^4.1.4": + version: 4.1.4 + resolution: "object.assign@npm:4.1.4" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.4 + has-symbols: ^1.0.3 + object-keys: ^1.1.1 + checksum: 76cab513a5999acbfe0ff355f15a6a125e71805fcf53de4e9d4e082e1989bdb81d1e329291e1e4e0ae7719f0e4ef80e88fb2d367ae60500d79d25a6224ac8864 + languageName: node + linkType: hard + +"object.getownpropertydescriptors@npm:^2.0.3": + version: 2.1.6 + resolution: "object.getownpropertydescriptors@npm:2.1.6" + dependencies: + array.prototype.reduce: ^1.0.5 + call-bind: ^1.0.2 + define-properties: ^1.2.0 + es-abstract: ^1.21.2 + safe-array-concat: ^1.0.0 + checksum: 7757ce0ef61c8bee7f8043f8980fd3d46fc1ab3faf0795bd1f9f836781143b4afc91f7219a3eed4675fbd0b562f3708f7e736d679ebfd43ea37ab6077d9f5004 + languageName: node + linkType: hard + +"obliterator@npm:^2.0.0": + version: 2.0.4 + resolution: "obliterator@npm:2.0.4" + checksum: f28ad35b6d812089315f375dc3e6e5f9bebf958ebe4b10ccd471c7115cbcf595e74bdac4783ae758e5b1f47e3096427fdb37cfa7bed566b132df92ff317b9a7c + languageName: node + linkType: hard + +"once@npm:^1.3.0": + version: 1.4.0 + resolution: "once@npm:1.4.0" + dependencies: + wrappy: 1 + checksum: cd0a88501333edd640d95f0d2700fbde6bff20b3d4d9bdc521bdd31af0656b5706570d6c6afe532045a20bb8dc0849f8332d6f2a416e0ba6d3d3b98806c7db68 + languageName: node + linkType: hard + +"onetime@npm:^5.1.0": + version: 5.1.2 + resolution: "onetime@npm:5.1.2" + dependencies: + mimic-fn: ^2.1.0 + checksum: 2478859ef817fc5d4e9c2f9e5728512ddd1dbc9fb7829ad263765bb6d3b91ce699d6e2332eef6b7dff183c2f490bd3349f1666427eaba4469fba0ac38dfd0d34 + languageName: node + linkType: hard + +"onetime@npm:^6.0.0": + version: 6.0.0 + resolution: "onetime@npm:6.0.0" + dependencies: + mimic-fn: ^4.0.0 + checksum: 0846ce78e440841335d4e9182ef69d5762e9f38aa7499b19f42ea1c4cd40f0b4446094c455c713f9adac3f4ae86f613bb5e30c99e52652764d06a89f709b3788 + languageName: node + linkType: hard + +"ordinal@npm:^1.0.3": + version: 1.0.3 + resolution: "ordinal@npm:1.0.3" + checksum: 6761c5b7606b6c4b0c22b4097dab4fe7ffcddacc49238eedf9c0ced877f5d4e4ad3f4fd43fefa1cc3f167cc54c7149267441b2ae85b81ccf13f45cf4b7947164 + languageName: node + linkType: hard + +"os-tmpdir@npm:~1.0.2": + version: 1.0.2 + resolution: "os-tmpdir@npm:1.0.2" + checksum: 5666560f7b9f10182548bf7013883265be33620b1c1b4a4d405c25be2636f970c5488ff3e6c48de75b55d02bde037249fe5dbfbb4c0fb7714953d56aed062e6d + languageName: node + linkType: hard + +"p-limit@npm:^1.1.0": + version: 1.3.0 + resolution: "p-limit@npm:1.3.0" + dependencies: + p-try: ^1.0.0 + checksum: 281c1c0b8c82e1ac9f81acd72a2e35d402bf572e09721ce5520164e9de07d8274451378a3470707179ad13240535558f4b277f02405ad752e08c7d5b0d54fbfd + languageName: node + linkType: hard + +"p-limit@npm:^2.0.0": + version: 2.3.0 + resolution: "p-limit@npm:2.3.0" + dependencies: + p-try: ^2.0.0 + checksum: 84ff17f1a38126c3314e91ecfe56aecbf36430940e2873dadaa773ffe072dc23b7af8e46d4b6485d302a11673fe94c6b67ca2cfbb60c989848b02100d0594ac1 + languageName: node + linkType: hard + +"p-limit@npm:^3.0.2": + version: 3.1.0 + resolution: "p-limit@npm:3.1.0" + dependencies: + yocto-queue: ^0.1.0 + checksum: 7c3690c4dbf62ef625671e20b7bdf1cbc9534e83352a2780f165b0d3ceba21907e77ad63401708145ca4e25bfc51636588d89a8c0aeb715e6c37d1c066430360 + languageName: node + linkType: hard + +"p-locate@npm:^2.0.0": + version: 2.0.0 + resolution: "p-locate@npm:2.0.0" + dependencies: + p-limit: ^1.1.0 + checksum: e2dceb9b49b96d5513d90f715780f6f4972f46987dc32a0e18bc6c3fc74a1a5d73ec5f81b1398af5e58b99ea1ad03fd41e9181c01fa81b4af2833958696e3081 + languageName: node + linkType: hard + +"p-locate@npm:^3.0.0": + version: 3.0.0 + resolution: "p-locate@npm:3.0.0" + dependencies: + p-limit: ^2.0.0 + checksum: 83991734a9854a05fe9dbb29f707ea8a0599391f52daac32b86f08e21415e857ffa60f0e120bfe7ce0cc4faf9274a50239c7895fc0d0579d08411e513b83a4ae + languageName: node + linkType: hard + +"p-locate@npm:^5.0.0": + version: 5.0.0 + resolution: "p-locate@npm:5.0.0" + dependencies: + p-limit: ^3.0.2 + checksum: 1623088f36cf1cbca58e9b61c4e62bf0c60a07af5ae1ca99a720837356b5b6c5ba3eb1b2127e47a06865fee59dd0453cad7cc844cda9d5a62ac1a5a51b7c86d3 + languageName: node + linkType: hard + +"p-map@npm:^4.0.0": + version: 4.0.0 + resolution: "p-map@npm:4.0.0" + dependencies: + aggregate-error: ^3.0.0 + checksum: cb0ab21ec0f32ddffd31dfc250e3afa61e103ef43d957cc45497afe37513634589316de4eb88abdfd969fe6410c22c0b93ab24328833b8eb1ccc087fc0442a1c + languageName: node + linkType: hard + +"p-try@npm:^1.0.0": + version: 1.0.0 + resolution: "p-try@npm:1.0.0" + checksum: 3b5303f77eb7722144154288bfd96f799f8ff3e2b2b39330efe38db5dd359e4fb27012464cd85cb0a76e9b7edd1b443568cb3192c22e7cffc34989df0bafd605 + languageName: node + linkType: hard + +"p-try@npm:^2.0.0": + version: 2.2.0 + resolution: "p-try@npm:2.2.0" + checksum: f8a8e9a7693659383f06aec604ad5ead237c7a261c18048a6e1b5b85a5f8a067e469aa24f5bc009b991ea3b058a87f5065ef4176793a200d4917349881216cae + languageName: node + linkType: hard + +"parent-module@npm:^1.0.0": + version: 1.0.1 + resolution: "parent-module@npm:1.0.1" + dependencies: + callsites: ^3.0.0 + checksum: 6ba8b255145cae9470cf5551eb74be2d22281587af787a2626683a6c20fbb464978784661478dd2a3f1dad74d1e802d403e1b03c1a31fab310259eec8ac560ff + languageName: node + linkType: hard + +"parse-cache-control@npm:^1.0.1": + version: 1.0.1 + resolution: "parse-cache-control@npm:1.0.1" + checksum: 5a70868792124eb07c2dd07a78fcb824102e972e908254e9e59ce59a4796c51705ff28196d2b20d3b7353d14e9f98e65ed0e4eda9be072cc99b5297dc0466fee + languageName: node + linkType: hard + +"parse-json@npm:^5.0.0": + version: 5.2.0 + resolution: "parse-json@npm:5.2.0" + dependencies: + "@babel/code-frame": ^7.0.0 + error-ex: ^1.3.1 + json-parse-even-better-errors: ^2.3.0 + lines-and-columns: ^1.1.6 + checksum: 62085b17d64da57f40f6afc2ac1f4d95def18c4323577e1eced571db75d9ab59b297d1d10582920f84b15985cbfc6b6d450ccbf317644cfa176f3ed982ad87e2 + languageName: node + linkType: hard + +"path-exists@npm:^3.0.0": + version: 3.0.0 + resolution: "path-exists@npm:3.0.0" + checksum: 96e92643aa34b4b28d0de1cd2eba52a1c5313a90c6542d03f62750d82480e20bfa62bc865d5cfc6165f5fcd5aeb0851043c40a39be5989646f223300021bae0a + languageName: node + linkType: hard + +"path-exists@npm:^4.0.0": + version: 4.0.0 + resolution: "path-exists@npm:4.0.0" + checksum: 505807199dfb7c50737b057dd8d351b82c033029ab94cb10a657609e00c1bc53b951cfdbccab8de04c5584d5eff31128ce6afd3db79281874a5ef2adbba55ed1 + languageName: node + linkType: hard + +"path-is-absolute@npm:^1.0.0": + version: 1.0.1 + resolution: "path-is-absolute@npm:1.0.1" + checksum: 060840f92cf8effa293bcc1bea81281bd7d363731d214cbe5c227df207c34cd727430f70c6037b5159c8a870b9157cba65e775446b0ab06fd5ecc7e54615a3b8 + languageName: node + linkType: hard + +"path-key@npm:^3.1.0": + version: 3.1.1 + resolution: "path-key@npm:3.1.1" + checksum: 55cd7a9dd4b343412a8386a743f9c746ef196e57c823d90ca3ab917f90ab9f13dd0ded27252ba49dbdfcab2b091d998bc446f6220cd3cea65db407502a740020 + languageName: node + linkType: hard + +"path-key@npm:^4.0.0": + version: 4.0.0 + resolution: "path-key@npm:4.0.0" + checksum: 8e6c314ae6d16b83e93032c61020129f6f4484590a777eed709c4a01b50e498822b00f76ceaf94bc64dbd90b327df56ceadce27da3d83393790f1219e07721d7 + languageName: node + linkType: hard + +"path-parse@npm:^1.0.6": + version: 1.0.7 + resolution: "path-parse@npm:1.0.7" + checksum: 49abf3d81115642938a8700ec580da6e830dde670be21893c62f4e10bd7dd4c3742ddc603fe24f898cba7eb0c6bc1777f8d9ac14185d34540c6d4d80cd9cae8a + languageName: node + linkType: hard + +"path-scurry@npm:^1.10.1": + version: 1.10.1 + resolution: "path-scurry@npm:1.10.1" + dependencies: + lru-cache: ^9.1.1 || ^10.0.0 + minipass: ^5.0.0 || ^6.0.2 || ^7.0.0 + checksum: e2557cff3a8fb8bc07afdd6ab163a92587884f9969b05bbbaf6fe7379348bfb09af9ed292af12ed32398b15fb443e81692047b786d1eeb6d898a51eb17ed7d90 + languageName: node + linkType: hard + +"path-type@npm:^4.0.0": + version: 4.0.0 + resolution: "path-type@npm:4.0.0" + checksum: 5b1e2daa247062061325b8fdbfd1fb56dde0a448fb1455453276ea18c60685bdad23a445dc148cf87bc216be1573357509b7d4060494a6fd768c7efad833ee45 + languageName: node + linkType: hard + +"pathval@npm:^1.1.1": + version: 1.1.1 + resolution: "pathval@npm:1.1.1" + checksum: 090e3147716647fb7fb5b4b8c8e5b55e5d0a6086d085b6cd23f3d3c01fcf0ff56fd3cc22f2f4a033bd2e46ed55d61ed8379e123b42afe7d531a2a5fc8bb556d6 + languageName: node + linkType: hard + +"pbkdf2@npm:^3.0.17": + version: 3.1.2 + resolution: "pbkdf2@npm:3.1.2" + dependencies: + create-hash: ^1.1.2 + create-hmac: ^1.1.4 + ripemd160: ^2.0.1 + safe-buffer: ^5.0.1 + sha.js: ^2.4.8 + checksum: 2c950a100b1da72123449208e231afc188d980177d021d7121e96a2de7f2abbc96ead2b87d03d8fe5c318face097f203270d7e27908af9f471c165a4e8e69c92 + languageName: node + linkType: hard + +"performance-now@npm:^2.1.0": + version: 2.1.0 + resolution: "performance-now@npm:2.1.0" + checksum: 534e641aa8f7cba160f0afec0599b6cecefbb516a2e837b512be0adbe6c1da5550e89c78059c7fabc5c9ffdf6627edabe23eb7c518c4500067a898fa65c2b550 + languageName: node + linkType: hard + +"picomatch@npm:^2.0.4, picomatch@npm:^2.2.1, picomatch@npm:^2.3.1": + version: 2.3.1 + resolution: "picomatch@npm:2.3.1" + checksum: 050c865ce81119c4822c45d3c84f1ced46f93a0126febae20737bd05ca20589c564d6e9226977df859ed5e03dc73f02584a2b0faad36e896936238238b0446cf + languageName: node + linkType: hard + +"pidtree@npm:^0.6.0": + version: 0.6.0 + resolution: "pidtree@npm:0.6.0" + bin: + pidtree: bin/pidtree.js + checksum: 8fbc073ede9209dd15e80d616e65eb674986c93be49f42d9ddde8dbbd141bb53d628a7ca4e58ab5c370bb00383f67d75df59a9a226dede8fa801267a7030c27a + languageName: node + linkType: hard + +"pluralize@npm:^8.0.0": + version: 8.0.0 + resolution: "pluralize@npm:8.0.0" + checksum: 08931d4a6a4a5561a7f94f67a31c17e6632cb21e459ab3ff4f6f629d9a822984cf8afef2311d2005fbea5d7ef26016ebb090db008e2d8bce39d0a9a9d218736e + languageName: node + linkType: hard + +"prettier-plugin-solidity@npm:^1.0.0-beta.19": + version: 1.1.3 + resolution: "prettier-plugin-solidity@npm:1.1.3" + dependencies: + "@solidity-parser/parser": ^0.16.0 + semver: ^7.3.8 + solidity-comments-extractor: ^0.0.7 + peerDependencies: + prettier: ">=2.3.0 || >=3.0.0-alpha.0" + checksum: d5aadfa411a4d983a2bd204048726fd91fbcaffbfa26d818ef0d6001fb65f82d0eae082e935e96c79e65e09ed979b186311ddb8c38be2f0ce5dd5f5265df77fe + languageName: node + linkType: hard + +"prettier@npm:^2.1.2, prettier@npm:^2.5.1, prettier@npm:^2.8.3": + version: 2.8.8 + resolution: "prettier@npm:2.8.8" + bin: + prettier: bin-prettier.js + checksum: b49e409431bf129dd89238d64299ba80717b57ff5a6d1c1a8b1a28b590d998a34e083fa13573bc732bb8d2305becb4c9a4407f8486c81fa7d55100eb08263cf8 + languageName: node + linkType: hard + +"process-nextick-args@npm:~2.0.0": + version: 2.0.1 + resolution: "process-nextick-args@npm:2.0.1" + checksum: 1d38588e520dab7cea67cbbe2efdd86a10cc7a074c09657635e34f035277b59fbb57d09d8638346bf7090f8e8ebc070c96fa5fd183b777fff4f5edff5e9466cf + languageName: node + linkType: hard + +"promise-retry@npm:^2.0.1": + version: 2.0.1 + resolution: "promise-retry@npm:2.0.1" + dependencies: + err-code: ^2.0.2 + retry: ^0.12.0 + checksum: f96a3f6d90b92b568a26f71e966cbbc0f63ab85ea6ff6c81284dc869b41510e6cdef99b6b65f9030f0db422bf7c96652a3fff9f2e8fb4a0f069d8f4430359429 + languageName: node + linkType: hard + +"promise@npm:^8.0.0": + version: 8.3.0 + resolution: "promise@npm:8.3.0" + dependencies: + asap: ~2.0.6 + checksum: a69f0ddbddf78ffc529cffee7ad950d307347615970564b17988ce43fbe767af5c738a9439660b24a9a8cbea106c0dcbb6c2b20e23b7e96a8e89e5c2679e94d5 + languageName: node + linkType: hard + +"psl@npm:^1.1.28": + version: 1.9.0 + resolution: "psl@npm:1.9.0" + checksum: 20c4277f640c93d393130673f392618e9a8044c6c7bf61c53917a0fddb4952790f5f362c6c730a9c32b124813e173733f9895add8d26f566ed0ea0654b2e711d + languageName: node + linkType: hard + +"punycode@npm:^2.1.0, punycode@npm:^2.1.1": + version: 2.3.0 + resolution: "punycode@npm:2.3.0" + checksum: 39f760e09a2a3bbfe8f5287cf733ecdad69d6af2fe6f97ca95f24b8921858b91e9ea3c9eeec6e08cede96181b3bb33f95c6ffd8c77e63986508aa2e8159fa200 + languageName: node + linkType: hard + +"qs@npm:^6.4.0, qs@npm:^6.7.0, qs@npm:^6.9.4": + version: 6.11.2 + resolution: "qs@npm:6.11.2" + dependencies: + side-channel: ^1.0.4 + checksum: e812f3c590b2262548647d62f1637b6989cc56656dc960b893fe2098d96e1bd633f36576f4cd7564dfbff9db42e17775884db96d846bebe4f37420d073ecdc0b + languageName: node + linkType: hard + +"qs@npm:~6.5.2": + version: 6.5.3 + resolution: "qs@npm:6.5.3" + checksum: 6f20bf08cabd90c458e50855559539a28d00b2f2e7dddcb66082b16a43188418cb3cb77cbd09268bcef6022935650f0534357b8af9eeb29bf0f27ccb17655692 + languageName: node + linkType: hard + +"queue-microtask@npm:^1.2.2, queue-microtask@npm:^1.2.3": + version: 1.2.3 + resolution: "queue-microtask@npm:1.2.3" + checksum: b676f8c040cdc5b12723ad2f91414d267605b26419d5c821ff03befa817ddd10e238d22b25d604920340fd73efd8ba795465a0377c4adf45a4a41e4234e42dc4 + languageName: node + linkType: hard + +"randombytes@npm:^2.1.0": + version: 2.1.0 + resolution: "randombytes@npm:2.1.0" + dependencies: + safe-buffer: ^5.1.0 + checksum: d779499376bd4cbb435ef3ab9a957006c8682f343f14089ed5f27764e4645114196e75b7f6abf1cbd84fd247c0cb0651698444df8c9bf30e62120fbbc52269d6 + languageName: node + linkType: hard + +"raw-body@npm:^2.4.1": + version: 2.5.2 + resolution: "raw-body@npm:2.5.2" + dependencies: + bytes: 3.1.2 + http-errors: 2.0.0 + iconv-lite: 0.4.24 + unpipe: 1.0.0 + checksum: ba1583c8d8a48e8fbb7a873fdbb2df66ea4ff83775421bfe21ee120140949ab048200668c47d9ae3880012f6e217052690628cf679ddfbd82c9fc9358d574676 + languageName: node + linkType: hard + +"readable-stream@npm:^2.2.2": + version: 2.3.8 + resolution: "readable-stream@npm:2.3.8" + dependencies: + core-util-is: ~1.0.0 + inherits: ~2.0.3 + isarray: ~1.0.0 + process-nextick-args: ~2.0.0 + safe-buffer: ~5.1.1 + string_decoder: ~1.1.1 + util-deprecate: ~1.0.1 + checksum: 65645467038704f0c8aaf026a72fbb588a9e2ef7a75cd57a01702ee9db1c4a1e4b03aaad36861a6a0926546a74d174149c8c207527963e0c2d3eee2f37678a42 + languageName: node + linkType: hard + +"readable-stream@npm:^3.6.0": + version: 3.6.2 + resolution: "readable-stream@npm:3.6.2" + dependencies: + inherits: ^2.0.3 + string_decoder: ^1.1.1 + util-deprecate: ^1.0.1 + checksum: bdcbe6c22e846b6af075e32cf8f4751c2576238c5043169a1c221c92ee2878458a816a4ea33f4c67623c0b6827c8a400409bfb3cf0bf3381392d0b1dfb52ac8d + languageName: node + linkType: hard + +"readdirp@npm:~3.2.0": + version: 3.2.0 + resolution: "readdirp@npm:3.2.0" + dependencies: + picomatch: ^2.0.4 + checksum: 0456a4465a13eb5eaf40f0e0836b1bc6b9ebe479b48ba6f63a738b127a1990fb7b38f3ec4b4b6052f9230f976bc0558f12812347dc6b42ce4d548cfe82a9b6f3 + languageName: node + linkType: hard + +"readdirp@npm:~3.6.0": + version: 3.6.0 + resolution: "readdirp@npm:3.6.0" + dependencies: + picomatch: ^2.2.1 + checksum: 1ced032e6e45670b6d7352d71d21ce7edf7b9b928494dcaba6f11fba63180d9da6cd7061ebc34175ffda6ff529f481818c962952004d273178acd70f7059b320 + languageName: node + linkType: hard + +"reduce-flatten@npm:^2.0.0": + version: 2.0.0 + resolution: "reduce-flatten@npm:2.0.0" + checksum: 64393ef99a16b20692acfd60982d7fdbd7ff8d9f8f185c6023466444c6dd2abb929d67717a83cec7f7f8fb5f46a25d515b3b2bf2238fdbfcdbfd01d2a9e73cb8 + languageName: node + linkType: hard + +"regexp.prototype.flags@npm:^1.5.0": + version: 1.5.0 + resolution: "regexp.prototype.flags@npm:1.5.0" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.2.0 + functions-have-names: ^1.2.3 + checksum: c541687cdbdfff1b9a07f6e44879f82c66bbf07665f9a7544c5fd16acdb3ec8d1436caab01662d2fbcad403f3499d49ab0b77fbc7ef29ef961d98cc4bc9755b4 + languageName: node + linkType: hard + +"req-cwd@npm:^2.0.0": + version: 2.0.0 + resolution: "req-cwd@npm:2.0.0" + dependencies: + req-from: ^2.0.0 + checksum: c44f9dea0b0f7d3a72be18a04f7769e0eefbadca363e3a346c1c02b79745126c871e1f6970357b3e731c26740aad8344bf80fb3ce055a2bcf8ca85ad2b44f519 + languageName: node + linkType: hard + +"req-from@npm:^2.0.0": + version: 2.0.0 + resolution: "req-from@npm:2.0.0" + dependencies: + resolve-from: ^3.0.0 + checksum: 4c369881a2296e23e71668ed089c5d93b37652fe900ec9f1e1f5c1da65f6bca4ee271e97ba2b806fdea50219e011995d1df3c80a7209015cc1e1fc622507f140 + languageName: node + linkType: hard + +"request-promise-core@npm:1.1.4": + version: 1.1.4 + resolution: "request-promise-core@npm:1.1.4" + dependencies: + lodash: ^4.17.19 + peerDependencies: + request: ^2.34 + checksum: c798bafd552961e36fbf5023b1d081e81c3995ab390f1bc8ef38a711ba3fe4312eb94dbd61887073d7356c3499b9380947d7f62faa805797c0dc50f039425699 + languageName: node + linkType: hard + +"request-promise-native@npm:^1.0.5": + version: 1.0.9 + resolution: "request-promise-native@npm:1.0.9" + dependencies: + request-promise-core: 1.1.4 + stealthy-require: ^1.1.1 + tough-cookie: ^2.3.3 + peerDependencies: + request: ^2.34 + checksum: 3e2c694eefac88cb20beef8911ad57a275ab3ccbae0c4ca6c679fffb09d5fd502458aab08791f0814ca914b157adab2d4e472597c97a73be702918e41725ed69 + languageName: node + linkType: hard + +"request@npm:^2.88.0": + version: 2.88.2 + resolution: "request@npm:2.88.2" + dependencies: + aws-sign2: ~0.7.0 + aws4: ^1.8.0 + caseless: ~0.12.0 + combined-stream: ~1.0.6 + extend: ~3.0.2 + forever-agent: ~0.6.1 + form-data: ~2.3.2 + har-validator: ~5.1.3 + http-signature: ~1.2.0 + is-typedarray: ~1.0.0 + isstream: ~0.1.2 + json-stringify-safe: ~5.0.1 + mime-types: ~2.1.19 + oauth-sign: ~0.9.0 + performance-now: ^2.1.0 + qs: ~6.5.2 + safe-buffer: ^5.1.2 + tough-cookie: ~2.5.0 + tunnel-agent: ^0.6.0 + uuid: ^3.3.2 + checksum: 4e112c087f6eabe7327869da2417e9d28fcd0910419edd2eb17b6acfc4bfa1dad61954525949c228705805882d8a98a86a0ea12d7f739c01ee92af7062996983 + languageName: node + linkType: hard + +"require-directory@npm:^2.1.1": + version: 2.1.1 + resolution: "require-directory@npm:2.1.1" + checksum: fb47e70bf0001fdeabdc0429d431863e9475e7e43ea5f94ad86503d918423c1543361cc5166d713eaa7029dd7a3d34775af04764bebff99ef413111a5af18c80 + languageName: node + linkType: hard + +"require-from-string@npm:^2.0.0, require-from-string@npm:^2.0.2": + version: 2.0.2 + resolution: "require-from-string@npm:2.0.2" + checksum: a03ef6895445f33a4015300c426699bc66b2b044ba7b670aa238610381b56d3f07c686251740d575e22f4c87531ba662d06937508f0f3c0f1ddc04db3130560b + languageName: node + linkType: hard + +"require-main-filename@npm:^2.0.0": + version: 2.0.0 + resolution: "require-main-filename@npm:2.0.0" + checksum: e9e294695fea08b076457e9ddff854e81bffbe248ed34c1eec348b7abbd22a0d02e8d75506559e2265e96978f3c4720bd77a6dad84755de8162b357eb6c778c7 + languageName: node + linkType: hard + +"resolve-from@npm:^3.0.0": + version: 3.0.0 + resolution: "resolve-from@npm:3.0.0" + checksum: fff9819254d2d62b57f74e5c2ca9c0bdd425ca47287c4d801bc15f947533148d858229ded7793b0f59e61e49e782fffd6722048add12996e1bd4333c29669062 + languageName: node + linkType: hard + +"resolve-from@npm:^4.0.0": + version: 4.0.0 + resolution: "resolve-from@npm:4.0.0" + checksum: f4ba0b8494846a5066328ad33ef8ac173801a51739eb4d63408c847da9a2e1c1de1e6cbbf72699211f3d13f8fc1325648b169bd15eb7da35688e30a5fb0e4a7f + languageName: node + linkType: hard + +"resolve@npm:1.17.0": + version: 1.17.0 + resolution: "resolve@npm:1.17.0" + dependencies: + path-parse: ^1.0.6 + checksum: 9ceaf83b3429f2d7ff5d0281b8d8f18a1f05b6ca86efea7633e76b8f76547f33800799dfdd24434942dec4fbd9e651ed3aef577d9a6b5ec87ad89c1060e24759 + languageName: node + linkType: hard + +"resolve@patch:resolve@1.17.0#~builtin": + version: 1.17.0 + resolution: "resolve@patch:resolve@npm%3A1.17.0#~builtin::version=1.17.0&hash=c3c19d" + dependencies: + path-parse: ^1.0.6 + checksum: 6fd799f282ddf078c4bc20ce863e3af01fa8cb218f0658d9162c57161a2dbafe092b13015b9a4c58d0e1e801cf7aa7a4f13115fea9db98c3f9a0c43e429bad6f + languageName: node + linkType: hard + +"restore-cursor@npm:^3.1.0": + version: 3.1.0 + resolution: "restore-cursor@npm:3.1.0" + dependencies: + onetime: ^5.1.0 + signal-exit: ^3.0.2 + checksum: f877dd8741796b909f2a82454ec111afb84eb45890eb49ac947d87991379406b3b83ff9673a46012fca0d7844bb989f45cc5b788254cf1a39b6b5a9659de0630 + languageName: node + linkType: hard + +"retry@npm:^0.12.0": + version: 0.12.0 + resolution: "retry@npm:0.12.0" + checksum: 623bd7d2e5119467ba66202d733ec3c2e2e26568074923bc0585b6b99db14f357e79bdedb63cab56cec47491c4a0da7e6021a7465ca6dc4f481d3898fdd3158c + languageName: node + linkType: hard + +"reusify@npm:^1.0.4": + version: 1.0.4 + resolution: "reusify@npm:1.0.4" + checksum: c3076ebcc22a6bc252cb0b9c77561795256c22b757f40c0d8110b1300723f15ec0fc8685e8d4ea6d7666f36c79ccc793b1939c748bf36f18f542744a4e379fcc + languageName: node + linkType: hard + +"rfdc@npm:^1.3.0": + version: 1.3.0 + resolution: "rfdc@npm:1.3.0" + checksum: fb2ba8512e43519983b4c61bd3fa77c0f410eff6bae68b08614437bc3f35f91362215f7b4a73cbda6f67330b5746ce07db5dd9850ad3edc91271ad6deea0df32 + languageName: node + linkType: hard + +"rimraf@npm:^2.2.8": + version: 2.7.1 + resolution: "rimraf@npm:2.7.1" + dependencies: + glob: ^7.1.3 + bin: + rimraf: ./bin.js + checksum: cdc7f6eacb17927f2a075117a823e1c5951792c6498ebcce81ca8203454a811d4cf8900314154d3259bb8f0b42ab17f67396a8694a54cae3283326e57ad250cd + languageName: node + linkType: hard + +"rimraf@npm:^3.0.2": + version: 3.0.2 + resolution: "rimraf@npm:3.0.2" + dependencies: + glob: ^7.1.3 + bin: + rimraf: bin.js + checksum: 87f4164e396f0171b0a3386cc1877a817f572148ee13a7e113b238e48e8a9f2f31d009a92ec38a591ff1567d9662c6b67fd8818a2dbbaed74bc26a87a2a4a9a0 + languageName: node + linkType: hard + +"ripemd160@npm:^2.0.0, ripemd160@npm:^2.0.1": + version: 2.0.2 + resolution: "ripemd160@npm:2.0.2" + dependencies: + hash-base: ^3.0.0 + inherits: ^2.0.1 + checksum: 006accc40578ee2beae382757c4ce2908a826b27e2b079efdcd2959ee544ddf210b7b5d7d5e80467807604244e7388427330f5c6d4cd61e6edaddc5773ccc393 + languageName: node + linkType: hard + +"rlp@npm:^2.2.3": + version: 2.2.7 + resolution: "rlp@npm:2.2.7" + dependencies: + bn.js: ^5.2.0 + bin: + rlp: bin/rlp + checksum: 3db4dfe5c793f40ac7e0be689a1f75d05e6f2ca0c66189aeb62adab8c436b857ab4420a419251ee60370d41d957a55698fc5e23ab1e1b41715f33217bc4bb558 + languageName: node + linkType: hard + +"ronin-dpos-contract@workspace:.": + version: 0.0.0-use.local + resolution: "ronin-dpos-contract@workspace:." + dependencies: + "@nomicfoundation/hardhat-chai-matchers": ^1.0.3 + "@nomicfoundation/hardhat-foundry": ^1.0.1 + "@nomiclabs/hardhat-ethers": ^2.0.3 + "@openzeppelin/contracts": 4.7.3 + "@solidstate/hardhat-4byte-uploader": ^1.1.0 + "@typechain/ethers-v5": ^8.0.5 + "@typechain/hardhat": ^3.0.0 + "@types/chai": ^4.3.0 + "@types/fs-extra": 11.0.1 + "@types/mocha": ^9.0.0 + "@types/node": ^17.0.0 + chai: ^4.3.4 + dotenv: ^10.0.0 + ethers: ^5.5.2 + fs-extra: 11.1.1 + hardhat: 2.14.0 + hardhat-contract-sizer: 2.8.0 + hardhat-deploy: 0.11.29 + hardhat-gas-reporter: ^1.0.8 + hardhat-storage-layout: ^0.1.7 + husky: ^7.0.4 + lint-staged: ">=10" + prettier: ^2.5.1 + prettier-plugin-solidity: ^1.0.0-beta.19 + rimraf: ^3.0.2 + solc-0.8: "npm:solc@^0.8.0" + solhint: ^3.3.6 + solidity-docgen: 0.5.16 + table: ^6.8.1 + ts-node: ^10.4.0 + typechain: ^6.0.5 + typescript: ^4.5.4 + languageName: unknown + linkType: soft + +"run-parallel-limit@npm:^1.1.0": + version: 1.1.0 + resolution: "run-parallel-limit@npm:1.1.0" + dependencies: + queue-microtask: ^1.2.2 + checksum: 672c3b87e7f939c684b9965222b361421db0930223ed1e43ebf0e7e48ccc1a022ea4de080bef4d5468434e2577c33b7681e3f03b7593fdc49ad250a55381123c + languageName: node + linkType: hard + +"run-parallel@npm:^1.1.9": + version: 1.2.0 + resolution: "run-parallel@npm:1.2.0" + dependencies: + queue-microtask: ^1.2.2 + checksum: cb4f97ad25a75ebc11a8ef4e33bb962f8af8516bb2001082ceabd8902e15b98f4b84b4f8a9b222e5d57fc3bd1379c483886ed4619367a7680dad65316993021d + languageName: node + linkType: hard + +"rustbn.js@npm:~0.2.0": + version: 0.2.0 + resolution: "rustbn.js@npm:0.2.0" + checksum: 2148e7ba34e70682907ee29df4784639e6eb025481b2c91249403b7ec57181980161868d9aa24822a5075dd1bb5a180dfedc77309e5f0d27b6301f9b563af99a + languageName: node + linkType: hard + +"rxjs@npm:^7.8.0": + version: 7.8.1 + resolution: "rxjs@npm:7.8.1" + dependencies: + tslib: ^2.1.0 + checksum: de4b53db1063e618ec2eca0f7965d9137cabe98cf6be9272efe6c86b47c17b987383df8574861bcced18ebd590764125a901d5506082be84a8b8e364bf05f119 + languageName: node + linkType: hard + +"safe-array-concat@npm:^1.0.0": + version: 1.0.0 + resolution: "safe-array-concat@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + get-intrinsic: ^1.2.0 + has-symbols: ^1.0.3 + isarray: ^2.0.5 + checksum: f43cb98fe3b566327d0c09284de2b15fb85ae964a89495c1b1a5d50c7c8ed484190f4e5e71aacc167e16231940079b326f2c0807aea633d47cc7322f40a6b57f + languageName: node + linkType: hard + +"safe-buffer@npm:^5.0.1, safe-buffer@npm:^5.1.0, safe-buffer@npm:^5.1.1, safe-buffer@npm:^5.1.2, safe-buffer@npm:^5.2.0, safe-buffer@npm:~5.2.0": + version: 5.2.1 + resolution: "safe-buffer@npm:5.2.1" + checksum: b99c4b41fdd67a6aaf280fcd05e9ffb0813654894223afb78a31f14a19ad220bba8aba1cb14eddce1fcfb037155fe6de4e861784eb434f7d11ed58d1e70dd491 + languageName: node + linkType: hard + +"safe-buffer@npm:~5.1.0, safe-buffer@npm:~5.1.1": + version: 5.1.2 + resolution: "safe-buffer@npm:5.1.2" + checksum: f2f1f7943ca44a594893a852894055cf619c1fbcb611237fc39e461ae751187e7baf4dc391a72125e0ac4fb2d8c5c0b3c71529622e6a58f46b960211e704903c + languageName: node + linkType: hard + +"safe-regex-test@npm:^1.0.0": + version: 1.0.0 + resolution: "safe-regex-test@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + get-intrinsic: ^1.1.3 + is-regex: ^1.1.4 + checksum: bc566d8beb8b43c01b94e67de3f070fd2781685e835959bbbaaec91cc53381145ca91f69bd837ce6ec244817afa0a5e974fc4e40a2957f0aca68ac3add1ddd34 + languageName: node + linkType: hard + +"safer-buffer@npm:>= 2.1.2 < 3, safer-buffer@npm:>= 2.1.2 < 3.0.0, safer-buffer@npm:^2.0.2, safer-buffer@npm:^2.1.0, safer-buffer@npm:~2.1.0": + version: 2.1.2 + resolution: "safer-buffer@npm:2.1.2" + checksum: cab8f25ae6f1434abee8d80023d7e72b598cf1327164ddab31003c51215526801e40b66c5e65d658a0af1e9d6478cadcb4c745f4bd6751f97d8644786c0978b0 + languageName: node + linkType: hard + +"scrypt-js@npm:2.0.4": + version: 2.0.4 + resolution: "scrypt-js@npm:2.0.4" + checksum: 679e8940953ebbef40863bfcc58f1d3058d4b7af0ca9bd8062d8213c30e14db59c6ebfc82a85fbd3b90b6d46b708be4c53b9c4bb200b6f50767dc08a846315a9 + languageName: node + linkType: hard + +"scrypt-js@npm:3.0.1, scrypt-js@npm:^3.0.0": + version: 3.0.1 + resolution: "scrypt-js@npm:3.0.1" + checksum: b7c7d1a68d6ca946f2fbb0778e0c4ec63c65501b54023b2af7d7e9f48fdb6c6580d6f7675cd53bda5944c5ebc057560d5a6365079752546865defb3b79dea454 + languageName: node + linkType: hard + +"secp256k1@npm:^4.0.1": + version: 4.0.3 + resolution: "secp256k1@npm:4.0.3" + dependencies: + elliptic: ^6.5.4 + node-addon-api: ^2.0.0 + node-gyp: latest + node-gyp-build: ^4.2.0 + checksum: 21e219adc0024fbd75021001358780a3cc6ac21273c3fcaef46943af73969729709b03f1df7c012a0baab0830fb9a06ccc6b42f8d50050c665cb98078eab477b + languageName: node + linkType: hard + +"semver@npm:^5.5.0, semver@npm:^5.7.0": + version: 5.7.2 + resolution: "semver@npm:5.7.2" + bin: + semver: bin/semver + checksum: fb4ab5e0dd1c22ce0c937ea390b4a822147a9c53dbd2a9a0132f12fe382902beef4fbf12cf51bb955248d8d15874ce8cd89532569756384f994309825f10b686 + languageName: node + linkType: hard + +"semver@npm:^6.3.0": + version: 6.3.1 + resolution: "semver@npm:6.3.1" + bin: + semver: bin/semver.js + checksum: ae47d06de28836adb9d3e25f22a92943477371292d9b665fb023fae278d345d508ca1958232af086d85e0155aee22e313e100971898bbb8d5d89b8b1d4054ca2 + languageName: node + linkType: hard + +"semver@npm:^7.3.2, semver@npm:^7.3.5, semver@npm:^7.3.8, semver@npm:^7.5.4": + version: 7.5.4 + resolution: "semver@npm:7.5.4" + dependencies: + lru-cache: ^6.0.0 + bin: + semver: bin/semver.js + checksum: 12d8ad952fa353b0995bf180cdac205a4068b759a140e5d3c608317098b3575ac2f1e09182206bf2eb26120e1c0ed8fb92c48c592f6099680de56bb071423ca3 + languageName: node + linkType: hard + +"serialize-javascript@npm:6.0.0": + version: 6.0.0 + resolution: "serialize-javascript@npm:6.0.0" + dependencies: + randombytes: ^2.1.0 + checksum: 56f90b562a1bdc92e55afb3e657c6397c01a902c588c0fe3d4c490efdcc97dcd2a3074ba12df9e94630f33a5ce5b76a74784a7041294628a6f4306e0ec84bf93 + languageName: node + linkType: hard + +"set-blocking@npm:^2.0.0": + version: 2.0.0 + resolution: "set-blocking@npm:2.0.0" + checksum: 6e65a05f7cf7ebdf8b7c75b101e18c0b7e3dff4940d480efed8aad3a36a4005140b660fa1d804cb8bce911cac290441dc728084a30504d3516ac2ff7ad607b02 + languageName: node + linkType: hard + +"setimmediate@npm:1.0.4": + version: 1.0.4 + resolution: "setimmediate@npm:1.0.4" + checksum: 1d3726183ade73fa1c83bd562b05ae34e97802229d5b9292cde7ed03846524f04eb0fdd2131cc159103e3a7afb7c4e958b35bf960e3c4846fa50d94a3278be6f + languageName: node + linkType: hard + +"setimmediate@npm:^1.0.5": + version: 1.0.5 + resolution: "setimmediate@npm:1.0.5" + checksum: c9a6f2c5b51a2dabdc0247db9c46460152ffc62ee139f3157440bd48e7c59425093f42719ac1d7931f054f153e2d26cf37dfeb8da17a794a58198a2705e527fd + languageName: node + linkType: hard + +"setprototypeof@npm:1.2.0": + version: 1.2.0 + resolution: "setprototypeof@npm:1.2.0" + checksum: be18cbbf70e7d8097c97f713a2e76edf84e87299b40d085c6bf8b65314e994cc15e2e317727342fa6996e38e1f52c59720b53fe621e2eb593a6847bf0356db89 + languageName: node + linkType: hard + +"sha.js@npm:^2.4.0, sha.js@npm:^2.4.8": + version: 2.4.11 + resolution: "sha.js@npm:2.4.11" + dependencies: + inherits: ^2.0.1 + safe-buffer: ^5.0.1 + bin: + sha.js: ./bin.js + checksum: ebd3f59d4b799000699097dadb831c8e3da3eb579144fd7eb7a19484cbcbb7aca3c68ba2bb362242eb09e33217de3b4ea56e4678184c334323eca24a58e3ad07 + languageName: node + linkType: hard + +"sha1@npm:^1.1.1": + version: 1.1.1 + resolution: "sha1@npm:1.1.1" + dependencies: + charenc: ">= 0.0.1" + crypt: ">= 0.0.1" + checksum: da9f47e949988e2f595ef19733fd1dc736866ef6de4e421a55c13b444c03ae532e528b7350ae6ea55d9fb053be61d4648ec2cd5250d46cfdbdf4f6b4e763713d + languageName: node + linkType: hard + +"shebang-command@npm:^2.0.0": + version: 2.0.0 + resolution: "shebang-command@npm:2.0.0" + dependencies: + shebang-regex: ^3.0.0 + checksum: 6b52fe87271c12968f6a054e60f6bde5f0f3d2db483a1e5c3e12d657c488a15474121a1d55cd958f6df026a54374ec38a4a963988c213b7570e1d51575cea7fa + languageName: node + linkType: hard + +"shebang-regex@npm:^3.0.0": + version: 3.0.0 + resolution: "shebang-regex@npm:3.0.0" + checksum: 1a2bcae50de99034fcd92ad4212d8e01eedf52c7ec7830eedcf886622804fe36884278f2be8be0ea5fde3fd1c23911643a4e0f726c8685b61871c8908af01222 + languageName: node + linkType: hard + +"side-channel@npm:^1.0.4": + version: 1.0.4 + resolution: "side-channel@npm:1.0.4" + dependencies: + call-bind: ^1.0.0 + get-intrinsic: ^1.0.2 + object-inspect: ^1.9.0 + checksum: 351e41b947079c10bd0858364f32bb3a7379514c399edb64ab3dce683933483fc63fb5e4efe0a15a2e8a7e3c436b6a91736ddb8d8c6591b0460a24bb4a1ee245 + languageName: node + linkType: hard + +"signal-exit@npm:^3.0.2, signal-exit@npm:^3.0.7": + version: 3.0.7 + resolution: "signal-exit@npm:3.0.7" + checksum: a2f098f247adc367dffc27845853e9959b9e88b01cb301658cfe4194352d8d2bb32e18467c786a7fe15f1d44b233ea35633d076d5e737870b7139949d1ab6318 + languageName: node + linkType: hard + +"signal-exit@npm:^4.0.1": + version: 4.1.0 + resolution: "signal-exit@npm:4.1.0" + checksum: 64c757b498cb8629ffa5f75485340594d2f8189e9b08700e69199069c8e3070fb3e255f7ab873c05dc0b3cec412aea7402e10a5990cb6a050bd33ba062a6c549 + languageName: node + linkType: hard + +"simple-wcswidth@npm:^1.0.1": + version: 1.0.1 + resolution: "simple-wcswidth@npm:1.0.1" + checksum: dc5bf4cb131d9c386825d1355add2b1ecc408b37dc2c2334edd7a1a4c9f527e6b594dedcdbf6d949bce2740c3a332e39af1183072a2d068e40d9e9146067a37f + languageName: node + linkType: hard + +"slash@npm:^3.0.0": + version: 3.0.0 + resolution: "slash@npm:3.0.0" + checksum: 94a93fff615f25a999ad4b83c9d5e257a7280c90a32a7cb8b4a87996e4babf322e469c42b7f649fd5796edd8687652f3fb452a86dc97a816f01113183393f11c + languageName: node + linkType: hard + +"slice-ansi@npm:^3.0.0": + version: 3.0.0 + resolution: "slice-ansi@npm:3.0.0" + dependencies: + ansi-styles: ^4.0.0 + astral-regex: ^2.0.0 + is-fullwidth-code-point: ^3.0.0 + checksum: 5ec6d022d12e016347e9e3e98a7eb2a592213a43a65f1b61b74d2c78288da0aded781f665807a9f3876b9daa9ad94f64f77d7633a0458876c3a4fdc4eb223f24 + languageName: node + linkType: hard + +"slice-ansi@npm:^4.0.0": + version: 4.0.0 + resolution: "slice-ansi@npm:4.0.0" + dependencies: + ansi-styles: ^4.0.0 + astral-regex: ^2.0.0 + is-fullwidth-code-point: ^3.0.0 + checksum: 4a82d7f085b0e1b070e004941ada3c40d3818563ac44766cca4ceadd2080427d337554f9f99a13aaeb3b4a94d9964d9466c807b3d7b7541d1ec37ee32d308756 + languageName: node + linkType: hard + +"slice-ansi@npm:^5.0.0": + version: 5.0.0 + resolution: "slice-ansi@npm:5.0.0" + dependencies: + ansi-styles: ^6.0.0 + is-fullwidth-code-point: ^4.0.0 + checksum: 7e600a2a55e333a21ef5214b987c8358fe28bfb03c2867ff2cbf919d62143d1812ac27b4297a077fdaf27a03da3678e49551c93e35f9498a3d90221908a1180e + languageName: node + linkType: hard + +"smart-buffer@npm:^4.2.0": + version: 4.2.0 + resolution: "smart-buffer@npm:4.2.0" + checksum: b5167a7142c1da704c0e3af85c402002b597081dd9575031a90b4f229ca5678e9a36e8a374f1814c8156a725d17008ae3bde63b92f9cfd132526379e580bec8b + languageName: node + linkType: hard + +"socks-proxy-agent@npm:^7.0.0": + version: 7.0.0 + resolution: "socks-proxy-agent@npm:7.0.0" + dependencies: + agent-base: ^6.0.2 + debug: ^4.3.3 + socks: ^2.6.2 + checksum: 720554370154cbc979e2e9ce6a6ec6ced205d02757d8f5d93fe95adae454fc187a5cbfc6b022afab850a5ce9b4c7d73e0f98e381879cf45f66317a4895953846 + languageName: node + linkType: hard + +"socks@npm:^2.6.2": + version: 2.7.1 + resolution: "socks@npm:2.7.1" + dependencies: + ip: ^2.0.0 + smart-buffer: ^4.2.0 + checksum: 259d9e3e8e1c9809a7f5c32238c3d4d2a36b39b83851d0f573bfde5f21c4b1288417ce1af06af1452569cd1eb0841169afd4998f0e04ba04656f6b7f0e46d748 + languageName: node + linkType: hard "solc-0.8@npm:solc@^0.8.0": - version "0.8.21" - resolved "https://registry.yarnpkg.com/solc/-/solc-0.8.21.tgz#c3cd505c360ea2fa0eaa5ab574ef96bffb1a2766" - integrity sha512-N55ogy2dkTRwiONbj4e6wMZqUNaLZkiRcjGyeafjLYzo/tf/IvhHY5P5wpe+H3Fubh9idu071i8eOGO31s1ylg== - dependencies: - command-exists "^1.2.8" - commander "^8.1.0" - follow-redirects "^1.12.1" - js-sha3 "0.8.0" - memorystream "^0.3.1" - semver "^5.5.0" - tmp "0.0.33" - -solc@0.7.3: - version "0.7.3" - resolved "https://registry.yarnpkg.com/solc/-/solc-0.7.3.tgz#04646961bd867a744f63d2b4e3c0701ffdc7d78a" - integrity sha512-GAsWNAjGzIDg7VxzP6mPjdurby3IkGCjQcM8GFYZT6RyaoUZKmMU6Y7YwG+tFGhv7dwZ8rmR4iwFDrrD99JwqA== - dependencies: - command-exists "^1.2.8" - commander "3.0.2" - follow-redirects "^1.12.1" - fs-extra "^0.30.0" - js-sha3 "0.8.0" - memorystream "^0.3.1" - require-from-string "^2.0.0" - semver "^5.5.0" - tmp "0.0.33" - -solc@^0.6.7: - version "0.6.12" - resolved "https://registry.yarnpkg.com/solc/-/solc-0.6.12.tgz#48ac854e0c729361b22a7483645077f58cba080e" - integrity sha512-Lm0Ql2G9Qc7yPP2Ba+WNmzw2jwsrd3u4PobHYlSOxaut3TtUbj9+5ZrT6f4DUpNPEoBaFUOEg9Op9C0mk7ge9g== - dependencies: - command-exists "^1.2.8" - commander "3.0.2" - fs-extra "^0.30.0" - js-sha3 "0.8.0" - memorystream "^0.3.1" - require-from-string "^2.0.0" - semver "^5.5.0" - tmp "0.0.33" - -solhint@^3.3.6: - version "3.4.1" - resolved "https://registry.yarnpkg.com/solhint/-/solhint-3.4.1.tgz#8ea15b21c13d1be0b53fd46d605a24d0b36a0c46" - integrity sha512-pzZn2RlZhws1XwvLPVSsxfHrwsteFf5eySOhpAytzXwKQYbTCJV6z8EevYDiSVKMpWrvbKpEtJ055CuEmzp4Xg== - dependencies: - "@solidity-parser/parser" "^0.16.0" - ajv "^6.12.6" - antlr4 "^4.11.0" - ast-parents "^0.0.1" - chalk "^4.1.2" - commander "^10.0.0" - cosmiconfig "^8.0.0" - fast-diff "^1.2.0" - glob "^8.0.3" - ignore "^5.2.4" - js-yaml "^4.1.0" - lodash "^4.17.21" - pluralize "^8.0.0" - semver "^6.3.0" - strip-ansi "^6.0.1" - table "^6.8.1" - text-table "^0.2.0" - optionalDependencies: - prettier "^2.8.3" - -solidity-comments-extractor@^0.0.7: - version "0.0.7" - resolved "https://registry.yarnpkg.com/solidity-comments-extractor/-/solidity-comments-extractor-0.0.7.tgz#99d8f1361438f84019795d928b931f4e5c39ca19" - integrity sha512-wciNMLg/Irp8OKGrh3S2tfvZiZ0NEyILfcRCXCD4mp7SgK/i9gzLfhY2hY7VMCQJ3kH9UB9BzNdibIVMchzyYw== - -solidity-docgen@0.5.16: - version "0.5.16" - resolved "https://registry.yarnpkg.com/solidity-docgen/-/solidity-docgen-0.5.16.tgz#c12a5cac7ca656ff01b10dd832891983bb071f50" - integrity sha512-rFVpqSNnDGKvL68mPf4J9mEQIl+Ixy6bIz/YE6AgjBCPtrlm4KjWQhcBMQWc/LarSCenOpzhbG1tHqP9gf9kcg== - dependencies: - "@oclif/command" "^1.8.0" - "@oclif/config" "^1.17.0" - "@oclif/errors" "^1.3.3" - "@oclif/plugin-help" "^3.2.0" - globby "^11.0.0" - handlebars "^4.7.6" - json5 "^2.1.3" - lodash "^4.17.15" - micromatch "^4.0.2" - minimatch "^3.0.4" - semver "^7.3.2" - solc "^0.6.7" - -source-map-support@^0.5.13: - version "0.5.21" - resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" - integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== - dependencies: - buffer-from "^1.0.0" - source-map "^0.6.0" - -source-map@^0.6.0, source-map@^0.6.1: - version "0.6.1" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" - integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== - -sprintf-js@~1.0.2: - version "1.0.3" - resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" - integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== - -sshpk@^1.7.0: - version "1.17.0" - resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.17.0.tgz#578082d92d4fe612b13007496e543fa0fbcbe4c5" - integrity sha512-/9HIEs1ZXGhSPE8X6Ccm7Nam1z8KcoCqPdI7ecm1N33EzAetWahvQWVqLZtaZQ+IDKX4IyA2o0gBzqIMkAagHQ== - dependencies: - asn1 "~0.2.3" - assert-plus "^1.0.0" - bcrypt-pbkdf "^1.0.0" - dashdash "^1.12.0" - ecc-jsbn "~0.1.1" - getpass "^0.1.1" - jsbn "~0.1.0" - safer-buffer "^2.0.2" - tweetnacl "~0.14.0" - -stacktrace-parser@^0.1.10: - version "0.1.10" - resolved "https://registry.yarnpkg.com/stacktrace-parser/-/stacktrace-parser-0.1.10.tgz#29fb0cae4e0d0b85155879402857a1639eb6051a" - integrity sha512-KJP1OCML99+8fhOHxwwzyWrlUuVX5GQ0ZpJTd1DFXhdkrvg1szxfHhawXUZ3g9TkXORQd4/WG68jMlQZ2p8wlg== - dependencies: - type-fest "^0.7.1" - -statuses@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" - integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== - -stealthy-require@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/stealthy-require/-/stealthy-require-1.1.1.tgz#35b09875b4ff49f26a777e509b3090a3226bf24b" - integrity sha512-ZnWpYnYugiOVEY5GkcuJK1io5V8QmNYChG62gSit9pQVGErXtrKuPC55ITaVSukmMta5qpMU7vqLt2Lnni4f/g== - -streamsearch@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-1.1.0.tgz#404dd1e2247ca94af554e841a8ef0eaa238da764" - integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== - -string-argv@^0.3.1: - version "0.3.2" - resolved "https://registry.yarnpkg.com/string-argv/-/string-argv-0.3.2.tgz#2b6d0ef24b656274d957d54e0a4bbf6153dc02b6" - integrity sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q== - -string-format@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/string-format/-/string-format-2.0.0.tgz#f2df2e7097440d3b65de31b6d40d54c96eaffb9b" - integrity sha512-bbEs3scLeYNXLecRRuk6uJxdXUSj6le/8rNPHChIJTn2V79aXVTR1EH2OH5zLKKoz0V02fOUKZZcw01pLUShZA== - -"string-width@^1.0.2 || 2", string-width@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" - integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== - dependencies: - is-fullwidth-code-point "^2.0.0" - strip-ansi "^4.0.0" - -string-width@^3.0.0, string-width@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" - integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== - dependencies: - emoji-regex "^7.0.1" - is-fullwidth-code-point "^2.0.0" - strip-ansi "^5.1.0" - -string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: - version "4.2.3" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== - dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" - -string-width@^5.0.0: - version "5.1.2" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-5.1.2.tgz#14f8daec6d81e7221d2a357e668cab73bdbca794" - integrity sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA== - dependencies: - eastasianwidth "^0.2.0" - emoji-regex "^9.2.2" - strip-ansi "^7.0.1" - -string.prototype.trim@^1.2.7: - version "1.2.7" - resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.2.7.tgz#a68352740859f6893f14ce3ef1bb3037f7a90533" - integrity sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" - -string.prototype.trimend@^1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz#c4a27fa026d979d79c04f17397f250a462944533" - integrity sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" - -string.prototype.trimstart@^1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz#e90ab66aa8e4007d92ef591bbf3cd422c56bdcf4" - integrity sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" - -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== - dependencies: - safe-buffer "~5.2.0" - -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== - dependencies: - safe-buffer "~5.1.0" - -strip-ansi@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" - integrity sha512-4XaJ2zQdCzROZDivEVIDPkcQn8LMFSa8kj8Gxb/Lnwzv9A8VctNZ+lfivC/sV3ivW8ElJTERXZoPBRrZKkNKow== - dependencies: - ansi-regex "^3.0.0" - -strip-ansi@^5.0.0, strip-ansi@^5.1.0, strip-ansi@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" - integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== - dependencies: - ansi-regex "^4.1.0" - -strip-ansi@^6.0.0, strip-ansi@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== - dependencies: - ansi-regex "^5.0.1" - -strip-ansi@^7.0.1: - version "7.1.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-7.1.0.tgz#d5b6568ca689d8561370b0707685d22434faff45" - integrity sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ== - dependencies: - ansi-regex "^6.0.1" - -strip-final-newline@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-3.0.0.tgz#52894c313fbff318835280aed60ff71ebf12b8fd" - integrity sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw== - -strip-hex-prefix@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz#0c5f155fef1151373377de9dbb588da05500e36f" - integrity sha512-q8d4ue7JGEiVcypji1bALTos+0pWtyGlivAWyPuTkHzuTCJqrK9sWxYQZUq6Nq3cuyv3bm734IhHvHtGGURU6A== - dependencies: - is-hex-prefixed "1.0.0" - -strip-json-comments@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" - integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== - -strip-json-comments@3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" - integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== - -supports-color@6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-6.0.0.tgz#76cfe742cf1f41bb9b1c29ad03068c05b4c0e40a" - integrity sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg== - dependencies: - has-flag "^3.0.0" - -supports-color@8.1.1: - version "8.1.1" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" - integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== - dependencies: - has-flag "^4.0.0" - -supports-color@^5.3.0: - version "5.5.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" - integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== - dependencies: - has-flag "^3.0.0" - -supports-color@^7.1.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" - integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== - dependencies: - has-flag "^4.0.0" - -sync-request@^6.0.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/sync-request/-/sync-request-6.1.0.tgz#e96217565b5e50bbffe179868ba75532fb597e68" - integrity sha512-8fjNkrNlNCrVc/av+Jn+xxqfCjYaBoHqCsDz6mt030UMxJGr+GSfCV1dQt2gRtlL63+VPidwDVLr7V2OcTSdRw== - dependencies: - http-response-object "^3.0.1" - sync-rpc "^1.2.1" - then-request "^6.0.0" - -sync-rpc@^1.2.1: - version "1.3.6" - resolved "https://registry.yarnpkg.com/sync-rpc/-/sync-rpc-1.3.6.tgz#b2e8b2550a12ccbc71df8644810529deb68665a7" - integrity sha512-J8jTXuZzRlvU7HemDgHi3pGnh/rkoqR/OZSjhTyyZrEkkYQbk7Z33AXp37mkPfPpfdOuj7Ex3H/TJM1z48uPQw== - dependencies: - get-port "^3.1.0" - -table-layout@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/table-layout/-/table-layout-1.0.2.tgz#c4038a1853b0136d63365a734b6931cf4fad4a04" - integrity sha512-qd/R7n5rQTRFi+Zf2sk5XVVd9UQl6ZkduPFC3S7WEGJAmetDTjY3qPN50eSKzwuzEyQKy5TN2TiZdkIjos2L6A== - dependencies: - array-back "^4.0.1" - deep-extend "~0.6.0" - typical "^5.2.0" - wordwrapjs "^4.0.0" - -table@^6.8.1: - version "6.8.1" - resolved "https://registry.yarnpkg.com/table/-/table-6.8.1.tgz#ea2b71359fe03b017a5fbc296204471158080bdf" - integrity sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA== - dependencies: - ajv "^8.0.1" - lodash.truncate "^4.4.2" - slice-ansi "^4.0.0" - string-width "^4.2.3" - strip-ansi "^6.0.1" - -text-table@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" - integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== - -then-request@^6.0.0: - version "6.0.2" - resolved "https://registry.yarnpkg.com/then-request/-/then-request-6.0.2.tgz#ec18dd8b5ca43aaee5cb92f7e4c1630e950d4f0c" - integrity sha512-3ZBiG7JvP3wbDzA9iNY5zJQcHL4jn/0BWtXIkagfz7QgOL/LqjCEOBQuJNZfu0XYnv5JhKh+cDxCPM4ILrqruA== - dependencies: - "@types/concat-stream" "^1.6.0" - "@types/form-data" "0.0.33" - "@types/node" "^8.0.0" - "@types/qs" "^6.2.31" - caseless "~0.12.0" - concat-stream "^1.6.0" - form-data "^2.2.0" - http-basic "^8.1.1" - http-response-object "^3.0.1" - promise "^8.0.0" - qs "^6.4.0" - -through@^2.3.8: - version "2.3.8" - resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" - integrity sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg== - -tmp@0.0.33: - version "0.0.33" - resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz#6d34335889768d21b2bcda0aa277ced3b1bfadf9" - integrity sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw== - dependencies: - os-tmpdir "~1.0.2" - -to-regex-range@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" - integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== - dependencies: - is-number "^7.0.0" - -toidentifier@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" - integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== - -tough-cookie@^2.3.3, tough-cookie@~2.5.0: - version "2.5.0" - resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" - integrity sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g== - dependencies: - psl "^1.1.28" - punycode "^2.1.1" - -ts-command-line-args@^2.2.0: - version "2.5.1" - resolved "https://registry.yarnpkg.com/ts-command-line-args/-/ts-command-line-args-2.5.1.tgz#e64456b580d1d4f6d948824c274cf6fa5f45f7f0" - integrity sha512-H69ZwTw3rFHb5WYpQya40YAX2/w7Ut75uUECbgBIsLmM+BNuYnxsltfyyLMxy6sEeKxgijLTnQtLd0nKd6+IYw== - dependencies: - chalk "^4.1.0" - command-line-args "^5.1.1" - command-line-usage "^6.1.0" - string-format "^2.0.0" - -ts-essentials@^7.0.1: - version "7.0.3" - resolved "https://registry.yarnpkg.com/ts-essentials/-/ts-essentials-7.0.3.tgz#686fd155a02133eedcc5362dc8b5056cde3e5a38" - integrity sha512-8+gr5+lqO3G84KdiTSMRLtuyJ+nTBVRKuCrK4lidMPdVeEp0uqC875uE5NMcaA7YYMN7XsNiFQuMvasF8HT/xQ== - -ts-node@^10.4.0: - version "10.9.1" - resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.1.tgz#e73de9102958af9e1f0b168a6ff320e25adcff4b" - integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== - dependencies: - "@cspotcode/source-map-support" "^0.8.0" - "@tsconfig/node10" "^1.0.7" - "@tsconfig/node12" "^1.0.7" - "@tsconfig/node14" "^1.0.0" - "@tsconfig/node16" "^1.0.2" - acorn "^8.4.1" - acorn-walk "^8.1.1" - arg "^4.1.0" - create-require "^1.1.0" - diff "^4.0.1" - make-error "^1.1.1" - v8-compile-cache-lib "^3.0.1" - yn "3.1.1" - -tslib@^1.9.3: - version "1.14.1" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" - integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== - -tslib@^2.0.0, tslib@^2.1.0, tslib@^2.5.0, tslib@^2.6.1: - version "2.6.1" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.1.tgz#fd8c9a0ff42590b25703c0acb3de3d3f4ede0410" - integrity sha512-t0hLfiEKfMUoqhG+U1oid7Pva4bbDPHYfJNiB7BiIjRkj1pyC++4N3huJfqY6aRH6VTB0rvtzQwjM4K6qpfOig== - -tsort@0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/tsort/-/tsort-0.0.1.tgz#e2280f5e817f8bf4275657fd0f9aebd44f5a2786" - integrity sha512-Tyrf5mxF8Ofs1tNoxA13lFeZ2Zrbd6cKbuH3V+MQ5sb6DtBj5FjrXVsRWT8YvNAQTqNoz66dz1WsbigI22aEnw== - -tunnel-agent@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" - integrity sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w== - dependencies: - safe-buffer "^5.0.1" - -tweetnacl-util@^0.15.1: - version "0.15.1" - resolved "https://registry.yarnpkg.com/tweetnacl-util/-/tweetnacl-util-0.15.1.tgz#b80fcdb5c97bcc508be18c44a4be50f022eea00b" - integrity sha512-RKJBIj8lySrShN4w6i/BonWp2Z/uxwC3h4y7xsRrpP59ZboCd0GpEVsOnMDYLMmKBpYhb5TgHzZXy7wTfYFBRw== - -tweetnacl@^0.14.3, tweetnacl@~0.14.0: - version "0.14.5" - resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" - integrity sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA== - -tweetnacl@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-1.0.3.tgz#ac0af71680458d8a6378d0d0d050ab1407d35596" - integrity sha512-6rt+RN7aOi1nGMyC4Xa5DdYiukl2UWCbcJft7YhxReBGQD7OAM8Pbxw6YMo4r2diNEA8FEmu32YOn9rhaiE5yw== - -type-detect@^4.0.0, type-detect@^4.0.5: - version "4.0.8" - resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" - integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== - -type-fest@^0.21.3: - version "0.21.3" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" - integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== - -type-fest@^0.7.1: - version "0.7.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.7.1.tgz#8dda65feaf03ed78f0a3f9678f1869147f7c5c48" - integrity sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg== - -typechain@^6.0.5: - version "6.1.0" - resolved "https://registry.yarnpkg.com/typechain/-/typechain-6.1.0.tgz#462a35f555accf870689d1ba5698749108d0ce81" - integrity sha512-GGfkK0p3fUgz8kYxjSS4nKcWXE0Lo+teHTetghousIK5njbNoYNDlwn91QIyD181L3fVqlTvBE0a/q3AZmjNfw== - dependencies: - "@types/prettier" "^2.1.1" - debug "^4.1.1" - fs-extra "^7.0.0" - glob "^7.1.6" - js-sha3 "^0.8.0" - lodash "^4.17.15" - mkdirp "^1.0.4" - prettier "^2.1.2" - ts-command-line-args "^2.2.0" - ts-essentials "^7.0.1" - -typed-array-buffer@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz#18de3e7ed7974b0a729d3feecb94338d1472cd60" - integrity sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw== - dependencies: - call-bind "^1.0.2" - get-intrinsic "^1.2.1" - is-typed-array "^1.1.10" - -typed-array-byte-length@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz#d787a24a995711611fb2b87a4052799517b230d0" - integrity sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA== - dependencies: - call-bind "^1.0.2" - for-each "^0.3.3" - has-proto "^1.0.1" - is-typed-array "^1.1.10" - -typed-array-byte-offset@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz#cbbe89b51fdef9cd6aaf07ad4707340abbc4ea0b" - integrity sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg== - dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - for-each "^0.3.3" - has-proto "^1.0.1" - is-typed-array "^1.1.10" - -typed-array-length@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/typed-array-length/-/typed-array-length-1.0.4.tgz#89d83785e5c4098bec72e08b319651f0eac9c1bb" - integrity sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng== - dependencies: - call-bind "^1.0.2" - for-each "^0.3.3" - is-typed-array "^1.1.9" - -typedarray@^0.0.6: - version "0.0.6" - resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" - integrity sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA== - -typescript@^4.5.4: - version "4.9.5" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" - integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== - -typical@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/typical/-/typical-4.0.0.tgz#cbeaff3b9d7ae1e2bbfaf5a4e6f11eccfde94fc4" - integrity sha512-VAH4IvQ7BDFYglMd7BPRDfLgxZZX4O4TFcRDA6EN5X7erNJJq+McIEp8np9aVtxrCJ6qx4GTYVfOWNjcqwZgRw== - -typical@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/typical/-/typical-5.2.0.tgz#4daaac4f2b5315460804f0acf6cb69c52bb93066" - integrity sha512-dvdQgNDNJo+8B2uBQoqdb11eUCE1JQXhvjC/CZtgvZseVd5TYMXnq0+vuUemXbd/Se29cTaUuPX3YIc2xgbvIg== - -uglify-js@^3.1.4: - version "3.17.4" - resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.17.4.tgz#61678cf5fa3f5b7eb789bb345df29afb8257c22c" - integrity sha512-T9q82TJI9e/C1TAxYvfb16xO120tMVFZrGA3f9/P4424DNu6ypK103y0GPFVa17yotwSyZW5iYXgjYHkGrJW/g== - -unbox-primitive@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" - integrity sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw== - dependencies: - call-bind "^1.0.2" - has-bigints "^1.0.2" - has-symbols "^1.0.3" - which-boxed-primitive "^1.0.2" - -undici@^5.14.0: - version "5.22.1" - resolved "https://registry.yarnpkg.com/undici/-/undici-5.22.1.tgz#877d512effef2ac8be65e695f3586922e1a57d7b" - integrity sha512-Ji2IJhFXZY0x/0tVBXeQwgPlLWw13GVzpsWPQ3rV50IFMMof2I55PZZxtm4P6iNq+L5znYN9nSTAq0ZyE6lSJw== - dependencies: - busboy "^1.6.0" - -universalify@^0.1.0: - version "0.1.2" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" - integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== - -universalify@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" - integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== - -unpipe@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" - integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== - -uri-js@^4.2.2: - version "4.4.1" - resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" - integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== - dependencies: - punycode "^2.1.0" - -util-deprecate@^1.0.1, util-deprecate@~1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== - -uuid@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-2.0.1.tgz#c2a30dedb3e535d72ccf82e343941a50ba8533ac" - integrity sha512-nWg9+Oa3qD2CQzHIP4qKUqwNfzKn8P0LtFhotaCTFchsV7ZfDhAybeip/HZVeMIpZi9JgY1E3nUlwaCmZT1sEg== - -uuid@^3.3.2: - version "3.4.0" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" - integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A== - -uuid@^8.3.2: - version "8.3.2" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" - integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== - -v8-compile-cache-lib@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz#6336e8d71965cb3d35a1bbb7868445a7c05264bf" - integrity sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg== - -verror@1.10.0: - version "1.10.0" - resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" - integrity sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw== - dependencies: - assert-plus "^1.0.0" - core-util-is "1.0.2" - extsprintf "^1.2.0" - -which-boxed-primitive@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6" - integrity sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg== - dependencies: - is-bigint "^1.0.1" - is-boolean-object "^1.1.0" - is-number-object "^1.0.4" - is-string "^1.0.5" - is-symbol "^1.0.3" - -which-module@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.1.tgz#776b1fe35d90aebe99e8ac15eb24093389a4a409" - integrity sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ== - -which-typed-array@^1.1.10, which-typed-array@^1.1.11: - version "1.1.11" - resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.11.tgz#99d691f23c72aab6768680805a271b69761ed61a" - integrity sha512-qe9UWWpkeG5yzZ0tNYxDmd7vo58HDBc39mZ0xWWpolAGADdFOzkfamWLDxkOWcvHQKVmdTyQdLD4NOfjLWTKew== - dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - for-each "^0.3.3" - gopd "^1.0.1" - has-tostringtag "^1.0.0" - -which@1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" - integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== - dependencies: - isexe "^2.0.0" - -which@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" - integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== - dependencies: - isexe "^2.0.0" - -wide-align@1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.3.tgz#ae074e6bdc0c14a431e804e624549c633b000457" - integrity sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA== - dependencies: - string-width "^1.0.2 || 2" - -widest-line@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" - integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== - dependencies: - string-width "^4.0.0" - -wordwrap@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" - integrity sha512-gvVzJFlPycKc5dZN4yPkP8w7Dc37BtP1yczEneOb4uq34pXZcvrtRTmWV8W+Ume+XCxKgbjM+nevkyFPMybd4Q== - -wordwrapjs@^4.0.0: - version "4.0.1" - resolved "https://registry.yarnpkg.com/wordwrapjs/-/wordwrapjs-4.0.1.tgz#d9790bccfb110a0fc7836b5ebce0937b37a8b98f" - integrity sha512-kKlNACbvHrkpIw6oPeYDSmdCTu2hdMHoyXLTcUKala++lx5Y+wjJ/e474Jqv5abnVmwxw08DiTuHmw69lJGksA== - dependencies: - reduce-flatten "^2.0.0" - typical "^5.2.0" - -workerpool@6.2.1: - version "6.2.1" - resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.1.tgz#46fc150c17d826b86a008e5a4508656777e9c343" - integrity sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw== - -wrap-ansi@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-5.1.0.tgz#1fd1f67235d5b6d0fee781056001bfb694c03b09" - integrity sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q== - dependencies: - ansi-styles "^3.2.0" - string-width "^3.0.0" - strip-ansi "^5.0.0" - -wrap-ansi@^6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz#e9393ba07102e6c91a3b221478f0257cd2856e53" - integrity sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== - dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" - -wrappy@1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" - integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== - -ws@7.4.6: - version "7.4.6" - resolved "https://registry.yarnpkg.com/ws/-/ws-7.4.6.tgz#5654ca8ecdeee47c33a9a4bf6d28e2be2980377c" - integrity sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A== - -ws@^7.4.6: - version "7.5.9" - resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" - integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== - -xmlhttprequest@1.8.0: - version "1.8.0" - resolved "https://registry.yarnpkg.com/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz#67fe075c5c24fef39f9d65f5f7b7fe75171968fc" - integrity sha512-58Im/U0mlVBLM38NdZjHyhuMtCqa61469k2YP/AaPbvCoV9aQGUpbJBj1QRm2ytRiVQBD/fsw7L2bJGDVQswBA== - -y18n@^4.0.0: - version "4.0.3" - resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf" - integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ== - -y18n@^5.0.5: - version "5.0.8" - resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" - integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== - -yallist@^3.0.2: - version "3.1.1" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" - integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== - -yallist@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" - integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== - -yaml@^2.2.2: - version "2.3.1" - resolved "https://registry.yarnpkg.com/yaml/-/yaml-2.3.1.tgz#02fe0975d23cd441242aa7204e09fc28ac2ac33b" - integrity sha512-2eHWfjaoXgTBC2jNM1LRef62VQa0umtvRiDSk6HSzW7RvS5YtkabJrwYLLEKWBc8a5U2PTSCs+dJjUTJdlHsWQ== - -yargs-parser@13.1.2, yargs-parser@^13.1.2: - version "13.1.2" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-13.1.2.tgz#130f09702ebaeef2650d54ce6e3e5706f7a4fb38" - integrity sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg== - dependencies: - camelcase "^5.0.0" - decamelize "^1.2.0" - -yargs-parser@20.2.4: - version "20.2.4" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.4.tgz#b42890f14566796f85ae8e3a25290d205f154a54" - integrity sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA== - -yargs-parser@^20.2.2: - version "20.2.9" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee" - integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== - -yargs-unparser@1.6.0: - version "1.6.0" - resolved "https://registry.yarnpkg.com/yargs-unparser/-/yargs-unparser-1.6.0.tgz#ef25c2c769ff6bd09e4b0f9d7c605fb27846ea9f" - integrity sha512-W9tKgmSn0DpSatfri0nx52Joq5hVXgeLiqR/5G0sZNDoLZFOr/xjBUDcShCOGNsBnEMNo1KAMBkTej1Hm62HTw== - dependencies: - flat "^4.1.0" - lodash "^4.17.15" - yargs "^13.3.0" - -yargs-unparser@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/yargs-unparser/-/yargs-unparser-2.0.0.tgz#f131f9226911ae5d9ad38c432fe809366c2325eb" - integrity sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA== - dependencies: - camelcase "^6.0.0" - decamelize "^4.0.0" - flat "^5.0.2" - is-plain-obj "^2.1.0" - -yargs@13.3.2, yargs@^13.3.0: - version "13.3.2" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-13.3.2.tgz#ad7ffefec1aa59565ac915f82dccb38a9c31a2dd" - integrity sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw== - dependencies: - cliui "^5.0.0" - find-up "^3.0.0" - get-caller-file "^2.0.1" - require-directory "^2.1.1" - require-main-filename "^2.0.0" - set-blocking "^2.0.0" - string-width "^3.0.0" - which-module "^2.0.0" - y18n "^4.0.0" - yargs-parser "^13.1.2" - -yargs@16.2.0: - version "16.2.0" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66" - integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== - dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.0" - y18n "^5.0.5" - yargs-parser "^20.2.2" - -yn@3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" - integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== - -yocto-queue@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" - integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== - -zksync-web3@^0.14.3: - version "0.14.3" - resolved "https://registry.yarnpkg.com/zksync-web3/-/zksync-web3-0.14.3.tgz#64ac2a16d597464c3fc4ae07447a8007631c57c9" - integrity sha512-hT72th4AnqyLW1d5Jlv8N2B/qhEnl2NePK2A3org7tAa24niem/UAaHMkEvmWI3SF9waYUPtqAtjpf+yvQ9zvQ== + version: 0.8.21 + resolution: "solc@npm:0.8.21" + dependencies: + command-exists: ^1.2.8 + commander: ^8.1.0 + follow-redirects: ^1.12.1 + js-sha3: 0.8.0 + memorystream: ^0.3.1 + semver: ^5.5.0 + tmp: 0.0.33 + bin: + solcjs: solc.js + checksum: 0145d0e1f4ba7b1ec574a2ad7c4782357c4a27949c3bcc7bb4411a7b325a3ad186c18f93b1802a438ea9a527711dd56d2d7190bc8dd431dc194fb6098ab6ed01 + languageName: node + linkType: hard + +"solc@npm:0.7.3": + version: 0.7.3 + resolution: "solc@npm:0.7.3" + dependencies: + command-exists: ^1.2.8 + commander: 3.0.2 + follow-redirects: ^1.12.1 + fs-extra: ^0.30.0 + js-sha3: 0.8.0 + memorystream: ^0.3.1 + require-from-string: ^2.0.0 + semver: ^5.5.0 + tmp: 0.0.33 + bin: + solcjs: solcjs + checksum: 2d8eb16c6d8f648213c94dc8d977cffe5099cba7d41c82d92d769ef71ae8320a985065ce3d6c306440a85f8e8d2b27fb30bdd3ac38f69e5c1fa0ab8a3fb2f217 + languageName: node + linkType: hard + +"solc@npm:^0.6.7": + version: 0.6.12 + resolution: "solc@npm:0.6.12" + dependencies: + command-exists: ^1.2.8 + commander: 3.0.2 + fs-extra: ^0.30.0 + js-sha3: 0.8.0 + memorystream: ^0.3.1 + require-from-string: ^2.0.0 + semver: ^5.5.0 + tmp: 0.0.33 + bin: + solcjs: solcjs + checksum: 1e2bf927f3ef4f3b195b7619ff64f715916d94dc59091a8a710e47bdd4b18e0bd92b55ea43a04ce7fabce9ad7a3e4e73ccaf127a50ebbf963a9de9046576e3b6 + languageName: node + linkType: hard + +"solhint@npm:^3.3.6": + version: 3.4.1 + resolution: "solhint@npm:3.4.1" + dependencies: + "@solidity-parser/parser": ^0.16.0 + ajv: ^6.12.6 + antlr4: ^4.11.0 + ast-parents: ^0.0.1 + chalk: ^4.1.2 + commander: ^10.0.0 + cosmiconfig: ^8.0.0 + fast-diff: ^1.2.0 + glob: ^8.0.3 + ignore: ^5.2.4 + js-yaml: ^4.1.0 + lodash: ^4.17.21 + pluralize: ^8.0.0 + prettier: ^2.8.3 + semver: ^6.3.0 + strip-ansi: ^6.0.1 + table: ^6.8.1 + text-table: ^0.2.0 + dependenciesMeta: + prettier: + optional: true + bin: + solhint: solhint.js + checksum: 4f81b5bac126c6b07ac36be887c0b120263b5628671d8433c5a20ed9f8168ec6224a706456f1b625c0b9e15143427d229eff497dfea94eca398b63b727c8f7bc + languageName: node + linkType: hard + +"solidity-comments-extractor@npm:^0.0.7": + version: 0.0.7 + resolution: "solidity-comments-extractor@npm:0.0.7" + checksum: a5cedf2310709969bc1783a6c336171478536f2f0ea96ad88437e0ef1e8844c0b37dd75591b0a824ec9c30640ea7e31b5f03128e871e6235bef3426617ce96c4 + languageName: node + linkType: hard + +"solidity-docgen@npm:0.5.16": + version: 0.5.16 + resolution: "solidity-docgen@npm:0.5.16" + dependencies: + "@oclif/command": ^1.8.0 + "@oclif/config": ^1.17.0 + "@oclif/errors": ^1.3.3 + "@oclif/plugin-help": ^3.2.0 + globby: ^11.0.0 + handlebars: ^4.7.6 + json5: ^2.1.3 + lodash: ^4.17.15 + micromatch: ^4.0.2 + minimatch: ^3.0.4 + semver: ^7.3.2 + solc: ^0.6.7 + bin: + solidity-docgen: dist/cli.js + checksum: 9afcc901065f9ca15f561d7373aaeb9e4033aed2384efd47c4c1c7fe4ac3d24bc24bda41e10cdf92cc78477ea61fa85124b4653b3bb71995980c1a503c78904b + languageName: node + linkType: hard + +"source-map-support@npm:^0.5.13": + version: 0.5.21 + resolution: "source-map-support@npm:0.5.21" + dependencies: + buffer-from: ^1.0.0 + source-map: ^0.6.0 + checksum: 43e98d700d79af1d36f859bdb7318e601dfc918c7ba2e98456118ebc4c4872b327773e5a1df09b0524e9e5063bb18f0934538eace60cca2710d1fa687645d137 + languageName: node + linkType: hard + +"source-map@npm:^0.6.0, source-map@npm:^0.6.1": + version: 0.6.1 + resolution: "source-map@npm:0.6.1" + checksum: 59ce8640cf3f3124f64ac289012c2b8bd377c238e316fb323ea22fbfe83da07d81e000071d7242cad7a23cd91c7de98e4df8830ec3f133cb6133a5f6e9f67bc2 + languageName: node + linkType: hard + +"sprintf-js@npm:~1.0.2": + version: 1.0.3 + resolution: "sprintf-js@npm:1.0.3" + checksum: 19d79aec211f09b99ec3099b5b2ae2f6e9cdefe50bc91ac4c69144b6d3928a640bb6ae5b3def70c2e85a2c3d9f5ec2719921e3a59d3ca3ef4b2fd1a4656a0df3 + languageName: node + linkType: hard + +"sshpk@npm:^1.7.0": + version: 1.17.0 + resolution: "sshpk@npm:1.17.0" + dependencies: + asn1: ~0.2.3 + assert-plus: ^1.0.0 + bcrypt-pbkdf: ^1.0.0 + dashdash: ^1.12.0 + ecc-jsbn: ~0.1.1 + getpass: ^0.1.1 + jsbn: ~0.1.0 + safer-buffer: ^2.0.2 + tweetnacl: ~0.14.0 + bin: + sshpk-conv: bin/sshpk-conv + sshpk-sign: bin/sshpk-sign + sshpk-verify: bin/sshpk-verify + checksum: ba109f65c8e6c35133b8e6ed5576abeff8aa8d614824b7275ec3ca308f081fef483607c28d97780c1e235818b0f93ed8c8b56d0a5968d5a23fd6af57718c7597 + languageName: node + linkType: hard + +"ssri@npm:^10.0.0": + version: 10.0.5 + resolution: "ssri@npm:10.0.5" + dependencies: + minipass: ^7.0.3 + checksum: 0a31b65f21872dea1ed3f7c200d7bc1c1b91c15e419deca14f282508ba917cbb342c08a6814c7f68ca4ca4116dd1a85da2bbf39227480e50125a1ceffeecb750 + languageName: node + linkType: hard + +"stacktrace-parser@npm:^0.1.10": + version: 0.1.10 + resolution: "stacktrace-parser@npm:0.1.10" + dependencies: + type-fest: ^0.7.1 + checksum: f4fbddfc09121d91e587b60de4beb4941108e967d71ad3a171812dc839b010ca374d064ad0a296295fed13acd103609d99a4224a25b4e67de13cae131f1901ee + languageName: node + linkType: hard + +"statuses@npm:2.0.1": + version: 2.0.1 + resolution: "statuses@npm:2.0.1" + checksum: 18c7623fdb8f646fb213ca4051be4df7efb3484d4ab662937ca6fbef7ced9b9e12842709872eb3020cc3504b93bde88935c9f6417489627a7786f24f8031cbcb + languageName: node + linkType: hard + +"stealthy-require@npm:^1.1.1": + version: 1.1.1 + resolution: "stealthy-require@npm:1.1.1" + checksum: 6805b857a9f3a6a1079fc6652278038b81011f2a5b22cbd559f71a6c02087e6f1df941eb10163e3fdc5391ab5807aa46758d4258547c1f5ede31e6d9bfda8dd3 + languageName: node + linkType: hard + +"streamsearch@npm:^1.1.0": + version: 1.1.0 + resolution: "streamsearch@npm:1.1.0" + checksum: 1cce16cea8405d7a233d32ca5e00a00169cc0e19fbc02aa839959985f267335d435c07f96e5e0edd0eadc6d39c98d5435fb5bbbdefc62c41834eadc5622ad942 + languageName: node + linkType: hard + +"string-argv@npm:^0.3.1": + version: 0.3.2 + resolution: "string-argv@npm:0.3.2" + checksum: 8703ad3f3db0b2641ed2adbb15cf24d3945070d9a751f9e74a924966db9f325ac755169007233e8985a39a6a292f14d4fee20482989b89b96e473c4221508a0f + languageName: node + linkType: hard + +"string-format@npm:^2.0.0": + version: 2.0.0 + resolution: "string-format@npm:2.0.0" + checksum: dada2ef95f6d36c66562c673d95315f80457fa7dce2f3609a2e75d1190b98c88319028cf0a5b6c043d01c18d581b2641579f79480584ba030d6ac6fceb30bc55 + languageName: node + linkType: hard + +"string-width-cjs@npm:string-width@^4.2.0, string-width@npm:^1.0.2 || 2 || 3 || 4, string-width@npm:^4.0.0, string-width@npm:^4.1.0, string-width@npm:^4.2.0, string-width@npm:^4.2.3": + version: 4.2.3 + resolution: "string-width@npm:4.2.3" + dependencies: + emoji-regex: ^8.0.0 + is-fullwidth-code-point: ^3.0.0 + strip-ansi: ^6.0.1 + checksum: e52c10dc3fbfcd6c3a15f159f54a90024241d0f149cf8aed2982a2d801d2e64df0bf1dc351cf8e95c3319323f9f220c16e740b06faecd53e2462df1d2b5443fb + languageName: node + linkType: hard + +"string-width@npm:^1.0.2 || 2, string-width@npm:^2.1.1": + version: 2.1.1 + resolution: "string-width@npm:2.1.1" + dependencies: + is-fullwidth-code-point: ^2.0.0 + strip-ansi: ^4.0.0 + checksum: d6173abe088c615c8dffaf3861dc5d5906ed3dc2d6fd67ff2bd2e2b5dce7fd683c5240699cf0b1b8aa679a3b3bd6b28b5053c824cb89b813d7f6541d8f89064a + languageName: node + linkType: hard + +"string-width@npm:^3.0.0, string-width@npm:^3.1.0": + version: 3.1.0 + resolution: "string-width@npm:3.1.0" + dependencies: + emoji-regex: ^7.0.1 + is-fullwidth-code-point: ^2.0.0 + strip-ansi: ^5.1.0 + checksum: 57f7ca73d201682816d573dc68bd4bb8e1dff8dc9fcf10470fdfc3474135c97175fec12ea6a159e67339b41e86963112355b64529489af6e7e70f94a7caf08b2 + languageName: node + linkType: hard + +"string-width@npm:^5.0.0, string-width@npm:^5.0.1, string-width@npm:^5.1.2": + version: 5.1.2 + resolution: "string-width@npm:5.1.2" + dependencies: + eastasianwidth: ^0.2.0 + emoji-regex: ^9.2.2 + strip-ansi: ^7.0.1 + checksum: 7369deaa29f21dda9a438686154b62c2c5f661f8dda60449088f9f980196f7908fc39fdd1803e3e01541970287cf5deae336798337e9319a7055af89dafa7193 + languageName: node + linkType: hard + +"string.prototype.trim@npm:^1.2.7": + version: 1.2.7 + resolution: "string.prototype.trim@npm:1.2.7" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.4 + es-abstract: ^1.20.4 + checksum: 05b7b2d6af63648e70e44c4a8d10d8cc457536df78b55b9d6230918bde75c5987f6b8604438c4c8652eb55e4fc9725d2912789eb4ec457d6995f3495af190c09 + languageName: node + linkType: hard + +"string.prototype.trimend@npm:^1.0.6": + version: 1.0.6 + resolution: "string.prototype.trimend@npm:1.0.6" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.4 + es-abstract: ^1.20.4 + checksum: 0fdc34645a639bd35179b5a08227a353b88dc089adf438f46be8a7c197fc3f22f8514c1c9be4629b3cd29c281582730a8cbbad6466c60f76b5f99cf2addb132e + languageName: node + linkType: hard + +"string.prototype.trimstart@npm:^1.0.6": + version: 1.0.6 + resolution: "string.prototype.trimstart@npm:1.0.6" + dependencies: + call-bind: ^1.0.2 + define-properties: ^1.1.4 + es-abstract: ^1.20.4 + checksum: 89080feef416621e6ef1279588994305477a7a91648d9436490d56010a1f7adc39167cddac7ce0b9884b8cdbef086987c4dcb2960209f2af8bac0d23ceff4f41 + languageName: node + linkType: hard + +"string_decoder@npm:^1.1.1": + version: 1.3.0 + resolution: "string_decoder@npm:1.3.0" + dependencies: + safe-buffer: ~5.2.0 + checksum: 8417646695a66e73aefc4420eb3b84cc9ffd89572861fe004e6aeb13c7bc00e2f616247505d2dbbef24247c372f70268f594af7126f43548565c68c117bdeb56 + languageName: node + linkType: hard + +"string_decoder@npm:~1.1.1": + version: 1.1.1 + resolution: "string_decoder@npm:1.1.1" + dependencies: + safe-buffer: ~5.1.0 + checksum: 9ab7e56f9d60a28f2be697419917c50cac19f3e8e6c28ef26ed5f4852289fe0de5d6997d29becf59028556f2c62983790c1d9ba1e2a3cc401768ca12d5183a5b + languageName: node + linkType: hard + +"strip-ansi-cjs@npm:strip-ansi@^6.0.1, strip-ansi@npm:^6.0.0, strip-ansi@npm:^6.0.1": + version: 6.0.1 + resolution: "strip-ansi@npm:6.0.1" + dependencies: + ansi-regex: ^5.0.1 + checksum: f3cd25890aef3ba6e1a74e20896c21a46f482e93df4a06567cebf2b57edabb15133f1f94e57434e0a958d61186087b1008e89c94875d019910a213181a14fc8c + languageName: node + linkType: hard + +"strip-ansi@npm:^4.0.0": + version: 4.0.0 + resolution: "strip-ansi@npm:4.0.0" + dependencies: + ansi-regex: ^3.0.0 + checksum: d9186e6c0cf78f25274f6750ee5e4a5725fb91b70fdd79aa5fe648eab092a0ec5b9621b22d69d4534a56319f75d8944efbd84e3afa8d4ad1b9a9491f12c84eca + languageName: node + linkType: hard + +"strip-ansi@npm:^5.0.0, strip-ansi@npm:^5.1.0, strip-ansi@npm:^5.2.0": + version: 5.2.0 + resolution: "strip-ansi@npm:5.2.0" + dependencies: + ansi-regex: ^4.1.0 + checksum: bdb5f76ade97062bd88e7723aa019adbfacdcba42223b19ccb528ffb9fb0b89a5be442c663c4a3fb25268eaa3f6ea19c7c3fbae830bd1562d55adccae1fcec46 + languageName: node + linkType: hard + +"strip-ansi@npm:^7.0.1": + version: 7.1.0 + resolution: "strip-ansi@npm:7.1.0" + dependencies: + ansi-regex: ^6.0.1 + checksum: 859c73fcf27869c22a4e4d8c6acfe690064659e84bef9458aa6d13719d09ca88dcfd40cbf31fd0be63518ea1a643fe070b4827d353e09533a5b0b9fd4553d64d + languageName: node + linkType: hard + +"strip-final-newline@npm:^3.0.0": + version: 3.0.0 + resolution: "strip-final-newline@npm:3.0.0" + checksum: 23ee263adfa2070cd0f23d1ac14e2ed2f000c9b44229aec9c799f1367ec001478469560abefd00c5c99ee6f0b31c137d53ec6029c53e9f32a93804e18c201050 + languageName: node + linkType: hard + +"strip-hex-prefix@npm:1.0.0": + version: 1.0.0 + resolution: "strip-hex-prefix@npm:1.0.0" + dependencies: + is-hex-prefixed: 1.0.0 + checksum: 4cafe7caee1d281d3694d14920fd5d3c11adf09371cef7e2ccedd5b83efd9e9bd2219b5d6ce6e809df6e0f437dc9d30db1192116580875698aad164a6d6b285b + languageName: node + linkType: hard + +"strip-json-comments@npm:2.0.1": + version: 2.0.1 + resolution: "strip-json-comments@npm:2.0.1" + checksum: 1074ccb63270d32ca28edfb0a281c96b94dc679077828135141f27d52a5a398ef5e78bcf22809d23cadc2b81dfbe345eb5fd8699b385c8b1128907dec4a7d1e1 + languageName: node + linkType: hard + +"strip-json-comments@npm:3.1.1": + version: 3.1.1 + resolution: "strip-json-comments@npm:3.1.1" + checksum: 492f73e27268f9b1c122733f28ecb0e7e8d8a531a6662efbd08e22cccb3f9475e90a1b82cab06a392f6afae6d2de636f977e231296400d0ec5304ba70f166443 + languageName: node + linkType: hard + +"supports-color@npm:6.0.0": + version: 6.0.0 + resolution: "supports-color@npm:6.0.0" + dependencies: + has-flag: ^3.0.0 + checksum: 005b4a7e5d78a9a703454f5b7da34336b82825747724d1f3eefea6c3956afcb33b79b31854a93cef0fc1f2449919ae952f79abbfd09a5b5b43ecd26407d3a3a1 + languageName: node + linkType: hard + +"supports-color@npm:8.1.1": + version: 8.1.1 + resolution: "supports-color@npm:8.1.1" + dependencies: + has-flag: ^4.0.0 + checksum: c052193a7e43c6cdc741eb7f378df605636e01ad434badf7324f17fb60c69a880d8d8fcdcb562cf94c2350e57b937d7425ab5b8326c67c2adc48f7c87c1db406 + languageName: node + linkType: hard + +"supports-color@npm:^5.3.0": + version: 5.5.0 + resolution: "supports-color@npm:5.5.0" + dependencies: + has-flag: ^3.0.0 + checksum: 95f6f4ba5afdf92f495b5a912d4abee8dcba766ae719b975c56c084f5004845f6f5a5f7769f52d53f40e21952a6d87411bafe34af4a01e65f9926002e38e1dac + languageName: node + linkType: hard + +"supports-color@npm:^7.1.0": + version: 7.2.0 + resolution: "supports-color@npm:7.2.0" + dependencies: + has-flag: ^4.0.0 + checksum: 3dda818de06ebbe5b9653e07842d9479f3555ebc77e9a0280caf5a14fb877ffee9ed57007c3b78f5a6324b8dbeec648d9e97a24e2ed9fdb81ddc69ea07100f4a + languageName: node + linkType: hard + +"sync-request@npm:^6.0.0": + version: 6.1.0 + resolution: "sync-request@npm:6.1.0" + dependencies: + http-response-object: ^3.0.1 + sync-rpc: ^1.2.1 + then-request: ^6.0.0 + checksum: cc8438a6749f62fb501d022fae0e3af3ac4a9983f889f929c8721b328a1c3408b98ca218aad886785a02be2c34bd75eb1a5a2608bd1fcee3c8c099391ff53a11 + languageName: node + linkType: hard + +"sync-rpc@npm:^1.2.1": + version: 1.3.6 + resolution: "sync-rpc@npm:1.3.6" + dependencies: + get-port: ^3.1.0 + checksum: 4340974fb5641c2cadb9df18d6b791ed2327f28cf6d8a00c99ebc2278e37391e3f5e237596da2ff83d14d2147594c6f5b3b98a93b9327644db425d239dea172f + languageName: node + linkType: hard + +"table-layout@npm:^1.0.2": + version: 1.0.2 + resolution: "table-layout@npm:1.0.2" + dependencies: + array-back: ^4.0.1 + deep-extend: ~0.6.0 + typical: ^5.2.0 + wordwrapjs: ^4.0.0 + checksum: 8f41b5671f101a5195747ec1727b1d35ea2cd5bf85addda11cc2f4b36892db9696ce3c2c7334b5b8a122505b34d19135fede50e25678df71b0439e0704fd953f + languageName: node + linkType: hard + +"table@npm:^6.8.1": + version: 6.8.1 + resolution: "table@npm:6.8.1" + dependencies: + ajv: ^8.0.1 + lodash.truncate: ^4.4.2 + slice-ansi: ^4.0.0 + string-width: ^4.2.3 + strip-ansi: ^6.0.1 + checksum: 08249c7046125d9d0a944a6e96cfe9ec66908d6b8a9db125531be6eb05fa0de047fd5542e9d43b4f987057f00a093b276b8d3e19af162a9c40db2681058fd306 + languageName: node + linkType: hard + +"tar@npm:^6.1.11, tar@npm:^6.1.2": + version: 6.2.0 + resolution: "tar@npm:6.2.0" + dependencies: + chownr: ^2.0.0 + fs-minipass: ^2.0.0 + minipass: ^5.0.0 + minizlib: ^2.1.1 + mkdirp: ^1.0.3 + yallist: ^4.0.0 + checksum: db4d9fe74a2082c3a5016630092c54c8375ff3b280186938cfd104f2e089c4fd9bad58688ef6be9cf186a889671bf355c7cda38f09bbf60604b281715ca57f5c + languageName: node + linkType: hard + +"text-table@npm:^0.2.0": + version: 0.2.0 + resolution: "text-table@npm:0.2.0" + checksum: b6937a38c80c7f84d9c11dd75e49d5c44f71d95e810a3250bd1f1797fc7117c57698204adf676b71497acc205d769d65c16ae8fa10afad832ae1322630aef10a + languageName: node + linkType: hard + +"then-request@npm:^6.0.0": + version: 6.0.2 + resolution: "then-request@npm:6.0.2" + dependencies: + "@types/concat-stream": ^1.6.0 + "@types/form-data": 0.0.33 + "@types/node": ^8.0.0 + "@types/qs": ^6.2.31 + caseless: ~0.12.0 + concat-stream: ^1.6.0 + form-data: ^2.2.0 + http-basic: ^8.1.1 + http-response-object: ^3.0.1 + promise: ^8.0.0 + qs: ^6.4.0 + checksum: a24a4fc95dd8591966bf3752f024f5cd4d53c2b2c29b23b4e40c3322df6a432d939bc17b589d8e9d760b90e92ab860f6f361a4dfcfe3542019e1615fb51afccc + languageName: node + linkType: hard + +"through@npm:^2.3.8": + version: 2.3.8 + resolution: "through@npm:2.3.8" + checksum: a38c3e059853c494af95d50c072b83f8b676a9ba2818dcc5b108ef252230735c54e0185437618596c790bbba8fcdaef5b290405981ffa09dce67b1f1bf190cbd + languageName: node + linkType: hard + +"tmp@npm:0.0.33": + version: 0.0.33 + resolution: "tmp@npm:0.0.33" + dependencies: + os-tmpdir: ~1.0.2 + checksum: 902d7aceb74453ea02abbf58c203f4a8fc1cead89b60b31e354f74ed5b3fb09ea817f94fb310f884a5d16987dd9fa5a735412a7c2dd088dd3d415aa819ae3a28 + languageName: node + linkType: hard + +"to-regex-range@npm:^5.0.1": + version: 5.0.1 + resolution: "to-regex-range@npm:5.0.1" + dependencies: + is-number: ^7.0.0 + checksum: f76fa01b3d5be85db6a2a143e24df9f60dd047d151062d0ba3df62953f2f697b16fe5dad9b0ac6191c7efc7b1d9dcaa4b768174b7b29da89d4428e64bc0a20ed + languageName: node + linkType: hard + +"toidentifier@npm:1.0.1": + version: 1.0.1 + resolution: "toidentifier@npm:1.0.1" + checksum: 952c29e2a85d7123239b5cfdd889a0dde47ab0497f0913d70588f19c53f7e0b5327c95f4651e413c74b785147f9637b17410ac8c846d5d4a20a5a33eb6dc3a45 + languageName: node + linkType: hard + +"tough-cookie@npm:^2.3.3, tough-cookie@npm:~2.5.0": + version: 2.5.0 + resolution: "tough-cookie@npm:2.5.0" + dependencies: + psl: ^1.1.28 + punycode: ^2.1.1 + checksum: 16a8cd090224dd176eee23837cbe7573ca0fa297d7e468ab5e1c02d49a4e9a97bb05fef11320605eac516f91d54c57838a25864e8680e27b069a5231d8264977 + languageName: node + linkType: hard + +"ts-command-line-args@npm:^2.2.0": + version: 2.5.1 + resolution: "ts-command-line-args@npm:2.5.1" + dependencies: + chalk: ^4.1.0 + command-line-args: ^5.1.1 + command-line-usage: ^6.1.0 + string-format: ^2.0.0 + bin: + write-markdown: dist/write-markdown.js + checksum: 7c0a7582e94f1d2160e3dd379851ec4f1758bc673ccd71bae07f839f83051b6b83e0ae14325c2d04ea728e5bde7b7eacfd2ab060b8fd4b8ab29e0bbf77f6c51e + languageName: node + linkType: hard + +"ts-essentials@npm:^7.0.1": + version: 7.0.3 + resolution: "ts-essentials@npm:7.0.3" + peerDependencies: + typescript: ">=3.7.0" + checksum: 74d75868acf7f8b95e447d8b3b7442ca21738c6894e576df9917a352423fde5eb43c5651da5f78997da6061458160ae1f6b279150b42f47ccc58b73e55acaa2f + languageName: node + linkType: hard + +"ts-node@npm:^10.4.0": + version: 10.9.1 + resolution: "ts-node@npm:10.9.1" + dependencies: + "@cspotcode/source-map-support": ^0.8.0 + "@tsconfig/node10": ^1.0.7 + "@tsconfig/node12": ^1.0.7 + "@tsconfig/node14": ^1.0.0 + "@tsconfig/node16": ^1.0.2 + acorn: ^8.4.1 + acorn-walk: ^8.1.1 + arg: ^4.1.0 + create-require: ^1.1.0 + diff: ^4.0.1 + make-error: ^1.1.1 + v8-compile-cache-lib: ^3.0.1 + yn: 3.1.1 + peerDependencies: + "@swc/core": ">=1.2.50" + "@swc/wasm": ">=1.2.50" + "@types/node": "*" + typescript: ">=2.7" + peerDependenciesMeta: + "@swc/core": + optional: true + "@swc/wasm": + optional: true + bin: + ts-node: dist/bin.js + ts-node-cwd: dist/bin-cwd.js + ts-node-esm: dist/bin-esm.js + ts-node-script: dist/bin-script.js + ts-node-transpile-only: dist/bin-transpile.js + ts-script: dist/bin-script-deprecated.js + checksum: 090adff1302ab20bd3486e6b4799e90f97726ed39e02b39e566f8ab674fd5bd5f727f43615debbfc580d33c6d9d1c6b1b3ce7d8e3cca3e20530a145ffa232c35 + languageName: node + linkType: hard + +"tslib@npm:^1.9.3": + version: 1.14.1 + resolution: "tslib@npm:1.14.1" + checksum: dbe628ef87f66691d5d2959b3e41b9ca0045c3ee3c7c7b906cc1e328b39f199bb1ad9e671c39025bd56122ac57dfbf7385a94843b1cc07c60a4db74795829acd + languageName: node + linkType: hard + +"tslib@npm:^2.0.0, tslib@npm:^2.1.0, tslib@npm:^2.5.0, tslib@npm:^2.6.1": + version: 2.6.1 + resolution: "tslib@npm:2.6.1" + checksum: b0d176d176487905b66ae4d5856647df50e37beea7571c53b8d10ba9222c074b81f1410fb91da13debaf2cbc970663609068bdebafa844ea9d69b146527c38fe + languageName: node + linkType: hard + +"tsort@npm:0.0.1": + version: 0.0.1 + resolution: "tsort@npm:0.0.1" + checksum: 581566c248690b9ea7e431e1545affb3d2cab0f5dcd0e45ddef815dfaec4864cb5f0cfd8072924dedbc0de9585ff07e3e65db60f14fab4123737b9bb6e72eacc + languageName: node + linkType: hard + +"tunnel-agent@npm:^0.6.0": + version: 0.6.0 + resolution: "tunnel-agent@npm:0.6.0" + dependencies: + safe-buffer: ^5.0.1 + checksum: 05f6510358f8afc62a057b8b692f05d70c1782b70db86d6a1e0d5e28a32389e52fa6e7707b6c5ecccacc031462e4bc35af85ecfe4bbc341767917b7cf6965711 + languageName: node + linkType: hard + +"tweetnacl-util@npm:^0.15.1": + version: 0.15.1 + resolution: "tweetnacl-util@npm:0.15.1" + checksum: ae6aa8a52cdd21a95103a4cc10657d6a2040b36c7a6da7b9d3ab811c6750a2d5db77e8c36969e75fdee11f511aa2b91c552496c6e8e989b6e490e54aca2864fc + languageName: node + linkType: hard + +"tweetnacl@npm:^0.14.3, tweetnacl@npm:~0.14.0": + version: 0.14.5 + resolution: "tweetnacl@npm:0.14.5" + checksum: 6061daba1724f59473d99a7bb82e13f211cdf6e31315510ae9656fefd4779851cb927adad90f3b488c8ed77c106adc0421ea8055f6f976ff21b27c5c4e918487 + languageName: node + linkType: hard + +"tweetnacl@npm:^1.0.3": + version: 1.0.3 + resolution: "tweetnacl@npm:1.0.3" + checksum: e4a57cac188f0c53f24c7a33279e223618a2bfb5fea426231991652a13247bea06b081fd745d71291fcae0f4428d29beba1b984b1f1ce6f66b06a6d1ab90645c + languageName: node + linkType: hard + +"type-detect@npm:^4.0.0, type-detect@npm:^4.0.5": + version: 4.0.8 + resolution: "type-detect@npm:4.0.8" + checksum: 62b5628bff67c0eb0b66afa371bd73e230399a8d2ad30d852716efcc4656a7516904570cd8631a49a3ce57c10225adf5d0cbdcb47f6b0255fe6557c453925a15 + languageName: node + linkType: hard + +"type-fest@npm:^0.21.3": + version: 0.21.3 + resolution: "type-fest@npm:0.21.3" + checksum: e6b32a3b3877f04339bae01c193b273c62ba7bfc9e325b8703c4ee1b32dc8fe4ef5dfa54bf78265e069f7667d058e360ae0f37be5af9f153b22382cd55a9afe0 + languageName: node + linkType: hard + +"type-fest@npm:^0.7.1": + version: 0.7.1 + resolution: "type-fest@npm:0.7.1" + checksum: 5b1b113529d59949d97b76977d545989ddc11b81bb0c766b6d2ccc65473cb4b4a5c7d24f5be2c2bb2de302a5d7a13c1732ea1d34c8c59b7e0ec1f890cf7fc424 + languageName: node + linkType: hard + +"typechain@npm:^6.0.5": + version: 6.1.0 + resolution: "typechain@npm:6.1.0" + dependencies: + "@types/prettier": ^2.1.1 + debug: ^4.1.1 + fs-extra: ^7.0.0 + glob: ^7.1.6 + js-sha3: ^0.8.0 + lodash: ^4.17.15 + mkdirp: ^1.0.4 + prettier: ^2.1.2 + ts-command-line-args: ^2.2.0 + ts-essentials: ^7.0.1 + peerDependencies: + typescript: ">=4.1.0" + bin: + typechain: dist/cli/cli.js + checksum: 9803a61d2c316a9f5cfbdbb88718ea9bdeff5485401b3d584d035069b96316d5bb4923129bfdcdd4327a7d44b9d37de95e38c7cd6d83ce1368ec38fab9d419b4 + languageName: node + linkType: hard + +"typed-array-buffer@npm:^1.0.0": + version: 1.0.0 + resolution: "typed-array-buffer@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + get-intrinsic: ^1.2.1 + is-typed-array: ^1.1.10 + checksum: 3e0281c79b2a40cd97fe715db803884301993f4e8c18e8d79d75fd18f796e8cd203310fec8c7fdb5e6c09bedf0af4f6ab8b75eb3d3a85da69328f28a80456bd3 + languageName: node + linkType: hard + +"typed-array-byte-length@npm:^1.0.0": + version: 1.0.0 + resolution: "typed-array-byte-length@npm:1.0.0" + dependencies: + call-bind: ^1.0.2 + for-each: ^0.3.3 + has-proto: ^1.0.1 + is-typed-array: ^1.1.10 + checksum: b03db16458322b263d87a702ff25388293f1356326c8a678d7515767ef563ef80e1e67ce648b821ec13178dd628eb2afdc19f97001ceae7a31acf674c849af94 + languageName: node + linkType: hard + +"typed-array-byte-offset@npm:^1.0.0": + version: 1.0.0 + resolution: "typed-array-byte-offset@npm:1.0.0" + dependencies: + available-typed-arrays: ^1.0.5 + call-bind: ^1.0.2 + for-each: ^0.3.3 + has-proto: ^1.0.1 + is-typed-array: ^1.1.10 + checksum: 04f6f02d0e9a948a95fbfe0d5a70b002191fae0b8fe0fe3130a9b2336f043daf7a3dda56a31333c35a067a97e13f539949ab261ca0f3692c41603a46a94e960b + languageName: node + linkType: hard + +"typed-array-length@npm:^1.0.4": + version: 1.0.4 + resolution: "typed-array-length@npm:1.0.4" + dependencies: + call-bind: ^1.0.2 + for-each: ^0.3.3 + is-typed-array: ^1.1.9 + checksum: 2228febc93c7feff142b8c96a58d4a0d7623ecde6c7a24b2b98eb3170e99f7c7eff8c114f9b283085cd59dcd2bd43aadf20e25bba4b034a53c5bb292f71f8956 + languageName: node + linkType: hard + +"typedarray@npm:^0.0.6": + version: 0.0.6 + resolution: "typedarray@npm:0.0.6" + checksum: 33b39f3d0e8463985eeaeeacc3cb2e28bc3dfaf2a5ed219628c0b629d5d7b810b0eb2165f9f607c34871d5daa92ba1dc69f49051cf7d578b4cbd26c340b9d1b1 + languageName: node + linkType: hard + +"typescript@npm:^4.5.4": + version: 4.9.5 + resolution: "typescript@npm:4.9.5" + bin: + tsc: bin/tsc + tsserver: bin/tsserver + checksum: ee000bc26848147ad423b581bd250075662a354d84f0e06eb76d3b892328d8d4440b7487b5a83e851b12b255f55d71835b008a66cbf8f255a11e4400159237db + languageName: node + linkType: hard + +"typescript@patch:typescript@^4.5.4#~builtin": + version: 4.9.5 + resolution: "typescript@patch:typescript@npm%3A4.9.5#~builtin::version=4.9.5&hash=289587" + bin: + tsc: bin/tsc + tsserver: bin/tsserver + checksum: 1f8f3b6aaea19f0f67cba79057674ba580438a7db55057eb89cc06950483c5d632115c14077f6663ea76fd09fce3c190e6414bb98582ec80aa5a4eaf345d5b68 + languageName: node + linkType: hard + +"typical@npm:^4.0.0": + version: 4.0.0 + resolution: "typical@npm:4.0.0" + checksum: a242081956825328f535e6195a924240b34daf6e7fdb573a1809a42b9f37fb8114fa99c7ab89a695e0cdb419d4149d067f6723e4b95855ffd39c6c4ca378efb3 + languageName: node + linkType: hard + +"typical@npm:^5.2.0": + version: 5.2.0 + resolution: "typical@npm:5.2.0" + checksum: ccaeb151a9a556291b495571ca44c4660f736fb49c29314bbf773c90fad92e9485d3cc2b074c933866c1595abbbc962f2b8bfc6e0f52a8c6b0cdd205442036ac + languageName: node + linkType: hard + +"uglify-js@npm:^3.1.4": + version: 3.17.4 + resolution: "uglify-js@npm:3.17.4" + bin: + uglifyjs: bin/uglifyjs + checksum: 7b3897df38b6fc7d7d9f4dcd658599d81aa2b1fb0d074829dd4e5290f7318dbca1f4af2f45acb833b95b1fe0ed4698662ab61b87e94328eb4c0a0d3435baf924 + languageName: node + linkType: hard + +"unbox-primitive@npm:^1.0.2": + version: 1.0.2 + resolution: "unbox-primitive@npm:1.0.2" + dependencies: + call-bind: ^1.0.2 + has-bigints: ^1.0.2 + has-symbols: ^1.0.3 + which-boxed-primitive: ^1.0.2 + checksum: b7a1cf5862b5e4b5deb091672ffa579aa274f648410009c81cca63fed3b62b610c4f3b773f912ce545bb4e31edc3138975b5bc777fc6e4817dca51affb6380e9 + languageName: node + linkType: hard + +"undici@npm:^5.14.0": + version: 5.22.1 + resolution: "undici@npm:5.22.1" + dependencies: + busboy: ^1.6.0 + checksum: 048a3365f622be44fb319316cedfaa241c59cf7f3368ae7667a12323447e1822e8cc3d00f6956c852d1478a6fde1cbbe753f49e05f2fdaed229693e716ebaf35 + languageName: node + linkType: hard + +"unique-filename@npm:^3.0.0": + version: 3.0.0 + resolution: "unique-filename@npm:3.0.0" + dependencies: + unique-slug: ^4.0.0 + checksum: 8e2f59b356cb2e54aab14ff98a51ac6c45781d15ceaab6d4f1c2228b780193dc70fae4463ce9e1df4479cb9d3304d7c2043a3fb905bdeca71cc7e8ce27e063df + languageName: node + linkType: hard + +"unique-slug@npm:^4.0.0": + version: 4.0.0 + resolution: "unique-slug@npm:4.0.0" + dependencies: + imurmurhash: ^0.1.4 + checksum: 0884b58365af59f89739e6f71e3feacb5b1b41f2df2d842d0757933620e6de08eff347d27e9d499b43c40476cbaf7988638d3acb2ffbcb9d35fd035591adfd15 + languageName: node + linkType: hard + +"universalify@npm:^0.1.0": + version: 0.1.2 + resolution: "universalify@npm:0.1.2" + checksum: 40cdc60f6e61070fe658ca36016a8f4ec216b29bf04a55dce14e3710cc84c7448538ef4dad3728d0bfe29975ccd7bfb5f414c45e7b78883567fb31b246f02dff + languageName: node + linkType: hard + +"universalify@npm:^2.0.0": + version: 2.0.0 + resolution: "universalify@npm:2.0.0" + checksum: 2406a4edf4a8830aa6813278bab1f953a8e40f2f63a37873ffa9a3bc8f9745d06cc8e88f3572cb899b7e509013f7f6fcc3e37e8a6d914167a5381d8440518c44 + languageName: node + linkType: hard + +"unpipe@npm:1.0.0": + version: 1.0.0 + resolution: "unpipe@npm:1.0.0" + checksum: 4fa18d8d8d977c55cb09715385c203197105e10a6d220087ec819f50cb68870f02942244f1017565484237f1f8c5d3cd413631b1ae104d3096f24fdfde1b4aa2 + languageName: node + linkType: hard + +"uri-js@npm:^4.2.2": + version: 4.4.1 + resolution: "uri-js@npm:4.4.1" + dependencies: + punycode: ^2.1.0 + checksum: 7167432de6817fe8e9e0c9684f1d2de2bb688c94388f7569f7dbdb1587c9f4ca2a77962f134ec90be0cc4d004c939ff0d05acc9f34a0db39a3c797dada262633 + languageName: node + linkType: hard + +"util-deprecate@npm:^1.0.1, util-deprecate@npm:~1.0.1": + version: 1.0.2 + resolution: "util-deprecate@npm:1.0.2" + checksum: 474acf1146cb2701fe3b074892217553dfcf9a031280919ba1b8d651a068c9b15d863b7303cb15bd00a862b498e6cf4ad7b4a08fb134edd5a6f7641681cb54a2 + languageName: node + linkType: hard + +"uuid@npm:2.0.1": + version: 2.0.1 + resolution: "uuid@npm:2.0.1" + checksum: e129e494e33cededdfc2cefbd63da966344b873bbfd3373a311b0acc2e7ab53d68b2515879444898867d84b863e44939e852484b9f3a54c4fd86d985a7dadb8d + languageName: node + linkType: hard + +"uuid@npm:^3.3.2": + version: 3.4.0 + resolution: "uuid@npm:3.4.0" + bin: + uuid: ./bin/uuid + checksum: 58de2feed61c59060b40f8203c0e4ed7fd6f99d42534a499f1741218a1dd0c129f4aa1de797bcf822c8ea5da7e4137aa3673431a96dae729047f7aca7b27866f + languageName: node + linkType: hard + +"uuid@npm:^8.3.2": + version: 8.3.2 + resolution: "uuid@npm:8.3.2" + bin: + uuid: dist/bin/uuid + checksum: 5575a8a75c13120e2f10e6ddc801b2c7ed7d8f3c8ac22c7ed0c7b2ba6383ec0abda88c905085d630e251719e0777045ae3236f04c812184b7c765f63a70e58df + languageName: node + linkType: hard + +"v8-compile-cache-lib@npm:^3.0.1": + version: 3.0.1 + resolution: "v8-compile-cache-lib@npm:3.0.1" + checksum: 78089ad549e21bcdbfca10c08850022b22024cdcc2da9b168bcf5a73a6ed7bf01a9cebb9eac28e03cd23a684d81e0502797e88f3ccd27a32aeab1cfc44c39da0 + languageName: node + linkType: hard + +"verror@npm:1.10.0": + version: 1.10.0 + resolution: "verror@npm:1.10.0" + dependencies: + assert-plus: ^1.0.0 + core-util-is: 1.0.2 + extsprintf: ^1.2.0 + checksum: c431df0bedf2088b227a4e051e0ff4ca54df2c114096b0c01e1cbaadb021c30a04d7dd5b41ab277bcd51246ca135bf931d4c4c796ecae7a4fef6d744ecef36ea + languageName: node + linkType: hard + +"which-boxed-primitive@npm:^1.0.2": + version: 1.0.2 + resolution: "which-boxed-primitive@npm:1.0.2" + dependencies: + is-bigint: ^1.0.1 + is-boolean-object: ^1.1.0 + is-number-object: ^1.0.4 + is-string: ^1.0.5 + is-symbol: ^1.0.3 + checksum: 53ce774c7379071729533922adcca47220228405e1895f26673bbd71bdf7fb09bee38c1d6399395927c6289476b5ae0629863427fd151491b71c4b6cb04f3a5e + languageName: node + linkType: hard + +"which-module@npm:^2.0.0": + version: 2.0.1 + resolution: "which-module@npm:2.0.1" + checksum: 1967b7ce17a2485544a4fdd9063599f0f773959cca24176dbe8f405e55472d748b7c549cd7920ff6abb8f1ab7db0b0f1b36de1a21c57a8ff741f4f1e792c52be + languageName: node + linkType: hard + +"which-typed-array@npm:^1.1.10, which-typed-array@npm:^1.1.11": + version: 1.1.11 + resolution: "which-typed-array@npm:1.1.11" + dependencies: + available-typed-arrays: ^1.0.5 + call-bind: ^1.0.2 + for-each: ^0.3.3 + gopd: ^1.0.1 + has-tostringtag: ^1.0.0 + checksum: 711ffc8ef891ca6597b19539075ec3e08bb9b4c2ca1f78887e3c07a977ab91ac1421940505a197758fb5939aa9524976d0a5bbcac34d07ed6faa75cedbb17206 + languageName: node + linkType: hard + +"which@npm:1.3.1": + version: 1.3.1 + resolution: "which@npm:1.3.1" + dependencies: + isexe: ^2.0.0 + bin: + which: ./bin/which + checksum: f2e185c6242244b8426c9df1510e86629192d93c1a986a7d2a591f2c24869e7ffd03d6dac07ca863b2e4c06f59a4cc9916c585b72ee9fa1aa609d0124df15e04 + languageName: node + linkType: hard + +"which@npm:^2.0.1, which@npm:^2.0.2": + version: 2.0.2 + resolution: "which@npm:2.0.2" + dependencies: + isexe: ^2.0.0 + bin: + node-which: ./bin/node-which + checksum: 1a5c563d3c1b52d5f893c8b61afe11abc3bab4afac492e8da5bde69d550de701cf9806235f20a47b5c8fa8a1d6a9135841de2596535e998027a54589000e66d1 + languageName: node + linkType: hard + +"wide-align@npm:1.1.3": + version: 1.1.3 + resolution: "wide-align@npm:1.1.3" + dependencies: + string-width: ^1.0.2 || 2 + checksum: d09c8012652a9e6cab3e82338d1874a4d7db2ad1bd19ab43eb744acf0b9b5632ec406bdbbbb970a8f4771a7d5ef49824d038ba70aa884e7723f5b090ab87134d + languageName: node + linkType: hard + +"wide-align@npm:^1.1.5": + version: 1.1.5 + resolution: "wide-align@npm:1.1.5" + dependencies: + string-width: ^1.0.2 || 2 || 3 || 4 + checksum: d5fc37cd561f9daee3c80e03b92ed3e84d80dde3365a8767263d03dacfc8fa06b065ffe1df00d8c2a09f731482fcacae745abfbb478d4af36d0a891fad4834d3 + languageName: node + linkType: hard + +"widest-line@npm:^3.1.0": + version: 3.1.0 + resolution: "widest-line@npm:3.1.0" + dependencies: + string-width: ^4.0.0 + checksum: 03db6c9d0af9329c37d74378ff1d91972b12553c7d72a6f4e8525fe61563fa7adb0b9d6e8d546b7e059688712ea874edd5ded475999abdeedf708de9849310e0 + languageName: node + linkType: hard + +"wordwrap@npm:^1.0.0": + version: 1.0.0 + resolution: "wordwrap@npm:1.0.0" + checksum: 2a44b2788165d0a3de71fd517d4880a8e20ea3a82c080ce46e294f0b68b69a2e49cff5f99c600e275c698a90d12c5ea32aff06c311f0db2eb3f1201f3e7b2a04 + languageName: node + linkType: hard + +"wordwrapjs@npm:^4.0.0": + version: 4.0.1 + resolution: "wordwrapjs@npm:4.0.1" + dependencies: + reduce-flatten: ^2.0.0 + typical: ^5.2.0 + checksum: 3d927f3c95d0ad990968da54c0ad8cde2801d8e91006cd7474c26e6b742cc8557250ce495c9732b2f9db1f903601cb74ec282e0f122ee0d02d7abe81e150eea8 + languageName: node + linkType: hard + +"workerpool@npm:6.2.1": + version: 6.2.1 + resolution: "workerpool@npm:6.2.1" + checksum: c2c6eebbc5225f10f758d599a5c016fa04798bcc44e4c1dffb34050cd361d7be2e97891aa44419e7afe647b1f767b1dc0b85a5e046c409d890163f655028b09d + languageName: node + linkType: hard + +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0, wrap-ansi@npm:^7.0.0": + version: 7.0.0 + resolution: "wrap-ansi@npm:7.0.0" + dependencies: + ansi-styles: ^4.0.0 + string-width: ^4.1.0 + strip-ansi: ^6.0.0 + checksum: a790b846fd4505de962ba728a21aaeda189b8ee1c7568ca5e817d85930e06ef8d1689d49dbf0e881e8ef84436af3a88bc49115c2e2788d841ff1b8b5b51a608b + languageName: node + linkType: hard + +"wrap-ansi@npm:^5.1.0": + version: 5.1.0 + resolution: "wrap-ansi@npm:5.1.0" + dependencies: + ansi-styles: ^3.2.0 + string-width: ^3.0.0 + strip-ansi: ^5.0.0 + checksum: 9b48c862220e541eb0daa22661b38b947973fc57054e91be5b0f2dcc77741a6875ccab4ebe970a394b4682c8dfc17e888266a105fb8b0a9b23c19245e781ceae + languageName: node + linkType: hard + +"wrap-ansi@npm:^6.2.0": + version: 6.2.0 + resolution: "wrap-ansi@npm:6.2.0" + dependencies: + ansi-styles: ^4.0.0 + string-width: ^4.1.0 + strip-ansi: ^6.0.0 + checksum: 6cd96a410161ff617b63581a08376f0cb9162375adeb7956e10c8cd397821f7eb2a6de24eb22a0b28401300bf228c86e50617cd568209b5f6775b93c97d2fe3a + languageName: node + linkType: hard + +"wrap-ansi@npm:^8.1.0": + version: 8.1.0 + resolution: "wrap-ansi@npm:8.1.0" + dependencies: + ansi-styles: ^6.1.0 + string-width: ^5.0.1 + strip-ansi: ^7.0.1 + checksum: 371733296dc2d616900ce15a0049dca0ef67597d6394c57347ba334393599e800bab03c41d4d45221b6bc967b8c453ec3ae4749eff3894202d16800fdfe0e238 + languageName: node + linkType: hard + +"wrappy@npm:1": + version: 1.0.2 + resolution: "wrappy@npm:1.0.2" + checksum: 159da4805f7e84a3d003d8841557196034155008f817172d4e986bd591f74aa82aa7db55929a54222309e01079a65a92a9e6414da5a6aa4b01ee44a511ac3ee5 + languageName: node + linkType: hard + +"ws@npm:7.4.6": + version: 7.4.6 + resolution: "ws@npm:7.4.6" + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: ^5.0.2 + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + checksum: 3a990b32ed08c72070d5e8913e14dfcd831919205be52a3ff0b4cdd998c8d554f167c9df3841605cde8b11d607768cacab3e823c58c96a5c08c987e093eb767a + languageName: node + linkType: hard + +"ws@npm:^7.4.6": + version: 7.5.9 + resolution: "ws@npm:7.5.9" + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: ^5.0.2 + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + checksum: c3c100a181b731f40b7f2fddf004aa023f79d64f489706a28bc23ff88e87f6a64b3c6651fbec3a84a53960b75159574d7a7385709847a62ddb7ad6af76f49138 + languageName: node + linkType: hard + +"xmlhttprequest@npm:1.8.0": + version: 1.8.0 + resolution: "xmlhttprequest@npm:1.8.0" + checksum: c891cf0d7884b4f5cce835aa01f1965727cd352cbd2d7a2e0605bf11ec99ae2198364cca54656ec8b2581a5704dee6c2bf9911922a0ff2a71b613455d32e81b7 + languageName: node + linkType: hard + +"y18n@npm:^4.0.0": + version: 4.0.3 + resolution: "y18n@npm:4.0.3" + checksum: 014dfcd9b5f4105c3bb397c1c8c6429a9df004aa560964fb36732bfb999bfe83d45ae40aeda5b55d21b1ee53d8291580a32a756a443e064317953f08025b1aa4 + languageName: node + linkType: hard + +"y18n@npm:^5.0.5": + version: 5.0.8 + resolution: "y18n@npm:5.0.8" + checksum: 54f0fb95621ee60898a38c572c515659e51cc9d9f787fb109cef6fde4befbe1c4602dc999d30110feee37456ad0f1660fa2edcfde6a9a740f86a290999550d30 + languageName: node + linkType: hard + +"yallist@npm:^3.0.2": + version: 3.1.1 + resolution: "yallist@npm:3.1.1" + checksum: 48f7bb00dc19fc635a13a39fe547f527b10c9290e7b3e836b9a8f1ca04d4d342e85714416b3c2ab74949c9c66f9cebb0473e6bc353b79035356103b47641285d + languageName: node + linkType: hard + +"yallist@npm:^4.0.0": + version: 4.0.0 + resolution: "yallist@npm:4.0.0" + checksum: 343617202af32df2a15a3be36a5a8c0c8545208f3d3dfbc6bb7c3e3b7e8c6f8e7485432e4f3b88da3031a6e20afa7c711eded32ddfb122896ac5d914e75848d5 + languageName: node + linkType: hard + +"yaml@npm:^2.2.2": + version: 2.3.1 + resolution: "yaml@npm:2.3.1" + checksum: 2c7bc9a7cd4c9f40d3b0b0a98e370781b68b8b7c4515720869aced2b00d92f5da1762b4ffa947f9e795d6cd6b19f410bd4d15fdd38aca7bd96df59bd9486fb54 + languageName: node + linkType: hard + +"yargs-parser@npm:13.1.2, yargs-parser@npm:^13.1.2": + version: 13.1.2 + resolution: "yargs-parser@npm:13.1.2" + dependencies: + camelcase: ^5.0.0 + decamelize: ^1.2.0 + checksum: c8bb6f44d39a4acd94462e96d4e85469df865de6f4326e0ab1ac23ae4a835e5dd2ddfe588317ebf80c3a7e37e741bd5cb0dc8d92bcc5812baefb7df7c885e86b + languageName: node + linkType: hard + +"yargs-parser@npm:20.2.4": + version: 20.2.4 + resolution: "yargs-parser@npm:20.2.4" + checksum: d251998a374b2743a20271c2fd752b9fbef24eb881d53a3b99a7caa5e8227fcafd9abf1f345ac5de46435821be25ec12189a11030c12ee6481fef6863ed8b924 + languageName: node + linkType: hard + +"yargs-parser@npm:^20.2.2": + version: 20.2.9 + resolution: "yargs-parser@npm:20.2.9" + checksum: 8bb69015f2b0ff9e17b2c8e6bfe224ab463dd00ca211eece72a4cd8a906224d2703fb8a326d36fdd0e68701e201b2a60ed7cf81ce0fd9b3799f9fe7745977ae3 + languageName: node + linkType: hard + +"yargs-unparser@npm:1.6.0": + version: 1.6.0 + resolution: "yargs-unparser@npm:1.6.0" + dependencies: + flat: ^4.1.0 + lodash: ^4.17.15 + yargs: ^13.3.0 + checksum: ca662bb94af53d816d47f2162f0a1d135783f09de9fd47645a5cb18dd25532b0b710432b680d2c065ff45de122ba4a96433c41595fa7bfcc08eb12e889db95c1 + languageName: node + linkType: hard + +"yargs-unparser@npm:2.0.0": + version: 2.0.0 + resolution: "yargs-unparser@npm:2.0.0" + dependencies: + camelcase: ^6.0.0 + decamelize: ^4.0.0 + flat: ^5.0.2 + is-plain-obj: ^2.1.0 + checksum: 68f9a542c6927c3768c2f16c28f71b19008710abd6b8f8efbac6dcce26bbb68ab6503bed1d5994bdbc2df9a5c87c161110c1dfe04c6a3fe5c6ad1b0e15d9a8a3 + languageName: node + linkType: hard + +"yargs@npm:13.3.2, yargs@npm:^13.3.0": + version: 13.3.2 + resolution: "yargs@npm:13.3.2" + dependencies: + cliui: ^5.0.0 + find-up: ^3.0.0 + get-caller-file: ^2.0.1 + require-directory: ^2.1.1 + require-main-filename: ^2.0.0 + set-blocking: ^2.0.0 + string-width: ^3.0.0 + which-module: ^2.0.0 + y18n: ^4.0.0 + yargs-parser: ^13.1.2 + checksum: 75c13e837eb2bb25717957ba58d277e864efc0cca7f945c98bdf6477e6ec2f9be6afa9ed8a876b251a21423500c148d7b91e88dee7adea6029bdec97af1ef3e8 + languageName: node + linkType: hard + +"yargs@npm:16.2.0": + version: 16.2.0 + resolution: "yargs@npm:16.2.0" + dependencies: + cliui: ^7.0.2 + escalade: ^3.1.1 + get-caller-file: ^2.0.5 + require-directory: ^2.1.1 + string-width: ^4.2.0 + y18n: ^5.0.5 + yargs-parser: ^20.2.2 + checksum: b14afbb51e3251a204d81937c86a7e9d4bdbf9a2bcee38226c900d00f522969ab675703bee2a6f99f8e20103f608382936034e64d921b74df82b63c07c5e8f59 + languageName: node + linkType: hard + +"yn@npm:3.1.1": + version: 3.1.1 + resolution: "yn@npm:3.1.1" + checksum: 2c487b0e149e746ef48cda9f8bad10fc83693cd69d7f9dcd8be4214e985de33a29c9e24f3c0d6bcf2288427040a8947406ab27f7af67ee9456e6b84854f02dd6 + languageName: node + linkType: hard + +"yocto-queue@npm:^0.1.0": + version: 0.1.0 + resolution: "yocto-queue@npm:0.1.0" + checksum: f77b3d8d00310def622123df93d4ee654fc6a0096182af8bd60679ddcdfb3474c56c6c7190817c84a2785648cdee9d721c0154eb45698c62176c322fb46fc700 + languageName: node + linkType: hard + +"zksync-web3@npm:^0.14.3": + version: 0.14.3 + resolution: "zksync-web3@npm:0.14.3" + peerDependencies: + ethers: ^5.7.0 + checksum: e89760c13e01ec43433e1e38a473138948c6a8d3a825c0f0aa6328eb7d28c63037a5ee4c922c1fd7d9580d2bf2cbbf2c7911f5e4d872f856dc591850a7e6f260 + languageName: node + linkType: hard